项目上使用了一个明文的密码,为了安全起见,客户要求不准使用明码,所以改为SHA256加密,具体方法如下,留着以后方便使用。
1、工具方法
//加密SHA256
public static String getSHA256(String str) {
LogUtils.i(TAG, "getSHA256 == " + str);
MessageDigest messageDigest;
String encodestr = "";
try {
messageDigest = MessageDigest.getInstance("SHA-256");
messageDigest.update(str.getBytes("UTF-8"));
encodestr = byte2HexSHA(messageDigest.digest());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
LogUtils.i(TAG, "getSHA256 encodestr == " + encodestr);
return encodestr;
}
private static String byte2HexSHA(byte[] bytes) {
StringBuffer stringBuffer = new StringBuffer();
String temp = null;
for (int i = 0; i < bytes.length; i++) {
temp = Integer.toHexString(bytes[i] & 0xFF);
if (temp.length() == 1) {
stringBuffer.append("0");
}
stringBuffer.append(temp);
}
return stringBuffer.toString();
}
2、使用方法
String pwSHA256 = getSHA256("123456789密码");
pwSHA256.equals("c14985fca7f4c84eeb545327910bda74fbe7b95f6a70df58ef119739b12baeb");
上面的"123456789密码"其实应该是EditText里面客户输入的,然后需要找一个网站把
“123456789密码”加密成对应的SHA256加密后的字符串进行对比即可。
比如我加密后的“c14985fca7f4c84eeb545327910bda74fbe7b95f6a70df58ef119739b12baeb1”。