当前位置: 首页 > news >正文

用html做的网站步骤广告设计公司排行

用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
http://www.pierceye.com/news/967624/

相关文章:

  • 素材图库网站源码网站建设及推广培训班
  • 英国电商网站jsp旅游网站开发系统
  • 机关网站建设引导语开发一个企业网站需要多少钱
  • 徐汇网站推广挣钱最快的小游戏
  • 手机网站开发的目的在线免费看影视网站
  • 湖州网站设计wordpress自动删除p标签
  • 昆明几大网站学生网站建设实训总结
  • 丽江手机网站建设建设公司起名大全
  • seo网站分析工具wordpress的安装包
  • 北京网站建设报价表徐州专业做网站
  • 怎样做网站卖网站国内免费开源crm
  • wordpress多语言网站济宁住房和城乡建设厅网站
  • 免费crm网站下载网站建设 繁体
  • 东莞企业官方网站建设网站建设对产品推销作用大吗
  • php网站路径问题站长工具权重查询
  • 箱包官方网站模板摄影后期教程网站
  • iis 手机网站同域名网站改版需要把之前网站里的文章都拷贝过来吗?
  • 网站是专门对生活中的一些所谓常识做辟谣的商标设计网站排行
  • seo网站设计营销工具抽奖网站插件
  • 家装设计网站大全网站建设用哪个好
  • 青海企业网站建设企业建设网
  • 电子商务网站环境建设怎么劝客户做网站
  • 山西教育学会的网站建设网站投放广告教程
  • 游戏网站的设计方案做装修业务呢有多少网站
  • 口碑好网站建设公司电话百度联盟网站备案信息
  • 网站建设排行公司建筑网页设计详情
  • 德国的网站后缀技术支持 东莞网站建设母婴护理
  • 彩票娱乐网站建设wordpress 邮件推送
  • 如何申请网站备案如何选择邯郸做网站
  • 专注做一家男生最爱的网站北京旅游设计网站建设