JAVA使用mysql加密解密函数(AES_ENCRYPT/AES_DECRYPT)

article/2025/9/21 5:00:09

前言

  最近大学做JavaWeb课设时发现,很多同学的有关于账号密码都是明文储存在mysql数据库中,其实这样做在实际应用中是非常不安全的,其实mysql最近本身就提供了非常好的两个函数来供我们去加密解密我们要存入的数据,下面我们就来介绍一下如何在java中使用加密解密函数去存储一下铭感的数据。


提示:以下是本篇文章正文内容,下面案例可供参考

正文

我们就举一个最常见的使用JavaWeb来实现注册登录功能的例子,很多同学在存账号密码到mysql中时就像如下代码所示直接将用户注册时输入的密码直接明文存入到了mysql数据库中。

 public void DepositUser(String name,String password){Connection con=getConn();try{//存入账号密码Statement st=con.createStatement();st.executeUpdate("INSERT INTO `user` (`user_name`, `user_password`) VALUES ('"+name+"','"+password+"');");}catch (Exception e){e.printStackTrace();}}

其实这样时非常不安全的,我们可以使用MYSQL提供的AES_ENCRYPT和AES_AES_DECRYPT这两个函数对数据进行加密存入 。

下面我对这两个函数的用法进行简单的介绍,并通过上面的例子来演示一下

AES_ENCRYPT函数就是加密函数,encrypt的英文意思就是加密,很好记忆

其加密原理可以看下面博主得到描述的十分详细

AES加密算法原理_张维鹏的博客-CSDN博客_aes加密算法原理

其使用步骤如下:

1、先将我们要将存入加密的数据在数据库中的类型改为vinbinary,实体类的类型还是可以用String类型就行了。

2、我们在java中向数据库中插入数据时使用加密函数加密。

 其用法非常简单,加密函数AES_ENCRYPT用有两个参数,前面的一个参数代表我们要加密的数据,后面一个参数我们可以理解为一个key,我们加密和解密的数据只能通过这个key去匹配是否是同一个数据,若加密设置key为‘Akey’,我们去解密这个数据时将key写为‘Bkey’,那么就不能解密这个数据了。

加密后的数据我们在mysql数据库中查看如下所示:

 这样就加密完成了

3、若需要我们解密已经存入的数据,我们就可以使用AES_DECRYPT函数来进行解密

我们通过下面的代码演示其解密效果:

 @Testpublic void test() throws ClassNotFoundException, SQLException{//连接mysql数据库Class.forName("com.mysql.cj.jdbc.Driver");Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/chx? serverTimezone=UTC","root","a2002621731");Statement st=connection.createStatement();//解密数据ResultSet rs=st.executeQuery("select AES_DECRYPT(password,'key')from chx.tb_user where id='222'");//测试解密效果while (rs.next()){System.out.println(rs.getString(1));}}

解密函数AES_DECRYPT的参数也有两个,其意义和解密函数AES_ENCRYPT类似。 

运行上面测试代码,

我们可以发现已经解密成功了。

同时在打印台我们发现有一串null,这是因为我们这个解密函数是根据这个key来解密的,如果我们加密的时候设置的key和解密的时候的key不一样,那么函数就不会去根据AES规则去解密数据,所以那个null就是因为我之前存储的数据没有设置key或设置的key不同,所以查询的数据变为null了 

 


总结

以上就是今天介绍的内容,简单描述了mysql提供的加密解密函数在java中的应用,希望对你有帮助。

 


http://chatgpt.dhexx.cn/article/1P6aRY05.shtml

相关文章

Encrypt 和 Decrypt 加密--解密

[例句]In order to encrypt and decrypt, you need an encryption algorithm and a key. 为了进行加密和解密,您需要加密算法和密钥。 数据加密 数据加密利用密码技术对信息进行加密,实现信息的隐蔽,从而起到保护信息安全的作用。它通过加密…

CSS选择器分类大全

选择器(选择符)就是根据不同需求把不同的标签选出来这就是选择器的作用。 简单来说,就是选择标签用的。 分类:基础选择器、复合选择器 目录 一、基础选择器 二、复合选择器 三、CSS3选择器补充: (一)层级选择器&am…

CSS选择器常见用法总结

文章目录 一、选择器的基本概念二、基础选择器1.标签选择器2. 类选择器3. id选择器4. 通配符选择器基础选择器总结 三、复合选择器1. 后代选择器2. 子代选择器3. 并集选择器4. 伪类选择器4.1 链接伪类选择器4.2 force 伪类选择器 复合选择器总结 一、选择器的基本概念 功能&am…

css深度选择器deep

1.为什么要有deep 1.当我们给组件设置scoped的时候&#xff0c;此时我们组件的css样式只会对自己的内容生效&#xff0c;不会对子组件里面的内容生效。 <style lang"scss" scoped> .login-page {min-height: 100vh;background: url(/assets/login-bg.svg) no-r…

CSS学习笔记之选择器(一)

目录 CSS选择器 标签选择器 id选择器 class选择器 后代选择器 群组选择器 * CSS 规则由两个主要的部分构成&#xff1a;选择器&#xff0c;以及一条或多条声明: 选择器通常是您需要改变样式的 HTML 元素。 每条声明由一个属性和一个值组成。 属性&#xff08;property&…

属性选择器

1、属性选择器的写法&#xff1a; 标签名[属性] { 声明即样式 } 运行结果&#xff1a; 如上图&#xff0c;只要有 type 属性的 input 标签样式都会发生变化 当然&#xff0c;也可以给属性加上属性值来限制条件 运行结果&#xff1a; input[type"text"] ---- 只有 t…

选择器类型

2.1 id选择器 用法 : 给html标签添加id属性和属性值,然后用css选取,并进行一系列操作 example: html:<div id"我是id选择器"></div> css选取: 用 #id里面的内容,此时是 #我是id选择器 进行操作: #我是id选择器{ width:100px; height:100px; } id…

vue时间选择器

1、年-月-日 时:分 效果展示&#xff1a; 打开选择器&#xff1a; <div class"label">记录日期:</div> <nut-cell :showIcon"true" :isLink"true" click.native"switchPicker"><span slot"title"&…

CSS —— 选择器(带你深入了解如何使用选择器)

一、基础选择器 基础选择器&#xff1a;标签&#xff08;元素&#xff09;选择器&#xff0c;类选择器&#xff0c;id 选择器&#xff0c;通配符选择器。 标签选择器&#xff1a;html 代码中的标签&#xff0c;如 <html>、<body>、<h1>、<p>、<im…

选 择 器

目录 1、三种基本选择器&#xff08;重要&#xff09; &#xff08;1&#xff09;基本选择器 &#xff08;2&#xff09;类选择器 class &#xff08;3&#xff09;id选择器 2、层次选择器 &#xff08;1&#xff09;后代选择器 &#xff08;2&#xff09;子选择器 &am…

AD域基础

文章目录 AD域基础1.什么是AD域2.AD域和工作组的区别2.1 工作组特点及优缺点2.2 AD域特点及优缺点 3.为什么要做AD域管理4.AD域可以做什么 AD域基础 1.什么是AD域 active directory 活动目录&#xff0c;指一组服务器和工作站的集合&#xff0c;域中的目录是始终呈激活可用&a…

创建AD域

创建AD域&#xff08;skills.cn&#xff09;&#xff1a; &#xff08;1&#xff09;安装首台域控制器 &#xff08;2&#xff09;安装第二台域控制器 &#xff08;3&#xff09;将member server加入到skills.cn域 &#xff08;4&#xff09;将client加入到skills.cn域 建域的必…

AD域详细介绍和部署

文章目录 网络基础域一、概述二、部署域模式1. 部署活动目录&#xff08;AD&#xff09;2. 客户机加入域3. 组织单位&#xff08;OU&#xff09;4. 组策略4.1 概述4.2 创建GPO4.3 组策略应用顺序4.4 编辑测试组策略4.5 阻止继承4.6 强制组策略4.7 计算机&用户脚本4.8 计算机…

AD域允许普通用户打开需要管理员权限的软件

问题场景描述 公司的所有电脑都加了域&#xff0c;防止有些不安分的员工擅自下载及安装一些其他软件&#xff0c;导致电脑变卡或者中毒等&#xff0c;所以加了域后&#xff0c;安装任何软件都由IT来安装&#xff0c;但是这里涉及到一个问题&#xff0c;安装的时候需要管理员密…

AD域组策略管理

一、Active Directory组策略管理 ADManager Plus是一个基于web的Active Directory管理和报表工具&#xff0c;只需点击几下即可帮助为多个域管理组策略对象(GPO)。它还提供预制的组策略(GPO)报表&#xff0c;可快速提取GPO相关信息。 使用ADManager Plus轻松管理Windows Acti…

AD域:添加辅域控制器(辅域服务器)

前言&#xff1a; 如下我创建了一个AD域&#xff0c;现在只有一个主域控制器&#xff0c;也就是创建AD域的第一台服务器默认为主域控制器。为防止主域服务器出现故障影响整个域的运作&#xff0c;故现在要为该域添加一个辅域服务器&#xff0c;用来做备用域服务器。 域&#…

什么是AD域?域能给公司带来什么好处?哪款AD域管理工具比较好?

经营公司中很重要的一点就是对公司的管理&#xff0c;所以基本上所有中型公司为了更方便地管理公司电脑&#xff0c;打印机和用户都会请IT咨询公司来做AD域的设计。当然很多小型公司也有这样的设计以方便未来的成长。AD域会给公司带来有很多好处&#xff0c;并且给公司成长留足…

AD域文件权限管理

活动目录文件权限管理 在网络上共享资源时&#xff0c;首先关心的是谁可以访问这些资源以及级别。在 Active Directory &#xff08;AD&#xff09; 环境中管理文件服务器可能很乏味&#xff0c;而且必须一次一个用户完成&#xff0c;这一事实使其成为系统管理员最耗时的活动之…

AD域实现统一用户管理

AD域服务 什么是目录&#xff08;directory&#xff09;呢&#xff1f; 日常生活中使用的电话薄内记录着亲朋好友的姓名、电话与地址等数据&#xff0c;它就是 telephone directory&#xff08;电话目录&#xff09;&#xff1b;计算机中的文件系统&#xff08;file system&am…

AD域建设管理(一)| 安装windows server2019、AD域、AD域证书服务

AD域建设管理&#xff08;一&#xff09;| 安装windows server2019、AD域、AD域证书服务 1.环境介绍及前言2.安装配置win server 2019虚拟机3.安装AD域服务、AD证书服务3.1.安装AD域服务3.2.配置AD域服务(将此服务器提升为域控制器)3.3.安装AD域证书服务3.4.配置AD域证书服务 4…