最近各种数据库泄露问题,让我不得不考虑自身密码的强度,下面特意写两种生成密码的方法,已被日后之用;
介绍两种生成随机密码的方式:(在密码字典里面,可以根据实际需要,手工注释不需要生成的字符段)
方式一:
/** * 生成随机密码生成方式一 * 密码字典 -> 随机获取字符 * @param len 生成密码长度 * @return */ public static String getPassWordOne(int len){ int i; //生成的随机数 int count = 0; //生成的密码的长度 // 密码字典 char[] str = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '~', '!', '@', '#', '$', '%', '^', '-', '+' }; StringBuffer stringBuffer = new StringBuffer(""); Random r = new Random(); while(count < len){ //生成 0 ~ 密码字典-1之间的随机数 i = r.nextInt(str.length); stringBuffer.append(str[i]); count ++; } return stringBuffer.toString(); }
方式二:
/** * 生成随机密码生成方式二 * 密码字典 -> 随机打乱集合顺序 -> 随机获取字符 * @param len 生成密码长度 * @return */ public static String getPassWordTwo(int len){ int i; //生成的随机数 int count = 0; //生成的密码的长度 // 密码字典 char[] str = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '~', '!', '@', '#', '$', '%', '^', '-', '+' }; StringBuffer stringBuffer = new StringBuffer(""); List<String> list = new ArrayList<String>(); Random r = new Random(); for (i = 0; i<str.length; i++) { list.add(str[i] + ""); } Collections.shuffle(list); while(count < len){ //生成 0 ~ 密码字典-1之间的随机数 i = r.nextInt(list.size()); stringBuffer.append(list.get(i)); count ++; } return stringBuffer.toString(); }