用html做的网站步骤,广告设计公司排行,2345网址导航12年11个,青春网站建设工作室若依虽然有加密解密功能#xff0c;然后只有前端有#xff0c;在用户点击保存密码的时候#xff0c;会将密码保存到本地#xff0c;但是为了防止密码泄露#xff0c;所以在保存的时候#xff0c;进行加密#xff0c;在回显密码的时候进行解密显示#xff0c;用户在登录…若依虽然有加密解密功能然后只有前端有在用户点击保存密码的时候会将密码保存到本地但是为了防止密码泄露所以在保存的时候进行加密在回显密码的时候进行解密显示用户在登录的时候密码照样会明文传输我们可以使用为了解决这个问题我们可以在登陆的时候前端加密后端解密验证密码正确性。 代码如下 首先去生成秘钥然后复制里面的公钥和私钥
前端代码
然后把公钥和私钥粘贴到前端的jsencrypt.js文件中注意粘贴的使用要先输入一对双引号使用idea进行粘贴如果使用vscode粘贴就无法出现\n
import JSEncrypt from jsencrypt/bin/jsencrypt.min// 密钥对生成 http://web.chacuo.net/netrsakeypairconst publicKey MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEArWms4iFd/TMBkAae2FP8\n 4Typ80/uvIRo1cN9AR9ircKkIjpksCUC/mnopE1WsSk/Kqtf8aDAOxJ9Bs6drCs\n 9GxfduwoIjbAR9mllzoP67ncn1dtuLXU6w/Va/pt8YebtzhZqfp7DVs5IGwkXf1c\n Xxfw9dxa9F8ftlCEHSQxBFcn8707XJ3iGNRBcp8gSZofiaj8Xn1Ws4kUyBb6Dg4\n f2SaBreaof7Wl9QWXkgXG7egHj4xtC5ztiBnFa8GC55ecBDLnO3EyTvY9PzvAd5Y\n Aj7FDNN70w1zeazunX02oeMQaTmtOGag73StoipsNbO8zbeeDblgXT1xNcrAx5m\n XwIDAQABconst privateKey MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCtaaziIV39MwGQ\n Bp7YU/zhPKnzT68hGjVw30BH2KtwqQiOmSwJQLaeikTVaxKT8qq1/xoMA7En0G\n zp2sKz70bF927CgiNsBH2aWXOg/rudyfV224tdTrD9Vrm3xh5u3OFmpnsNWzkg\n bCRd/VxfF/D13Fr0Xx2UIQdJDEEVyfzvTtcneIY1EFynyBL5mhJqPxefVaziRT\n IFvoODh/ZJoGt5qh/taX1BZeSBcbt6AePjG0LnO2IGcVrwYLnl5wEMuc7cTJO9j0\n /O8B3lgCPsUM03vTDXN5rO6dfTah4xBr5Oa04ZqDvdK2iKmw1s7zNt54NuWBdPXE\n 1ysDHmZfAgMBAAECggEABPVqniS6HU1iFA48aI8uQfqMGYsFlppqrQIkBu4w0iso\n qlnlGyxTw5afsmMLwZEeX0f7PFuOY6IJtTIfTBcIe9DFgg8Krr/GC8frdkGQxvrP\n ljbXylpYtkgDoEzO7AMmrryLw9KHxj//iC/PcmiWRZnXqBAfAbHepEX1ISgxxp/z\n UKNURlMNvCQT93p/3j9oacKIFMEKqShDTvus139uK9EmL3D8mm3Bp/kI4mOyKua3\n byuGG6kpmEACclWhNdCKN8dz7jLYbCWcOdWD6koqdSZy10Dbf6BD0FPhVJ9oFRC2\n g7l9vlihZJB9BkrZhb/bDOhhb2kyrPUlVR6dxRzgQKBgQDfMeTGX8Bdi8MIEH3u\n RbPt/vDR//sXFfEYt/p0gqCWZuAnT2eDo14pAuuQjc0idoQxpiazmAZR9/33td1L\n KYKb5WBogb56J7bI/w0u0MpG3TCyd6QIr1XXsDOuaEzhjKmwW3TwN1UI8YNjMGl\n vb36Vy3PL3wYVfFE28iI5ScfwKBgQDG5qQmE6I4zKKloXTqfNGs0PGkOXzAYbr\n eFDSePQGMb7qTWtnrBGAz9PqKXffzLIn/u2EO2cSheglSWfJKos55Fj/tFnTGuws\n ELJZldOi1kXGeABKUryl3T3kti8PWXx2zDvmp98m0I0C5Qo51gUDVLPnXOVAW\n lE0DvhTGIQKBgQChac/ttynDfWQa3PJ182rg39MBzIKme3PVUJiM0juZCeVqCH7w\n MKHUPwxlimekWNnZnjO3BmbruNGu55OW2/pdDFHgwpQjEtKv4SJwcE1t2TFj/eI7\n kyQjn58I4i62uILBHnpy/bQTOZvuCLGzT7mo5ot2nvy8DjbLy/Y/VkQPuQKBgQCq\n X1vSBdVaK8myLpc5pITvVZTDnNBrpC42utu4PcUBHVFkj6Zlql1f0iW6mYTGHieo\n 3NQFBYEXu74LWmJdTWTu1OtrNMgQbSpJ4I9070LWYZmx9mwXvPfZeaTGgHHIZGt\n TjSbQxsjASpmdzSE/LbAzlODhsAHnF8yA9kGkjfIQKBgEA2GzJIUnuzT8WTdSZL\n rJ0/6SBkSd9rlQvBx2jWa4G92zD6MeItbgEp8xlRKWzRfwGmEnt7R0SC3eGzWV\n EToc3UVRi750Cd0qNo7Q7blfnzGuca16t5lTaeeCp3P8FVlDbhg1F5ijrDNItoSH\n wWlvkBwJ0C1nQsBVrV08quVy// 加密
export function encrypt(txt) {const encryptor new JSEncrypt()encryptor.setPublicKey(publicKey) // 设置公钥return encryptor.encrypt(txt) // 对数据进行加密
}// 解密
export function decrypt(txt) {const encryptor new JSEncrypt()encryptor.setPrivateKey(privateKey) // 设置私钥return encryptor.decrypt(txt) // 对数据进行解密
}然后调用登录接口的encrypt方法对密码进行加密 到这里浏览器出现的密码被加密了就说明前端代码就搞定了
后端代码
在com.ruoyi.common.utils.sign包下新建RsaUtils类把私钥粘贴过来
package com.ruoyi.common.utils.sign;import org.apache.commons.codec.binary.Base64;import javax.crypto.Cipher;
import java.security.KeyFactory;
import java.security.PrivateKey;
import java.security.spec.PKCS8EncodedKeySpec;/*** RSA加密解密** author ruoyi**/
public class RsaUtils {// Rsa 私钥public static String privateKey MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCtaaziIV39MwGQ\n Bp7YU/zhPKnzT68hGjVw30BH2KtwqQiOmSwJQLaeikTVaxKT8qq1/xoMA7En0G\n zp2sKz70bF927CgiNsBH2aWXOg/rudyfV224tdTrD9Vrm3xh5u3OFmpnsNWzkg\n bCRd/VxfF/D13Fr0Xx2UIQdJDEEVyfzvTtcneIY1EFynyBL5mhJqPxefVaziRT\n IFvoODh/ZJoGt5qh/taX1BZeSBcbt6AePjG0LnO2IGcVrwYLnl5wEMuc7cTJO9j0\n /O8B3lgCPsUM03vTDXN5rO6dfTah4xBr5Oa04ZqDvdK2iKmw1s7zNt54NuWBdPXE\n 1ysDHmZfAgMBAAECggEABPVqniS6HU1iFA48aI8uQfqMGYsFlppqrQIkBu4w0iso\n qlnlGyxTw5afsmMLwZEeX0f7PFuOY6IJtTIfTBcIe9DFgg8Krr/GC8frdkGQxvrP\n ljbXylpYtkgDoEzO7AMmrryLw9KHxj//iC/PcmiWRZnXqBAfAbHepEX1ISgxxp/z\n UKNURlMNvCQT93p/3j9oacKIFMEKqShDTvus139uK9EmL3D8mm3Bp/kI4mOyKua3\n byuGG6kpmEACclWhNdCKN8dz7jLYbCWcOdWD6koqdSZy10Dbf6BD0FPhVJ9oFRC2\n g7l9vlihZJB9BkrZhb/bDOhhb2kyrPUlVR6dxRzgQKBgQDfMeTGX8Bdi8MIEH3u\n RbPt/vDR//sXFfEYt/p0gqCWZuAnT2eDo14pAuuQjc0idoQxpiazmAZR9/33td1L\n KYKb5WBogb56J7bI/w0u0MpG3TCyd6QIr1XXsDOuaEzhjKmwW3TwN1UI8YNjMGl\n vb36Vy3PL3wYVfFE28iI5ScfwKBgQDG5qQmE6I4zKKloXTqfNGs0PGkOXzAYbr\n eFDSePQGMb7qTWtnrBGAz9PqKXffzLIn/u2EO2cSheglSWfJKos55Fj/tFnTGuws\n ELJZldOi1kXGeABKUryl3T3kti8PWXx2zDvmp98m0I0C5Qo51gUDVLPnXOVAW\n lE0DvhTGIQKBgQChac/ttynDfWQa3PJ182rg39MBzIKme3PVUJiM0juZCeVqCH7w\n MKHUPwxlimekWNnZnjO3BmbruNGu55OW2/pdDFHgwpQjEtKv4SJwcE1t2TFj/eI7\n kyQjn58I4i62uILBHnpy/bQTOZvuCLGzT7mo5ot2nvy8DjbLy/Y/VkQPuQKBgQCq\n X1vSBdVaK8myLpc5pITvVZTDnNBrpC42utu4PcUBHVFkj6Zlql1f0iW6mYTGHieo\n 3NQFBYEXu74LWmJdTWTu1OtrNMgQbSpJ4I9070LWYZmx9mwXvPfZeaTGgHHIZGt\n TjSbQxsjASpmdzSE/LbAzlODhsAHnF8yA9kGkjfIQKBgEA2GzJIUnuzT8WTdSZL\n rJ0/6SBkSd9rlQvBx2jWa4G92zD6MeItbgEp8xlRKWzRfwGmEnt7R0SC3eGzWV\n EToc3UVRi750Cd0qNo7Q7blfnzGuca16t5lTaeeCp3P8FVlDbhg1F5ijrDNItoSH\n wWlvkBwJ0C1nQsBVrV08quVy;/*** 私钥解密** param privateKeyString 私钥* param text 待解密的文本* return 解密后的文本*/public static String decryptByPrivateKey(String text) throws Exception {return decryptByPrivateKey(privateKey, text);}/*** 私钥解密** param privateKeyString 私钥* param text 待解密的文本* return 解密后的文本*/public static String decryptByPrivateKey(String privateKeyString, String text) throws Exception {PKCS8EncodedKeySpec pkcs8EncodedKeySpec5 new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyString));KeyFactory keyFactory KeyFactory.getInstance(RSA);PrivateKey privateKey keyFactory.generatePrivate(pkcs8EncodedKeySpec5);Cipher cipher Cipher.getInstance(RSA);cipher.init(Cipher.DECRYPT_MODE, privateKey);byte[] result cipher.doFinal(Base64.decodeBase64(text));return new String(result);}}然后再登录接口那里对密码进行解密同时如果解密成功抛出异常代码如下
/*** 登录方法* * param loginBody 登录信息* return 结果*/
PostMapping(/login)
public AjaxResult login(RequestBody LoginBody loginBody) throws Exception
{AjaxResult ajax AjaxResult.success();// 生成令牌String token loginService.login(loginBody.getUsername(), RsaUtils.decryptByPrivateKey(loginBody.getPassword()), loginBody.getCode(),loginBody.getUuid());ajax.put(Constants.TOKEN, token);return ajax;
}到此代码就结束了最终测试登录成功再测试记住密码功能也正常如果下次想要该公钥和私钥记得前后端都要改 这里只是演示了基于若依自带的密码工具进行加密如果想要基于别的工具进行加密解密可以研究一下sm-crypto