JAVA-中文乱码、编码问题总结

总结总结遇到问题再总结

1.IO流中读取文件时出现乱码问题

1,先记录从文件中(new File()的时候)读取数据逐级包装直至缓冲字节输入流(new BufferReader())并设置编码格式

//文件路径
String path = "??????????????????";
//读取文件
File file = new File(path);
//包装成文件字节输入流
FileInputStream fis = new FileInputStream(file);
//下边这个流可以理解为从字节流迈向字符流的一个桥梁 
//并且InputStreamReader在创建对象的时候可以传入想要的字符编码的参
//数这里是“utf-8”
InputStreamReader isr = new InputStreamReader(fis,"utf-8");
//再将InputStreamReader包装进BufferReader中
BufferedReader br = new BufferedReader(isr);

2.字节码文件读取时出现的乱码问题

遇到了一个在eclipse使用过程中发生的转码问题 ,安装完eclipse后Project→Properties→Resource中写着默认的编码格式为GBK,我一直没有改成UTF-8,在学习过程中因为一直统一使用GBK编码 所以一直也没有出现问题
在这里插入图片描述直到有一天我在汤姆猫上运行我学习Servlet中写的代码时发现一个有趣的现象
如果我使用response直接向服务器发送中文内容不会出现乱码

`resp.getWriter().println("<h1>我喜欢吃</h1>");

但是在使用BufferReader的readline()方法读取到中文内容时会出现乱码情况,我试过无论我修改IO流中读取字符的编码格式 还是修改整个项目的编码格式 都不能改变这个乱码问题

BufferedReader br = new BufferedReader(fr);
br.readLine()//下图中“tom!”的那一行

在这里插入图片描述
请教了老师,得到了新的解决办法
在本类中加入一行代码,这句代码的意思是查看VM启动参数,运行后在控制台上就可以看到下图中的信息(只截了部分片段)可以看到有一个属性叫file.encoding它的值是GBK
意思我个人分析可能是我创建项目的时候使用的是GBK编码 然后自己也运行过这个项目 .class的字节码文件已经生成了 这时候如果只在项目右键Properties进去修改编码格式为时已晚

//查看VM启动参数
System.getProperties().list(System.out);

在这里插入图片描述老师给出了一个临时解决办法,在本类中将要出现乱码的那一行之前加上一行

System.setProperty("file.encoding", "utf-8");

将上文中提到的VM参数中file.encoding的值现改成utf-8
其实最根本的解决办法就是在项目创建之初就设定好编码格式,如果出现像我这样来不及的情况的话可以临时使用这个方法

3,使用Servlet过滤器Filter统一设置整个Servlet项目中的各种编码格式

Servlet提供了三大组件 servlet filer listener
在设置编码格式时 我们就可以预先设定一个全局范围内的过滤器,
创建Filter类 添加注解@WebFilter(eclipse在创建Filter类时会自动创建该注解) 注解的内容我这里直接写了/* ,表示本项目中所有请求都必须先经过这个Filter过滤

@WebFilter("/*")
public class EncodingFilter implements Filter {
    
	public EncodingFilter() {
    
    }

	 @Override
	public void init(FilterConfig fConfig) throws ServletException {
		//当Filter被初始化的时候调用,打印输出
		//Servlet默认是懒加载模式
		System.out.println("encodingfilter is initialized........");
	}
	 @Override
    public void destroy() {
    	//当filter被销毁的时候调用,打印输出
    	System.out.println("encodingfilter is destoryed.......");
    }
	
	//doFilter方法就相当于一个筛子 
	//一共四行代码 分别是我们提出的三个要求,和一条放行代码
	@Override
	public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
	
		//设置解析报文的编码格式
		request.setCharacterEncoding("utf-8");
		//设置返回响应使用的编码格式
		response.setCharacterEncoding("utf-8");
		//告诉浏览器响应内容是text和html类型的文件 编码格式是utf-8
		response.setContentType("text/html;charset=utf-8");
		
		//放行请求
		//其中包含了请求从哪里来  准备到哪里去的相关信息
		chain.doFilter(request, response);
	}
}

过滤器的功能除了简介的注解形式之外,Servlet中还有一种基于web.xml文件的形式,打开web.xml文件,在根目录下加入以下代码

	<filter>
		<!-- 标签的name -->
		<filter-name>encode</filter-name>
		<!-- 标签的类的位置 -->
		<filter-class>com.zyj.day02.EncodingFilter</filter-class>
	</filter>

	<filter-mapping>
		<!-- 对应得标签的name -->
		<filter-name>encode</filter-name>
		<!-- 声明作用域的范围 -->
		<url-pattern>/*</url-pattern>
	</filter-mapping>

虽然内容比较简单 但写起来也算是比较繁琐 所以建议还是使用注解的形式来实现功能
值得一提的是
通过在filter类的init方法中添加了一句打印语句我们发现,如果你既在类名上标明注解 又在web.xml文件中添加了配置,那么当有请求过来的时候,我们会在控制台上发现init方法执行了两次,虽然目前看来没有什么问题 但总的来说 二者有一个即可。

4,从阿里云服务器上的mysql数据库中读取数据产生的中文乱码

问题描述:
当我在servlet中连接好数据库 打算实现一个写入的功能 一个读取的功能
本来是可以通过sql语句顺利的写入中文,在数据库中查询到中文,还可以读取数据打印在控制台上 整个过程中都没有出现乱码问题 但当我想使用直接从数据库中读取中文 “小张” 作为我项目中登录功能的账号时 发现无法读取到正确的数据 以至于判定我在账号框输入的“小张”不存在 正在初学阶段 大体知道各个流程中的各个编码环境 但还是没有找到是哪个环节的编码格式与众不同

找到了一个解决办法 :
在项目中druid-config.properties(阿里云德鲁伊的配置文件)中的url属性后拼接一个?characterEncoding=utf-8 设置读取mysql数据库中数据的时候的编码格式

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://你的端口号:3306/estore?characterEncoding=utf-8
username=???mysql数据库的账号
password=???mysql数据库的密码
maxActive=30
maxWait=3000
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值