此处以SHA256加密方式为例
若依分类版使用的是Spring Security,
第一步
在ruoyi-framework模块下security包,security是若依封装的认证失败处理类,找到framework模块下的config包下的SecuityConfig找到这两个方法
第二步
Spring Security通过passwordEncoder()进行身份认证,传入的参数是需要实现PasswrodEncoder接口的类,此处我用了SHA256加密方法进行举例
第三步
在ruoyi-common模块内新增一个SHA256PasswordEncoder实现PasswordEncoder接口,
SHA256需要自己新增一个加密工具类进行加密
以下是我用的SHA256加密算法写法
public class SHA256Util {
public static String hash(String input) {
try {
MessageDigest digest = MessageDigest.getInstance("SHA-256");
byte[] hash = digest.digest(input.getBytes(StandardCharsets.UTF_8));
StringBuilder hexString = new StringBuilder();
for (byte b : hash) {
String hex = Integer.toHexString(0xff & b);
if (hex.length() == 1) {
hexString.append('0');
}
hexString.append(hex);
}
return hexString.toString();
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException("无法找到SHA-256算法", e);
}
}
}
第四步
在ruoyi-framework模块下security包修改身份认证接口:
第五步
以上已经实现了登录时的sha256的验证,现在修改注册、修改密码时候的加密算法进行替换
common下的utils的SecurityUtils类中修改
根据以上5步xiug即可