位置: 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)

  • 微信解封邀请辅助过期怎么办(微信解封邀请好友辅助多久失效)

    微信解封邀请辅助过期怎么办(微信解封邀请好友辅助多久失效)

  • 联发科与高通骁龙区别(联发科高通骁龙)

    联发科与高通骁龙区别(联发科高通骁龙)

  • amd840等于i几(amdx4 840相当于i几)

    amd840等于i几(amdx4 840相当于i几)

  • 华为p40怎么关闭系统更新(华为p40怎么关闭广告推送)

    华为p40怎么关闭系统更新(华为p40怎么关闭广告推送)

  • 输入法手机平方怎么打出来m2(手机搜狗输入法怎么打出平方)

    输入法手机平方怎么打出来m2(手机搜狗输入法怎么打出平方)

  • c盘里的program files可以删吗(c盘里的program files(x86)可以移动吗)

    c盘里的program files可以删吗(c盘里的program files(x86)可以移动吗)

  • 苹果11玩一会就发热正常吗(苹果11玩一会就发烫怎么解决)

    苹果11玩一会就发热正常吗(苹果11玩一会就发烫怎么解决)

  • bmp格式文件存在哪两种(bmp文件存储格式)

    bmp格式文件存在哪两种(bmp文件存储格式)

  • qq音乐付费包和会员有什么区别(qq音乐付费包和绿钻)

    qq音乐付费包和会员有什么区别(qq音乐付费包和绿钻)

  • 抖音歌曲版权原因限制分享怎么解决(抖音 bgm 版权)

    抖音歌曲版权原因限制分享怎么解决(抖音 bgm 版权)

  • 2080s和2080ti差多少(2080s和2080ti性能差距有多大)

    2080s和2080ti差多少(2080s和2080ti性能差距有多大)

  • 如山是小米旗下的吗(如山是小米旗下品牌吗)

    如山是小米旗下的吗(如山是小米旗下品牌吗)

  • 计算机主板上的组成部件一般通过什么连接(计算机主板上的南桥为什么叫南桥)

    计算机主板上的组成部件一般通过什么连接(计算机主板上的南桥为什么叫南桥)

  • 单卡手机如何能用双卡(单卡手机如何能用主副卡)

    单卡手机如何能用双卡(单卡手机如何能用主副卡)

  • 为什么vivo手机收到信息不显示内容(为什么vivo手机玩一会就很烫)

    为什么vivo手机收到信息不显示内容(为什么vivo手机玩一会就很烫)

  • 钉钉重新提交作业会有显示吗(钉钉重新提交作业老师知道吗)

    钉钉重新提交作业会有显示吗(钉钉重新提交作业老师知道吗)

  • ios10.3.3微信不兼容怎么办(ios10.3.3微信不兼容怎么办 此时无法下载微信)

    ios10.3.3微信不兼容怎么办(ios10.3.3微信不兼容怎么办 此时无法下载微信)

  • 5g手机是不是更费流量(5g手机是不是更耗电)

    5g手机是不是更费流量(5g手机是不是更耗电)

  • 天猫魔盒ip地址在哪(天猫魔盒ip地址怎么查)

    天猫魔盒ip地址在哪(天猫魔盒ip地址怎么查)

  • 荣耀20i多少瓦快充(荣耀20功率多少)

    荣耀20i多少瓦快充(荣耀20功率多少)

  • 红米k20有dc调光吗(红米k20pro的dc调光)

    红米k20有dc调光吗(红米k20pro的dc调光)

  • WPS如何删除多余的一页(wps如何删除多余的列)

    WPS如何删除多余的一页(wps如何删除多余的列)

  • 网易云拉黑能私信么(网易云拉黑对方能发消息吗)

    网易云拉黑能私信么(网易云拉黑对方能发消息吗)

  • window10怎么清理c盘(win10如何彻底清理c)

    window10怎么清理c盘(win10如何彻底清理c)

  • 京东轻松购有什么用(轻松购物)

    京东轻松购有什么用(轻松购物)

  • 带息负债融资成本率意义
  • 企业所得税属于地方税吗
  • 工商年报主营业务怎么填
  • 以前未入账固定资产补入账涉及的房产税
  • 减免税款借贷方表示
  • 税费退库怎么做凭证
  • 向投资者支付的股息红利等权益性投资收益款项
  • 小企业会计准则调整以前年度费用分录
  • 转给子公司发工资分录
  • 同一控制下企业合并取得的长期股权投资
  • 营改增对房地产行业的影响
  • 合同方和付款方不一致,发票开付款方可以吗
  • 帮客户代付保证金违法吗
  • 保险收入如何做账务处理?
  • 企业设备融资是什么意思?
  • 外地预缴企业所得税税率
  • 非生产企业主营业务成本
  • 个人转让认缴出资股权需要交纳印花税吗?
  • 税务行政复议范围不包括
  • 兼营小规模纳税人增值税优惠
  • 出口零税率是什么意思
  • 电子税务局里的利润表,本月金额是填累计数吗
  • 自己从自己公司直接拿钱是犯罪吗知乎
  • 信息服务业税收优惠政策
  • 广告业发生错账怎么办
  • 可持续增长率计算例题
  • 五险一金的会计分录怎么写
  • 简易计税 科目
  • Yii2使用驼峰命名的形式访问控制器的示例代码
  • 返利给客户的账务处理
  • 银行承兑汇票开出后多久可以签收
  • 用友标准版怎么反结账
  • 港田路凤凰城
  • 抖音小程序任务哪里接
  • mongodb4.0安装教程
  • 浅谈php技术
  • 基于thinkphp的cms
  • 批发企业商品盘点发生短缺时
  • 员工保险个人部分交多少
  • vue获取当前行
  • 非事业单位企业退休年龄
  • 小规模企业逾期是微信扫码付款吗
  • 什么情况下不用割包皮
  • 厂房推倒重建和改扩建的税务处理
  • 哪些行业不用缴纳增值税
  • 不是自己生产的产品可以用自己的商标吗
  • 会计怎么实现财务自由
  • 支付劳务费未开具发票
  • 所得税预缴申报表资产总额怎么填
  • 企业收入确认的文章
  • 出口报关单运费可以填0吗
  • 个体户是什么样的
  • 公司购买股东的东西
  • 其他应付款转出的会计分录
  • 差旅费住宿费专票
  • 购车税费怎样计算2023
  • 采购返利是什么意思
  • 收据 和发票
  • 补税的会计分录
  • 金税盘未清盘怎么处理
  • 餐饮业怎样做账
  • 会计各种凭证的填写示例
  • sql查询方法有哪些
  • windows进程数
  • 电脑winxp系统
  • debian系列
  • mac截图后怎么编辑
  • win7开机出现标志后就重启
  • 电脑xp系统如何
  • ie8-ie11浏览器
  • android开发webview
  • html怎么下
  • 用jQuery实现优酷首页轮播图
  • node.js+mysql
  • python字符串的编码规则
  • gradle 混淆
  • 个人经营所得定率征收税率表
  • 如何安装金税三期app
  • 个人所得税税单下载
  • 《税收实务》
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设