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

  • 华为手机来电声音小怎么调啊(华为手机来电声音太小怎么办)

    华为手机来电声音小怎么调啊(华为手机来电声音太小怎么办)

  • 苹果手机怎么缩小图片尺寸(苹果手机怎么缩放照片)

    苹果手机怎么缩小图片尺寸(苹果手机怎么缩放照片)

  • 华为深色省电皮肤有什么用(华为深色省电皮肤)

    华为深色省电皮肤有什么用(华为深色省电皮肤)

  • 拼多多场景推广能随时停吗(拼多多场景推广怎么收费)

    拼多多场景推广能随时停吗(拼多多场景推广怎么收费)

  • 蓝牙耳机配对后滴滴响(蓝牙耳机配对后一只没声音)

    蓝牙耳机配对后滴滴响(蓝牙耳机配对后一只没声音)

  • 电脑上的fn有什么用(电脑上的fn键是干嘛的)

    电脑上的fn有什么用(电脑上的fn键是干嘛的)

  • 小爱音箱要一直充电吗(小爱音箱要一直插电源线吗)

    小爱音箱要一直充电吗(小爱音箱要一直插电源线吗)

  • 拍抖音怎么加文字(拍抖音怎么加文案)

    拍抖音怎么加文字(拍抖音怎么加文案)

  • 为什么word打字下面有波浪线(为什么word打字中间间隔很大)

    为什么word打字下面有波浪线(为什么word打字中间间隔很大)

  • 微信电话不挂闹铃会响吗(微信电话怎么不挂)

    微信电话不挂闹铃会响吗(微信电话怎么不挂)

  • mac地址通常储存在(MAC地址通常储存在计算机的)

    mac地址通常储存在(MAC地址通常储存在计算机的)

  • 如何删除抖音里的作品(如何删除抖音里的收藏)

    如何删除抖音里的作品(如何删除抖音里的收藏)

  • 手机变繁体字是怎么回事(手机变繁体字了怎么办)

    手机变繁体字是怎么回事(手机变繁体字了怎么办)

  • 地铁电脑包要过安检吗(电脑过地铁要检查吗)

    地铁电脑包要过安检吗(电脑过地铁要检查吗)

  • 淘宝可以登录几个手机(淘宝可以登录几个)

    淘宝可以登录几个手机(淘宝可以登录几个)

  • 电脑发送到手机的文件在哪里(怎样将大文件从电脑发送到手机)

    电脑发送到手机的文件在哪里(怎样将大文件从电脑发送到手机)

  • python删除文件(python删除文件中的空行)

    python删除文件(python删除文件中的空行)

  • 索尼xperia1防水吗

    索尼xperia1防水吗

  • 一加7有语音助手吗(一加7t语音助手)

    一加7有语音助手吗(一加7t语音助手)

  • 电子三包凭证能换屏吗(电子三包凭证能确定平板是新的吗)

    电子三包凭证能换屏吗(电子三包凭证能确定平板是新的吗)

  • 手机打不进电话能打出是怎么回事(手机打不进电话也打不出去怎么回事)

    手机打不进电话能打出是怎么回事(手机打不进电话也打不出去怎么回事)

  • Transformer 中的mask(transformer add norm)

    Transformer 中的mask(transformer add norm)

  • vue3:安装配置sass(vue3 安装)

    vue3:安装配置sass(vue3 安装)

  • [深度学习] fast-reid入门教程

    [深度学习] fast-reid入门教程

  • Python解释器有哪几种

    Python解释器有哪几种

  • 计提所得税比实际缴纳的少
  • 金税盘购买的会计分录
  • 开票个人账户的钱怎么查
  • 小规模纳税人金融服务税率
  • 资产的企业所得税怎么算
  • 车船税没有发票可以税前扣除吗
  • 打桩和挖土
  • 对外捐赠衣物怎样入账
  • 房屋租赁发票在哪开
  • 国税发200931号文解读
  • 建材公司将自产产品卖出
  • 一个十图
  • 农民工预储金怎么开户
  • 公司解散实收资本退还怎么写
  • 企业合并怎么处理
  • 收到银行存款利息记账凭证怎么写
  • 苹果7充电设置在哪里
  • 软件无法运行解决方法
  • linux计划任务crontab
  • 收到折扣属于什么会计科目
  • 交罚金怎么交
  • 在php中,字符串有哪些表示形式
  • PHP:curl_error()的用法_cURL函数
  • 月末增值税计算公式
  • 如何抓好工程建设
  • 适用增值税差额征税政策的纳税人填写差额后的销售额
  • yolov5损失
  • 建筑业预缴增值税
  • php xml转数组
  • php防止sql注入的方法
  • 文心一言 VS ChatGPT
  • rm -rf/指令指删除什么
  • ps去水印的三种方法
  • 转账不同银行同城转账手续费多少
  • 公司发给员工的股票
  • 新的企业所得税
  • 将织梦dedecms转换到wordpress
  • 发票管理人员如何操作
  • 补充医疗保险会查hiv吗
  • Linux sqlite3 基本命令
  • 应收账款和应付账款属于什么科目
  • SQL Server 2005/2008 导入导出数据常见报错解决方法
  • 小规模纳税人企业所得税优惠政策最新2023
  • 接受捐赠计入
  • 增值税专用发票的税率是多少啊
  • 房屋租赁物业费谁承担
  • 税控盘有什么作用
  • 畜类生产性生物资产计算折旧的最低年限
  • 收到材料发票怎么写摘要
  • 增值税增量留抵退税进项构成比例
  • 用于研发的材料如何入账
  • 土地使用权如何计入房产原值交房产税时间
  • 长期应收款是否计提坏账准备
  • sqlserver临时表详解
  • win7系统分辨率调整不了
  • [视频]看科学家如何将纯净水变成金属
  • IPad怎么连接电视机看看影视
  • 重庆四日游最佳攻略超详细
  • win7屏幕太亮了怎么调电脑
  • win10升级后无法进入系统一直重启
  • Linux下通过script 命令记录(数据库)操作步骤
  • win8.1拨号上网
  • linux br0配置
  • centos6.9
  • 关闭linux命令
  • docker 开源项目
  • 好看的css样式代码
  • perl读取文件内容到数组
  • Unity3D游戏开发标准教程吴亚峰于复兴人民邮电出版社
  • cmd读取d盘
  • windows批量添加文件后缀
  • python基础视频教程
  • flask pycharm
  • 吉林市无犯罪记录证明网上申请流程
  • 临沂市国家税务局人员名单
  • 三方协议暂不支持缴款
  • 浙江省有多少家农业银行
  • 淮北市国家税务总局电话
  • 个体户定额纳税
  • 青岛振兴税务师招聘
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设