在主要:
public static void main(String[] args) throws NoSuchAlgorithmException {
System.out.println("encrypt:" + encryptPassword("superuser")+":" );
}
public static String encryptPassword(final String password) throws NoSuchAlgorithmException {
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] hashPassword = md.digest(password.getBytes());
String encryPass = Base64.encodeBase64String(hashPassword);
return encryPass;
}
我得到这个输出:
encrypt:C66i8K4gFQ23j1jN2sRCqQ==:
但是当我在我的应用程序中实现相同的东西时,我得到了以下输出:
encrypt:C66i8K4gFQ23j1jN2sRCqQ==
:
注意:在我的加密字符串上附加新行。
应用代码:
public boolean authenticateUsernamePasswordInternal(UsernamePasswordCredentials credentials) {
try {
System.out.println("encrypt:" + getHash("superuser")+":" );
} catch (Exception e) {
logger.error(e.getMessage(), e);
throw new BadCredentialsAuthenticationException(ErrorConstants.CONNECTION_FAILED);
}
}
private String getHash(String password) throws NoSuchAlgorithmException, UnsupportedEncodingException{
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] hashPassword = md.digest(password.getBytes());
String encryPass = Base64.encodeBase64String(hashPassword);
return encryPass;
}
如何删除多余的新行。 为什么会这样,请帮我是什么原因?
最佳答案
我可能回答迟了,但遇到了同样的问题。其实问题出在这里
Base64.encodeBase64String(hashPassword)
将该行更改为它应该可以工作的样子:
Base64.encodeBase64String(hashPassword,Base64.NO_WRAP)
默认情况下,Android Base64 实用程序会在编码字符串的末尾添加一个换行符。 Base64.NO_WRAP 标志告诉 util 创建不带换行符的编码字符串。
检查 here
关于java - 在我的加密字符串上附加新行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20040539/