1.备份代码:在进行任何修改之前,务必备份代码,以免修改过程中出现错误导致代码丢失。
2.打开代码文件:使用文本编辑器打开Java代码文件,找到文件编码方式。
3.转换编码方式:将文件编码方式从ANSI X3.4-1968改为UTF-8或其他UTF编码方式,具体步骤如下:
a.在文本编辑器中找到“另存为”选项;
b.在d出的对话框中选择编码方式为UTF-8或其他UTF编码方式;
c.保存文件并关闭文本编辑器。
4.检查代码:重新打开Java代码文件,检查代码是否能够正常编译和运行,以确保代码在编码转换过程中没有出现问题。
需要注意的是,如果Java代码中存在中文或其他非ASCII字符,转换编码方式可能会导致这些字符的乱码,此时需要手动修改相关字符的编码方式。如果您不确定如何进行 *** 作,建议咨询专业的软件工程师或相关技术支持人员。
服务器端修改数据库配置文件/etc/my.cnf
character-set-server=utf8mb4
collation_server=utf8mb4_unicode_ci
重启MySQL(按照官方文档,这两个选项都是可以动态设置的,但是实际的经验是Server必须重启一下)
已有的表修改编码为utf8mb4
ALTER TABLE
tbl_name
CONVERT TO CHARACTER SET
charset_name;
使用下面这个语句只是修改了表的default编码
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4
客户端
jdbc的连接字符串不支持utf8mb4,这个 这种方式 来解决的,如果服务器端设置了character_set_server=utf8mb4,则客户端会自动将传过去的utf-8视作utf8mb4。
Connector/J did not support utf8mb4 for servers 5.5.2 and newer.
Connector/J now auto-detects servers configured with character_set_server=utf8mb4 or treats the Java encoding utf-8 passed using characterEncoding=... as utf8mb4 in the SET NAMES= calls it makes when establishing the connection. (Bug #54175)
其他的client端,比如php、python需要看下client是否支持,如果不能在连接字符串中指定的话,可以在获取连接之后,执行”set names utf8mb4″来解决这个问题;
因为utf8mb4是utf8的超集,理论上即使client修改字符集为utf8mb4,也会不会对已有的utf8编码读取产生任何问题。
要让一个Java
源文件打开时编码格式为
UTF-8,需要做2件事情:
1)设置Java
源文件的默认编码格式为UTF-8;
2)设置workspace的编码格式为UTF-8。
相应设置如下:
设置
Java
源文件的默认编码格式为
UTF-8
在
Windows->Preference
页面中,选择
General->Content
Types
在右边的框中,选择
Text->Java
Source
File,将下面的
Default
Encoding
改为
UTF-8
设置
workspace
的编码格式为
UTF-8
在
Windows->Preference
页面中,选择
General->WorkSpace
选择右侧框中的
Text
File
encoding,改为
UTF-8
设置完这2处,默认打开
Java
源文件就是UTF-8编码了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)