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 会自动对其进行加密。

相关推荐
南 阳6 分钟前
Python从入门到精通day37
数据库·python·oracle
轩情吖40 分钟前
MySQL初识
android·数据库·sql·mysql·adb·存储引擎
Traced back40 分钟前
【.NET7 WinForm 实战】三层架构+EF Core+多数据库+完整功能(源码+教程+脚本)
数据库·架构·.net
观测云41 分钟前
KES(KingbaseES)数据库监控最佳实践
数据库
ding_zhikai1 小时前
【Web应用开发笔记】Django笔记4-1:简单使用 Django 与本地数据库
数据库·笔记·后端·python
奇点爆破XC1 小时前
Redis迁移
数据库·redis·bootstrap
断手当码农1 小时前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
菜鸟小九2 小时前
redis原理篇(基本数据结构)
数据结构·数据库·redis
没有bug.的程序员2 小时前
电商秒杀系统深度进阶:高并发流量建模、库存零超卖内核与 Redis+MQ 闭环
数据库·redis·缓存·高并发·电商秒杀·流量建模·库存零超卖
先做个垃圾出来………2 小时前
Python常见文件操作
linux·数据库·python