MySQL中的加密函数

本文简单介绍MySQL中的加密函数。

MySQL 提供了多种加密函数,以下是一些常用的:

  1. PASSWORD(str): 用于密码加密,通常用于创建用户时对密码进行加密。
  2. MD5(str): 生成一个128位的加密串,返回一个32位的16进制数。
  3. SHA1(str): 生成一个160位的加密串,返回一个40位的16进制数。
  4. ENCODE(str,pass_str): 使用 pass_str 作为密钥对 str 进行加密。
  5. DECODE(str,pass_str): 使用 pass_str 作为密钥对 str 进行解密。

示例:

SELECT MD5('mytext');
SELECT SHA1('mytext');
SELECT PASSWORD('mypassword');
SELECT ENCODE('hello', 'mykey');
SELECT DECODE('encoded_text', 'mykey');

注意:以上加密函数除了ENCODEDECODE可以解密外,其他的都是不可逆的。

PASSWORD(str)函数在 MySQL 中通常用于创建用户时对密码进行加密。

例如,当你想创建一个新的 MySQL 用户时,你可以使用PASSWORD(str)函数来加密用户的密码。

以下是一个示例:

CREATE USER 'newuser'@'localhost' IDENTIFIED BY PASSWORD('newpassword');

在这个例子中,newpassword是用户的原始密码,PASSWORD('newpassword')会返回加密后的密码。

注意:从 MySQL 5.7.6 开始,PASSWORD()函数已被废弃,建议使用更安全的ALTER USER语句来设置密码。

例如:

ALTER USER 'newuser'@'localhost' IDENTIFIED BY 'newpassword';

在这个例子中,newpassword是用户的原始密码,MySQL 会自动对其进行加密。

相关推荐
暮毅4 分钟前
10.Node.js连接MongoDb
数据库·mongodb·node.js
wowocpp7 分钟前
ubuntu 22.04 server 格式化 磁盘 为 ext4 并 自动挂载 LTS
服务器·数据库·ubuntu
成富30 分钟前
文本转SQL(Text-to-SQL),场景介绍与 Spring AI 实现
数据库·人工智能·sql·spring·oracle
songqq2731 分钟前
SQL题:使用hive查询各类型专利top 10申请人,以及对应的专利申请数
数据库·sql
计算机学长felix34 分钟前
基于SpringBoot的“校园交友网站”的设计与实现(源码+数据库+文档+PPT)
数据库·spring boot·毕业设计·交友
小码的头发丝、1 小时前
Django中ListView 和 DetailView类的区别
数据库·python·django
小兜全糖(xdqt)1 小时前
mysql数据同步到sql server
mysql·adb
Karoku0661 小时前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix
周全全2 小时前
MySQL报错解决:The user specified as a definer (‘root‘@‘%‘) does not exist
android·数据库·mysql
白云如幻2 小时前
MySQL的分组函数
数据库·mysql