j2ee项目中emoji相关的问题

来源:互联网 发布:网络歌曲播放视频播放 编辑:程序博客网 时间:2024/06/12 20:23

网站项目也许不多,但是也会有emoji的出现。而移动互联相关的项目就常常遇到了,作为移动互联项目的后台的j2ee项目更会遇到。

emoji之类的表情在utf8编码中占4位长度,而mysql数据库的utf-8编码一般为1,2,3位长度,因此直接储存带有emoji表情的文本会出错:


BatchUpdateException: Incorrect string value: '\xF0\x9F\x98\x9D' for column

会有如此之类的异常。


解决方法:

1 注意mysql编码,utf8改为utf-8mb4,这种编码兼容utf8且为4位长度,可以解决mysql储存emoji的问题。但是5.5.3版本之后的mysql才支持这种编码,之下的需要升级。

2 然后是看表。

修改database、table和column字符集。参考以下语句:
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE table_name CHANGE column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;


3 修改mysql配置文件my.cnf(windows为my.ini)

my.cnf一般在etc/mysql/my.cnf位置。找到后请在以下三部分里添加如下内容:

[client] default-character-set = utf8mb4

[mysql] default-character-set = utf8mb4

[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'

4 重启 MySQL Server、检查字符集

1.)重启命令参考:/etc/init.d/mysql restart

2.)输入命令:mysql,进入mysql命令行(如果提示没权限,可以尝试输入mysql -uroot -p你的密码)

3.)在mysql命令行中输入:SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%';


5 SSH之类,用到hibernate、JDBC的项目中,需要用到mysql的connector-java jar包。要保证这个jar包版本在5.1.13以上才能支持这些,否则就算是更新一下,emoji被读出来也会存不回去。


6 检查链接url

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/database?useUnicode=true&characterEncoding=utf8&autoReconnect=true&rewriteBatchedStatements=TRUE
jdbc.username=root
jdbc.password=password


这样就差不多了


参考:

mysql/java服务端对emoji的支持 Ilikewhite

原创粉丝点击