文档章节

中文乱码 解决思路

之渊
 之渊
发布于 2017/02/24 17:24
字数 650
阅读 9
收藏 0

一般的 乱码 ,百度 就和很多 的解决办法了。 总之 乱码的 出现 总的 原因是 : 编码的时候 使用 一种 字符集, 解码的时候 使用 另一种 字符集。 不要 想着 使用一种 办法 或者 是 一段代码 ,把 所有的中文乱码 问题 都解决掉。 就是 要 知道 编码的时候 使用的是 什么 字符集, 解码的时候,我们使用 一样的 字符集即可。 这样的 办法 对于其他语言来说都是 适用的。

下面是 我遇到的 一种,让我比较郁闷的 方式,花费了 我比较多的 精力:

public static String sendPostRequest(String path,String param) throws IOException {
		String sendUrlString=path+param;
		
		URL url = new URL(sendUrlString);
		HttpURLConnection conn = (HttpURLConnection) url.openConnection();
		//设置post方式请求
		conn.setRequestMethod("POST");
		
		//conn.setRequestProperty("Accept-Charset", "utf-8");
		//conn.setRequestProperty("contentType", "utf-8");
		conn.setRequestProperty("Content-type", "application/x-java-serialized-object");

		//设置传入参数
		conn.setDoOutput(true);
		//传入参数
		//conn.getOutputStream().write(param.toString().getBytes());
		// 解决中文乱码, 在 Linux 下没有乱码,本地有 ,估计 Linux 已经 帮我们转码了一次了。
		// 而且 Linux 下 的默认编码并没有 和 本地的一致,比如tomcat的啊, 系统的啊,没有 该为 默认中文的等。
		// 既然这样 在 Linux 下没有 乱码,可以不用管,如果以后  可以 去 修改 服务器里面的 编码。
		BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
		
		// 解决中文乱码,在 Linux 下有乱码,本地没有
		//BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream(),"GBK"));
				
		
		String readingString= "";
		// 读取完所有内容
		String readl=null;
		while (( readl=reader.readLine() )!=null) {
			
			readingString=readingString+readl;
			
			readl=null;
		}
		
		
		
		return readingString;
		
	}

就是 这样奇怪, 本地 和 服务器 运行的 时候 获取的 中文有乱码, 使用 的 不同 办法 即可。 就是这样 郁闷,我一直想着 统一 起来,不要 让 某个 环境 下面乱码。

参考 地址: https://www.oschina.net/question/920274_144632 其他网友给我的 启发, 这样子的话, tomcat 或者是 nginx 都是需要配置的 统一字符集的。 原来的设置: LANG="en_US.UTF-8" SYSFONT="latarcyrheb-sun16" 现在改为: LANG="zh_CN.UTF-8" SYSFONT="latarcyrheb-sun16" 然后再运行,通过日志分析,其form表单 post提交过来的数据不再乱码。但是,存入到mysql数据库表中的数据是乱码,问题依然没有解决,于是,到/etc/下,打开my.cnf文件,修改3处地方: [client] port = 3306 socket = /var/lib/mysql/mysql.sock default-character-set=utf8 2、在[mysqld]字段里加入character-set-server=utf8,如下: [mysqld] port = 3306 socket = /var/lib/mysql/mysql.sock character-set-server=utf8 3、在[mysql]字段里加入default-character-set=utf8,如下: [mysql] no-auto-rehash default-character-set=utf8 修改完成后,标红的地方是我加的。service mysql restart重启mysql服务就生效

© 著作权归作者所有

共有 人打赏支持
之渊
粉丝 11
博文 551
码字总数 161987
作品 0
佛山
程序员
私信 提问
Spring MVC3返回JSON数据中文乱码问题解决

Spring MVC3返回JSON数据中文乱码问题解决 查了下网上的一些资料,感觉比较复杂,这里,我这几使用两种很简单的办法解决了中文乱码问题。 Spring版本:3.2.2.RELEASE Jackson JSON版本:2.1...

双月通天
2015/10/14
209
0
【MySQL-20180117】MySQL终端无法输入中文

网上大部分都是MySQL终端输入中文出现乱码,然后更改MySQL server的字符集的操作,却缺少MySQL终端无法输入中文,将SQL语句粘贴复制到MySQL的终端中文无法显示: alter qsjxrecommend add co...

liuhuang9496
2018/01/17
0
0
使用Aspose将Word转成Pdf后中文乱码问题

场景: 使用Aspose.Word将word文档转换成pdf。 本地Windows开发环境,pdf文件正常。 本地Ubuntu系统上转换出的pdf也正常。 但是将程序部署到CentOS的服务器上,pdf的中文就都是乱码了。 解决...

Jarhf
2018/12/04
0
0
cmd中查询mysql表出现中文乱码

问题:在pycharm中正常的fetchall拉取数据,能够正常显示,而在cmd中直接select却出现中文乱码。 解决思路:右键查看cmd命令窗口属性得到,cmd窗口默认编码是gbk(如下图所示),而设置的mys...

fang_faye
2018/09/20
0
0
NSIS custom page中多语言支持

大家好!我在封装一个软件时遇到一些问题,在这里请教各位了。谢谢! 我是用NSIS这个软件来封装软件的。在自定义页面中:有中文和英文,客户在安装时,在中文环境下安装是都能够正常显示的。...

YangChenfei
2012/03/06
2K
0

没有更多内容

加载失败,请刷新页面

加载更多

rabbitMQ 在spring 的使用

一、准备工作 maven依赖 <dependency>  <groupId>com.rabbitmq</groupId>  <artifactId>amqp-client</artifactId>  <version>4.0.2</version></dependency> <dependency......

狼王黄师傅
昨天
1
0
Android JNI总结

0x01 JNI介绍 JNI是Java Native Interface的缩写,JNI不是Android专有的东西,它是从Java继承而来,但是在Android中,JNI的作用和重要性大大增强。 JNI在Android中起着连接Java和C/C++层的作...

天王盖地虎626
昨天
1
0
大数据教程(11.8)Hive1.2.2简介&初体验

上一篇文章分析了Hive1.2.2的安装,本节博主将分享Hive的体验&Hive服务端和客户端的使用方法。 一、Hive与hadoop直接的关系 Hive利用HDFS存储数据,利用MapReduce查询数据。 二、Hive与传统数...

em_aaron
昨天
3
0
跟我学Spring Cloud(Finchley版)-15-Hystrix监控详解

Hystrix提供了监控Hystrix Command的能力,本节来详细探讨。 监控端点与数据 应用整合Hystrix,同时应用包含spring-boot-starter-actuator 依赖,就会存在一个/actuator/hystrix.stream 端点...

周立_ITMuch
昨天
6
0
day26:shell题

1、 判断当前主机的CPU生产商,其信息在/proc/cpuinfo文件中vendor id一行中。 如果其生产商为AuthenticAMD,就显示其为AMD公司; 如果其生产商为GenuineIntel,就显示其为Intel公司; 否则,...

芬野de博客
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部