mysql+encode+decode+错误_mysql decode encode 乱码问题
帮网友解决了一个问题,感觉还是挺好的。
问题是这样的:
问个问题:为什么我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 乱码问题相关推荐
- mysql 报1055错误_MySQL数据库报1055错误
有点坑啊,当初装MySQL数据库的时候没有整配置文件,结果MySQL报1055错误的时候,网上的解决办法都说如果需要永久生效的话,只能通过改配置文件实现,but,我没有配置文件,蜜汁尴尬啊 1.已安装 ...
- mysql客户端汉化_Mysql客户端中文乱码问题解决
在Linux机器上使用Mysql客户端访问获取中文有时候是乱码,如下: mysql> select *from t_user;+----+-----------+-------------+-- ...
- mysql c 中文字符串_MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法...
开源数据库MySQL从来都是中小企业构建web应用的首选,特别是和PHP配合简直就是一 对黄金搭档,深受web开发人员的喜爱.但自从4.1以来MySQL加入了多字符集的支持,很多MySQL使用者发现中 ...
- mysql binlog恢复错误_mysql通过binlog日志来恢复数据
简介 在生产的过程中有这么一个业务场景:比如我在2016-11-19 09:30:00 通过mysqldump的方式备份了数据库,但是在2016-11-19 10:30:00的时候数据库崩溃了,如果通 ...
- mysql 忽略语法错误_MYSQL语句中易忽略的语法错误 | 学步园
$str="CREATE TABLE test ( id int( 11 ) NOT NULL AUTO_INCREMENT PRIMARY KEY , name VARCHAR( 255 ...
- mysql排序规则错误_MySQL中“非法混合排序规则”错误的疑难解答
阿波罗的战车 更改字符串的一个(或两者)的排序规则以使它们匹配,或者添加一个COLLATE从句到你的表情.这"校对"到底是什么?如下文所述字符集和排序规则:A 字符集是一组符号和编 ...
- mysql主从配置错误_mysql主从配置常见错误处理
1.error connecting to master 'repl@192.168.0.21:3306' - retry-time: 60 retries: 4 message: Authentic ...
- 解决mysql地区时间错误_mysql time zone时区的错误解决
错误提示: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zon ...
- mysql查询语法错误_MySQL内部联接查询语法错误
我是MySQL的新手,无法弄清楚这里出了什么问题.我有两张桌子.左表称为"锻炼".相关列是日期(日期类型)和ID(类型int). 右边的表称为Workout_locations(相 ...
最新文章
- Linux Kernel中的系统调用分析
- 【学习笔记】mongoDB初步(一)MongoDB的安装和增删改查基本语法,使用和命令
- python注释_python中的单行注释、多行注释
- 2021中国餐饮行业数字化调研报告
- mysql千万级数据量根据索引优化查询速度
- python解决数据不均衡,上采样方法解决
- 如何在Exchange中处理不能发送的信息
- mysql 修改max_allowed_packet
- 【Verilog设计—数字传输系统】ASK调制与FSK调制
- 3┃音视频直播系统之浏览器中通过 WebRTC 直播视频实时录制回放下载
- 美国大学 计算机专业 排名,2019美国大学计算机专业排名
- 0基础怎么自学软件测试?
- 从0开始学大数据(十二)
- python中创建requirement.txt
- 声纹识别概述(3)声纹识别系统
- 2021-05-27let的TDZ
- 摄像头poe供电原理_poe供电原理
- 阿里云ECS问题大全【转自阿里云社区】
- SQL必知必会1 查询部分 P1-P129
- puzzle(0211)几何划分问题
热门文章
- 大话设计模式—建造者模式
- Kafka生产者发送消息的三种方式
- 开机故障中的MBR引导故障的排查
- JetBrains 发布Kotlin 1.0
- 分布式系统之通信技术学习
- [转]如何将WCF服务发布到IIS中去VS2010版
- HashMap,LinkHashMap和TreeMap的区别
- 【长文】Google面试官分步解析自己泄漏前的面试题,超多干货和建议
- 不停刷朋友圈的人_不停刷新闻、朋友圈、微信群的朋友,休息一下,看多了伤身!...
- 编写一个函数判断一个整数是不是素数c语言,设计一个函数,用来判断一个整数是否为素数。代码如下,按要求在空白处填写适当的表达式或语句,使...