位置: IT常识 - 正文

前端加密,后端解密的过程及代码(密码明文传输解决,不是太保险。key在前端有显示)(前端加密后端解密代码)

编辑:rootadmin
前端加密,后端解密的过程及代码(密码明文传输解决,不是太保险。key在前端有显示)

推荐整理分享前端加密,后端解密的过程及代码(密码明文传输解决,不是太保险。key在前端有显示)(前端加密后端解密代码),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:前端加密,后端加密,前端加密后端解密的数据库系统,前端加密后端解密的数据库系统,前端加密后端解密 优点有哪些,前端加密后端解密方式,前端加密后端解密的数据库系统,前端加密后端解密代码,前端加密后端解密,内容如对您有帮助,希望把文章链接给更多的朋友!

在工作中经常遇到密码明文传输这个问题,为了让密码安全些会让加密,现在有个比较方便的AES加密分享给大家,话不多说,上代码

1,首先引入前端需要用到的js:crypto-js,下载命令    npm install crypto-js

将 crypto-js 文件放到要引用的路径

以下是要引用到的js

2,引用,jQuery也要记得引用哦

前端加密,后端解密的过程及代码(密码明文传输解决,不是太保险。key在前端有显示)(前端加密后端解密代码)

 3,在登录页的登录按钮的function里,设置key值和iv值,这是加密的设置字段,定义要进行加密的密码passwordNode

 下面再加个function

function aesMinEncrypt(key, iv, word){var _word = CryptoJS.enc.Utf8.parse(word),_key = CryptoJS.enc.Utf8.parse(key),_iv = CryptoJS.enc.Utf8.parse(iv);var encrypted = CryptoJS.AES.encrypt(_word, _key, {iv: _iv,mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7});return encrypted.toString();}

3,(另一种)上面的过程也可以这样

function encryption(){//密钥 (需要前端和后端保持一致)十六位作为密钥var key = "ABCDEFGHIJKL_key";//密钥偏移量 (需要前端和后端保持一致)十六位作为密钥偏移量var iv = "ABCDEFGHIJKLM_iv";var username=document.getElementById("usr").value;// var passwordNode=document.getElementById("paw").value;var passwordNode=aesMinEncrypt(key,iv,$("#paw").val());console.log(passwordNode);alert("加密后的密码为:"+passwordNode);$.ajax({url: "login",async:false,type: "POST",data: {'username':username,'password':passwordNode},success: function (result) {$("html").html(result);}});}function aesMinEncrypt(key, iv, word){var _word = CryptoJS.enc.Utf8.parse(word),_key = CryptoJS.enc.Utf8.parse(key),_iv = CryptoJS.enc.Utf8.parse(iv);var encrypted = CryptoJS.AES.encrypt(_word, _key, {iv: _iv,mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7});return encrypted.toString();$("#form").submit();}

4,前端加密就算是完成了,接下来是后端解密,后端解密需要用到一个工具类   AESUtils,里面是解密方法代码如下

package com.wuye.common.utils;import cn.jpush.api.utils.StringUtils;import sun.misc.BASE64Decoder;import javax.crypto.Cipher;import javax.crypto.spec.IvParameterSpec;import javax.crypto.spec.SecretKeySpec;/** * TODO * * @author CSD * @date 2022-07-28 14:16 */public class AESUtils { //密钥 (需要前端和后端保持一致)十六位作为密钥 private static final String KEY = "ABCDEFGHIJKL_key"; //密钥偏移量 (需要前端和后端保持一致)十六位作为密钥偏移量 private static final String IV = "ABCDEFGHIJKLM_iv"; //算法 private static final String ALGORITHMSTR = "AES/CBC/PKCS5Padding"; /** * base 64 decode * @param base64Code 待解码的base 64 code * @return 解码后的byte[] * @throws Exception */ public static byte[] base64Decode(String base64Code) throws Exception{ return StringUtils.isEmpty(base64Code) ? null : new BASE64Decoder().decodeBuffer(base64Code); } /** * AES解密 * @param encryptBytes 待解密的byte[] * @return 解密后的String * @throws Exception */ public static String aesDecryptByBytes(byte[] encryptBytes) throws Exception { Cipher cipher = Cipher.getInstance(ALGORITHMSTR); byte[] temp = IV.getBytes("UTF-8"); IvParameterSpec iv = new IvParameterSpec(temp); cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(KEY.getBytes(), "AES"), iv); byte[] decryptBytes = cipher.doFinal(encryptBytes); System.out.print(new String(decryptBytes)); return new String(decryptBytes); } /** * 将base 64 code AES解密 * @param encryptStr 待解密的base 64 code * @return 解密后的string * @throws Exception */ public static String aesDecrypt(String encryptStr) throws Exception { return StringUtils.isEmpty(encryptStr) ? null : aesDecryptByBytes(base64Decode(encryptStr)); } //测试一下 public static void main(String[] args) throws Exception { String str = "Q uus tQvLdwtGSldhrtKQ=="; str = str.replace(" ", "+"); System.out.println(str); aesDecrypt(str); }}

5,在密码验证的java页面做解密,建议打断点看看走的哪里,解密很简单,就一句

password = AESUtils.aesDecrypt(getPassword(request));

看你的具体页面需不需要抛个异常,我本身是下面这种情况

在另外一个项目里,我又发现,解密语句很简单,但是最重要是看你的登录走的哪里,然后出现如下

 但是大差不差,核心语句就是使用解密类的方法对获取到的密码进行解密。

谢谢大家的观看,也希望各位大佬能给出好的建议,如果觉得不错就点个赞再走吧,嘿嘿!

本文链接地址:https://www.jiuchutong.com/zhishi/288820.html 转载请保留说明!

上一篇:Vue3 + Vite 多入口配置(vue多入口文件)

下一篇:秋日里通往卢浮宫的杜乐丽花园,法国巴黎 (© Brian A. Jackson/Getty Images Plus)

  • 微信营销怎样做?(微信营销怎么做步骤)

    微信营销怎样做?(微信营销怎么做步骤)

  • iqooz5x双击亮屏在哪设置

    iqooz5x双击亮屏在哪设置

  • 小米手机怎么远程控制父母的手机(小米手机怎么远程开空调)

    小米手机怎么远程控制父母的手机(小米手机怎么远程开空调)

  • h0n0r是什么牌手机(h0n0r是什么牌手机怎么修改锁屏密码)

    h0n0r是什么牌手机(h0n0r是什么牌手机怎么修改锁屏密码)

  • 十进制数90转换成二进制数(十进制数90转换为十六进制数为)

    十进制数90转换成二进制数(十进制数90转换为十六进制数为)

  • 荣耀手机虚拟按键设置在哪里(荣耀手机虚拟按键怎么设置出来)

    荣耀手机虚拟按键设置在哪里(荣耀手机虚拟按键怎么设置出来)

  • 在拼多多上买东西能被微信好友看到吗(在拼多多买东西被骗了怎样来维护自身的权益)

    在拼多多上买东西能被微信好友看到吗(在拼多多买东西被骗了怎样来维护自身的权益)

  • 华为nova6微信视频美颜怎么设置(华为nova6微信视频)

    华为nova6微信视频美颜怎么设置(华为nova6微信视频)

  • imessage尚未送达是什么意思

    imessage尚未送达是什么意思

  • 手机桌面文件夹不见了(手机桌面文件夹怎么设置)

    手机桌面文件夹不见了(手机桌面文件夹怎么设置)

  • 美团没有营业执照怎么入驻(美团没有营业执照能上吗)

    美团没有营业执照怎么入驻(美团没有营业执照能上吗)

  • ags2-w09hn是什么型号(ags2wo9是什么型号)

    ags2-w09hn是什么型号(ags2wo9是什么型号)

  • 小黄车什么意思(仪表盘出现小黄车什么意思)

    小黄车什么意思(仪表盘出现小黄车什么意思)

  • 电脑管理员权限怎么解除(电脑管理员权限在哪里win10)

    电脑管理员权限怎么解除(电脑管理员权限在哪里win10)

  • ps变换选区是按哪个键(ps选择变换选区)

    ps变换选区是按哪个键(ps选择变换选区)

  • 怎么将2g网换成4g网(如何2g网络改成4g)

    怎么将2g网换成4g网(如何2g网络改成4g)

  • 微博私信误删怎么恢复(微博私信删除了可以恢复吗)

    微博私信误删怎么恢复(微博私信删除了可以恢复吗)

  • 华为屏幕组件包括什么(华为屏幕组件包括电池吗)

    华为屏幕组件包括什么(华为屏幕组件包括电池吗)

  • 电脑屏幕怎么截图按键(电脑屏幕怎么截图保存)

    电脑屏幕怎么截图按键(电脑屏幕怎么截图保存)

  • 手机固件什么意思(手机固件有什么用)

    手机固件什么意思(手机固件有什么用)

  • vsco色温在哪(vsco色温在哪里调)

    vsco色温在哪(vsco色温在哪里调)

  • 苹果xs是高通基带吗

    苹果xs是高通基带吗

  • 三星w系列全捐公益吗(三星wa)

    三星w系列全捐公益吗(三星wa)

  • element-ui table使用type=‘selection‘复选框全禁用-全选禁用

    element-ui table使用type=‘selection‘复选框全禁用-全选禁用

  • 帝国cms万能标签实现标题截取后自动加入省略号的方法(帝国cms插件编写教程)

    帝国cms万能标签实现标题截取后自动加入省略号的方法(帝国cms插件编写教程)

  • 销项税大于进项税时怎么处理
  • 转登记纳税人按规定再次登记为一般纳税人后
  • 非征税期抄税如何解决
  • 宁波财税网会计招聘
  • 什么是减免税额90%
  • 按份共同保证和连带共同保证
  • 付款方和发票抬头不一致如何账务处理
  • 企业会计准则可以中途变更吗
  • 上期金额和本期金额是什么意思
  • 注册资本金实缴和认缴区别
  • 自然人扣缴是什么意思
  • 厂区打地坪会计怎么做账
  • 安装服务费发票需要备注地址吗
  • 名义股东转让股份侵权
  • 银行转账结算方式的种类及适用范围
  • 收到政府补助的固定资产的账务处理
  • 进项转出后还能转入吗
  • 全资子公司向母公司划转资产 土地增值税
  • 系统技术维护费计入什么科目
  • 应付职工薪酬的账务处理
  • 出口退税金额和进项税额不一致
  • 企业计提工资的操作步骤
  • 代购本无罪,逃避关税须处罚
  • 餐饮行业采购流程图
  • 19年新会计制度
  • 以前年度损益调整贷方余额表示什么
  • 个体工商户开9%的税需要什么
  • 银行承兑汇票没有提示付款
  • 文件类型错误请重新选择
  • 本年收益在借方还结转吗
  • 稿酬计入工资所得吗
  • 增值税留抵税额在借方还是贷方
  • 法定盈余公积金转增资本
  • 苹果系统的声音
  • 提前支付的费用记账
  • 转出未交增值税会计科目
  • 茶叶的种类有哪些,八大茶类你都知道吗?
  • config.cfg是什么文件
  • 收到单据
  • 怎么检查当年的核酸结果
  • 解决跨域问题的注解
  • thinkphp框架怎么用
  • nodejs安装及环境配置win10
  • yolo系列算法比较
  • typescript类型别名
  • Ubuntu VPS中wordpress网站打开时提示”建立数据库连接错误”的解决办法
  • 金蝶存货核算不能结账,能强制结账吗
  • 固定资产原值怎么确定
  • php怎么关闭
  • c语言常用函数用法
  • 个人抬头的发票可以入账吗
  • 路桥费税率是几个点
  • 以货换货合同
  • 4.建筑业企业资质
  • 开红字发票做账时记账凭证上如何写摘要?
  • 契税发票错了能作废吗
  • 教材出版 技术咨询服务费
  • 将外购商品用于赠送客户
  • 如何避免电子发票重复报销的情况
  • 商贸公司库存表怎么做
  • 工会经费的减除项是什么
  • 企业取得的土地使用权用于自行开发建造厂房
  • Mysql中LAST_INSERT_ID()的函数使用详解
  • sqlserver 获取字符位置
  • 存储过程怎么理解
  • 老毛桃winpe系统对注册表信息进行备份的方法
  • Win10预览版怎么变回正式版
  • LINUX下的磁盘编辑工具
  • 红石数据
  • windows7怎么关不了机怎么办
  • nodejs filereader
  • android 一个绚丽的loading动效分析与实现!
  • nginx日志按天切割
  • python 条件变量
  • canvas+javascript
  • 出口企业能否更换法人
  • 2016年小微企业所得税优惠政策文号
  • 免税关口
  • 地方税务局发票管理所
  • 国地税合并6月15日挂牌
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设