package com.tiesheng.util.config; import cn.hutool.core.codec.Base64; import cn.hutool.core.util.RandomUtil; import cn.hutool.core.util.StrUtil; import cn.hutool.crypto.SecureUtil; import cn.hutool.crypto.SmUtil; import cn.hutool.crypto.symmetric.SM4; import com.tiesheng.util.exception.ApiException; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Configuration; /** * @author hao */ @Configuration @ConfigurationProperties(prefix = "tiesheng.encrypt") public class EncryptConfig { /** * 加解密对象 */ private final SM4 sm4; /** * 加密密钥 */ private String key = "WmdUzPJXbngVNiaSsQrihg=="; private Integer saltSize = 8; private boolean body = false; private String pwdPatten = "^(?![A-Za-z0-9]+$)(?![a-z0-9\\W]+$)(?![A-Za-z\\W]+$)(?![A-Z0-9\\W]+$)[a-zA-Z0-9\\W]{8,}$"; public EncryptConfig() { sm4 = SmUtil.sm4(Base64.decode(getKey())); } /** * 加密 * * @param content * @return */ public String encrypt(String content) { if (StrUtil.isEmpty(content)) { return ""; } return sm4.encryptBase64(content); } /** * 解密 * * @param base64 * @return */ public String decrypt(String base64) { try { return sm4.decryptStr(base64); } catch (Exception ignore) { } return base64; } /** * 创建密码 * * @param inputPasswd * @param salt 盐,不存将自动生成 * @return */ public String passwdCreate(String inputPasswd, String salt) { if (StrUtil.isEmpty(salt) || StrUtil.length(salt) != getSaltSize()) { salt = RandomUtil.randomString(saltSize); } if (!inputPasswd.matches(getPwdPatten())) { throw new ApiException("密码复杂度不够,请重新设置"); } return encrypt(salt + SecureUtil.sha1(salt + inputPasswd)); } /** * 密码校验 * * @param inputPasswd */ public void passwdVerify(String inputPasswd, String encrypted) { String salt = decrypt(encrypted).substring(0, saltSize); String inputEncrypted = passwdCreate(inputPasswd, salt); if (!StrUtil.equals(inputEncrypted, encrypted)) { throw new ApiException("账号或密码错误"); } } /////////////////////////////////////////////////////////////////////////// // setter\getter /////////////////////////////////////////////////////////////////////////// public String getKey() { return key; } public void setKey(String key) { this.key = key; } public Integer getSaltSize() { return saltSize; } public void setSaltSize(Integer saltSize) { this.saltSize = saltSize; } public boolean isBody() { return body; } public void setBody(boolean body) { this.body = body; } public String getPwdPatten() { return pwdPatten; } public void setPwdPatten(String pwdPatten) { this.pwdPatten = pwdPatten; } }