帮网友解决了一个问题,感觉还是挺好的。

问题是这样的:

问个问题:为什么我mysql中加密和解密出来的字段值不一样?

AES_ENCRYPT和  AES_DECRYPT

但是解密出来就不对了 有时候加密变成空值

我试过,确实有这样的情况:

INSERT INTO test () VALUES (ENCODE('老师你好','123456'));

插入了一个ENCODE的字符串,

SELECT DECODE(testField,'123456' ) FROM test;

查询出来的结果 是è€å¸ˆä½ 好, 看不懂啊!

注意到,test 表的编码是latin1, 如果test 表的编码是utf8 或者 gbk, 那么, INSERT INTO test () VALUES (ENCODE('老师你好','123456')); 这一句是会失败的, 我猜测 应该是编码问题。 如果开始是utf8,一个字符串在mysql之后, 其内容发生变化, 然后就变成了utf8不能认识的字符串了。 但是latin1 是可以认识的,因为 latin1是单字节编码的。

ENCODE('老师你好','123456') 是可以存入latin1 的。 但是不能正确读取。 其解析出来的字符串,latin1 无法表示

注意到这一点,其实就好办了, testField 字段就用 latin1 编码, 读取的时候以latin1 的方式解析,然后再次组装成 utf8,。

这样,虽然可以, 但是,般不建议通过把密码明文直接传递到 数据库

应该是加密后再传递

通过md5 即可

测试代码如下:

# show variables like 'character%';

drop TABLEifEXISTS test;/*generating test table*/CREATE TABLE `test` (

`testField` varchar(512) DEFAULT NULL

# ) ENGINE=InnoDB DEFAULT CHARSET= 'UTF8'COLLATE utf8_general_ci;

) ENGINE=InnoDB DEFAULT CHARACTER SET latin1;/*adding some test data to it*/# INSERT INTO test () VALUES (DES_ENCRYPT("Hello")), (DES_ENCRYPT("World"));

# INSERT INTO test () VALUES (ENCODE('abc','123')), ENCODE('mytext','mykeystring'));

# INSERT INTO test VALUES('a阿萨德b');

INSERT INTO test () VALUES (ENCODE('老师你好','123456'));

SELECT DECODE(testField,'123456') FROM test;

SELECT*FROM test;

# SELECT ENCODE('abc','123'), DECODE('aaa','123');

SELECT DECODE(ENCODE('mytext','mykeystring'),'mykeystring');

# SELECT DES_ENCRYPT('aa'), DES_DECRYPT('asdadw');

mysql+encode+decode+错误_mysql decode encode 乱码问题相关推荐

  1. mysql 报1055错误_MySQL数据库报1055错误

    有点坑啊,当初装MySQL数据库的时候没有整配置文件,结果MySQL报1055错误的时候,网上的解决办法都说如果需要永久生效的话,只能通过改配置文件实现,but,我没有配置文件,蜜汁尴尬啊 1.已安装 ...

  2. mysql客户端汉化_Mysql客户端中文乱码问题解决

    在Linux机器上使用Mysql客户端访问获取中文有时候是乱码,如下: mysql> select *from t_user;+----+-----------+-------------+-- ...

  3. mysql c 中文字符串_MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法...

    开源数据库MySQL从来都是中小企业构建web应用的首选,特别是和PHP配合简直就是一 对黄金搭档,深受web开发人员的喜爱.但自从4.1以来MySQL加入了多字符集的支持,很多MySQL使用者发现中 ...

  4. mysql binlog恢复错误_mysql通过binlog日志来恢复数据

    简介 在生产的过程中有这么一个业务场景:比如我在2016-11-19 09:30:00 通过mysqldump的方式备份了数据库,但是在2016-11-19 10:30:00的时候数据库崩溃了,如果通 ...

  5. mysql 忽略语法错误_MYSQL语句中易忽略的语法错误 | 学步园

    $str="CREATE TABLE test ( id int( 11 ) NOT NULL AUTO_INCREMENT PRIMARY KEY , name VARCHAR( 255 ...

  6. mysql排序规则错误_MySQL中“非法混合排序规则”错误的疑难解答

    阿波罗的战车 更改字符串的一个(或两者)的排序规则以使它们匹配,或者添加一个COLLATE从句到你的表情.这"校对"到底是什么?如下文所述字符集和排序规则:A 字符集是一组符号和编 ...

  7. mysql主从配置错误_mysql主从配置常见错误处理

    1.error connecting to master 'repl@192.168.0.21:3306' - retry-time: 60 retries: 4 message: Authentic ...

  8. 解决mysql地区时间错误_mysql time zone时区的错误解决

    错误提示: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zon ...

  9. mysql查询语法错误_MySQL内部联接查询语法错误

    我是MySQL的新手,无法弄清楚这里出了什么问题.我有两张桌子.左表称为"锻炼".相关列是日期(日期类型)和ID(类型int). 右边的表称为Workout_locations(相 ...

最新文章

  1. Linux Kernel中的系统调用分析
  2. 【学习笔记】mongoDB初步(一)MongoDB的安装和增删改查基本语法,使用和命令
  3. python注释_python中的单行注释、多行注释
  4. 2021中国餐饮行业数字化调研报告
  5. mysql千万级数据量根据索引优化查询速度
  6. python解决数据不均衡,上采样方法解决
  7. 如何在Exchange中处理不能发送的信息
  8. mysql 修改max_allowed_packet
  9. 【Verilog设计—数字传输系统】ASK调制与FSK调制
  10. 3┃音视频直播系统之浏览器中通过 WebRTC 直播视频实时录制回放下载
  11. 美国大学 计算机专业 排名,2019美国大学计算机专业排名
  12. 0基础怎么自学软件测试?
  13. 从0开始学大数据(十二)
  14. python中创建requirement.txt
  15. 声纹识别概述(3)声纹识别系统
  16. 2021-05-27let的TDZ
  17. 摄像头poe供电原理_poe供电原理
  18. 阿里云ECS问题大全【转自阿里云社区】
  19. SQL必知必会1 查询部分 P1-P129
  20. puzzle(0211)几何划分问题

热门文章

  1. 大话设计模式—建造者模式
  2. Kafka生产者发送消息的三种方式
  3. 开机故障中的MBR引导故障的排查
  4. JetBrains 发布Kotlin 1.0
  5. 分布式系统之通信技术学习
  6. [转]如何将WCF服务发布到IIS中去VS2010版
  7. HashMap,LinkHashMap和TreeMap的区别
  8. 【长文】Google面试官分步解析自己泄漏前的面试题,超多干货和建议
  9. 不停刷朋友圈的人_不停刷新闻、朋友圈、微信群的朋友,休息一下,看多了伤身!...
  10. 编写一个函数判断一个整数是不是素数c语言,设计一个函数,用来判断一个整数是否为素数。代码如下,按要求在空白处填写适当的表达式或语句,使...