「java乱码解析」java乱码的原因

博主:adminadmin 2022-11-29 05:22:07 57

本篇文章给大家谈谈java乱码解析,以及java乱码的原因对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

如何解决JavaEE开发中字符编码出现乱码问题

1、浏览器调用jsp,html等页面中文显示乱码

此情况需满足两个要求:

(1)文件本身是以utf-8编辑保存的(myEclipse中在properties中鼠标右键选择utf-8)

(2)浏览器用utf-8解析:

(手动)== 在浏览器中右键选择编码格式为utf-8

(智能)== 在文件中写入如: meta name="content-type" content="text/html; charset=UTF-8" 通过meta标签模拟response头,起到告诉浏览器用utf-8的编码解析

(智能)== response.setContentType("text/html;charset=UTF-8");起到告诉浏览器用utf-8的编码解析

常用:

meta name="content-type" content="text/html; charset=UTF-8"或meta charset="utf-8"

%@ pageEncoding="utf-8"%

?xml encoding="UTF-8"?

2、通过浏览器调用servlet,页面显示乱码。

Servlet乱码分为request乱码和response乱码;

(1)response乱码问题

解决方法:

在网上很有效的解决方法是添加:

response.setCharacterEncoding("UTF-8");

解决不了,后来又搜到一条解决方法是:

response.setContentType("text/html;charset=utf-8");或者 response.setHeader("content-type","text/html;charset=UTF-8");告诉浏览器用utf-8解析。(setHeader是HttpServletResponse的方法。如果想在拦截器Filter中设置字符编码,则无此方法,因为Filter的doFilter方法的参数类型是ServletResponse)

两句都填上,后来终于解决了这个问题;

其实我们应该思考一下本质:

response.setContentType("text/html;charset=UTF-8"); 目的是为了控制浏览器的行为,即控制浏览器用UTF-8进行解码;

response.setCharacterEncoding("UTF-8");目的是用于response.getWriter()输出的字符流的乱码问题。如果是response.getOutputStream()是不需要此种解决方案的,因为这句话的意思是为了将response对象中的数据以UTF-8解码后的字节流发向浏览器;

如何解决Java中的中文乱码问题

对于Java,由于默认的编码方式是UNICODE,所以用中文也易出问题,常见的解决是:

String s2 = new String(s1.getBytes(“ISO-8859-1”),”GBK”);

1、utf8解决JSP中文乱码问题

一般说来在每个页面的开始处,加入:

%@ page language="java" contentType="text/html; charset=UTF-8"

pageEncoding="UTF-8"%

%@ page language="java" contentType="text/html; charset=UTF-8"

pageEncoding="UTF-8"%

%

request.setCharacterEncoding("UTF-8");

%

◆charset=UTF-8的作用是指定JSP向客户端输出的编码方式为“UTF-8”;

◆pageEncoding="UTF-8",为了让JSP引擎能正确地解码含有中文字符的JSP页面,这在LINUX中很有效;

◆request.setCharacterEncoding("UTF-8");是对请求进行了中文编码。

有时,这样仍不能解决问题,还需要这样处理一下:

String msg = request.getParameter("message");

String str=new String(msg.getBytes("ISO-8859-1"),"UTF-8");

out.println(st);

java中filewriter中文乱码怎么解决?

要明白,用filewriter读取文件采取的是平台默认编码(视操作系统而定)。当要写入的文本文件编码和平台默认编码不一致时,就会出现中文乱码的情况。这时可以使用filewriter 的父类OutputStreamWriter来读取。OutputStreamWriter允许用户指定编码方式,代码为:

FileInputStream fis=new FileInputStream("文件路径");

OutputStreamWriter osw=new OutputStreamWriter(fis,"文本文件的编码方式(ANSI,UTF-8...)");

osw.write();

这样写入的编码可以保证和源文本文件编码一致,就不会出现乱码了。

javaweb怎么处理中文乱码问题

中文乱码问题真的是一个很棘手的问题,特别是从前台传到后台之后,都不知道问题出在哪里了。现在分享解决javaWEB中前后台中文乱码问题的3种方法。

方法一:

tomcat的自带编码是ISO-8859-1的格式,是不兼容中文的编码的。所以我们从后台接收的时候要注意。

采用相同的格式去接收(ISO-8859-1),然后用能解析的编码(utf-8)去转换。这样我们就能得到能兼容中文的格式了。这样处理之后发往前台。注意:发往前台的时候也需要设置一下

resp.setContentType("text/html;charset=utf-8");//设置页面的字符编码,解决界面显示中文乱码的问题

protected void service(HttpServletRequest req, HttpServletResponse resp)

throws ServletException, IOException {

//因为tomcat自带编码是ISO-8859-1格式

//解决乱码方法之一

span style="white-space:pre" /spanString name=req.getParameter("username");

span style="white-space:pre" /spanString pwd=req.getParameter("pwd");

span style="white-space:pre" /spanbyte[] b=name.getBytes("ISO-8859-1");//用tomcat的格式(iso-8859-1)方式去读。

span style="white-space:pre" /spanString str=new String(b,"utf-8");//采用utf-8去接string

span style="white-space:pre" /spanresp.setContentType("text/html;charset=utf-8");//设置页面的字符编码span style="white-space:pre" /span

span style="white-space:pre" /spanPrintWriter pw =resp.getWriter();

span style="white-space:pre" /spanString str1="htmlbodyfont size='5px' color='red'username:"+name+"pwd:"+pwd+"/font/body/html";

span style="white-space:pre" /spanpw.print(str1);

PrintWriter pw =resp.getWriter();

String str1="htmlbodyfont size='5px' color='red'username:"+name+"pwd:"+pwd+"/font/body/html";

pw.print(str1);

方法二:

由于方法一比较繁琐,采用用了简单的设置。只需要简单的一句就可以搞定

req.setCharacterEncoding("utf-8");//必须写在第一位,因为采用这种方式去读取数据,否则数据会出错。

这样就不用像之前的那样繁琐的设置了

protected void service(HttpServletRequest req, HttpServletResponse resp)

throws ServletException, IOException {

//因为tomcat自带编码是ISO-8859-1格式

//解决乱码二《法一比较繁琐》

req.setCharacterEncoding("utf-8");//必须写在第一位,因为采用这种方式去读取数据,否

则数据会出错。

//设置这样方式去读。这样中文就能够读取出来了,但是需要注意。表单的发送方式必须是span style="color:#ff0000;" method='post'/span

resp.setContentType("text/html;charset=utf-8");//设置传过去的页面显示的编码

String name=req.getParameter("username");

String pwd=req.getParameter("pwd");

PrintWriter pw =resp.getWriter();

String str1="htmlbodyfont size='5px' color='red'username:"+name+"pwd:"+pwd+"/font/body/html";

pw.print(str1);

方法三:

这是在法二的基础上修改的。虽然我们能修改编码格式去读,但是考虑到用户肯定不会修改,所以我们需要采用比较通用的办法,让用户修改配置文件。也就是web.xml文件

需要修改web.xml里面的内容,就是说,字符编码从xml接收过来。需要在xml文件中配置参数。

代码如下:

servlet

servlet-nameEncodeing/servlet-name

servlet-classcn.hncu.com.encode.Encodeing/servlet-class

init-param

param-namecharset/param-name

param-valueutf-8/param-value//这里面的内容可供用户自己填写(必须是编码格式)

/init-param

/servlet

我们知道前台和后台进行交换必须经过web.xml配置

我们需要获取web.xml的设置的参数

public void init(ServletConfig config) throws ServletException {

charset=config.getInitParameter("charset");//获得初始化参数。当然charset需要设置为全局变量。后面的service函数需要设置req.setCharacterEncoding(charset);

}

req.setCharacterEncoding(charset);

resp.setContentType("text/html;charset=utf-8");

String name=req.getParameter("username");

String pwd=req.getParameter("pwd");

PrintWriter pw =resp.getWriter();

String str1="htmlbodyfont size='5px' color='red'username:"+name+"pwd:"+pwd+"/font/body/html";

pw.print(str1);

java中文乱码,能说下string.getBytes()和new String()转码是,具体点。

1、Java中,【String.getBytes(String decode)】的方法,会根据指定的decode,编码返回某字符串在该编码下的byte数组表示,例如:

byte[] b_gbk = "中".getBytes("GBK");

byte[] b_utf8 = "中".getBytes("UTF-8");

byte[] b_iso88591 = "中".getBytes("ISO8859-1")

上面三行代码表示:分别返回“中”这个汉字在GBK、UTF-8和ISO8859-1编码下的byte数组表示,此时b_gbk的长度为2,b_utf8的长度为3,b_iso88591的长度为1。

2、而通过【new String(byte[], decode)】的方式来还原这个“中”字时,实际是使用decode指定的编码来将byte[ ]解析成字符串,例如:

String s_gbk = new String(b_gbk,"GBK");

String s_utf8 = new String(b_utf8,"UTF-8");

String s_iso88591 = new String(b_iso88591,"ISO8859-1");

s_gbk和s_utf8都是“中”,而只有s_iso88591是一个不认识 的字符,因为ISO8859-1编码的编码表中,根本就没有包含汉字字符,当然也就无法通过"中".getBytes("ISO8859-1")。

因此,通过【String.getBytes(String decode)】方法来得到byte[ ]时,要确定decode的编码表中确实存在String表示的码值,这样得到的byte[ ]数组才能正确被还原。

扩展资料

java中文编码避免乱码

1、为了让中文字符适应某些特殊要求(如http header头要求其内容必须为iso8859-1编码),可能会通过将中文字符按照字节方式来编码的情况,比如:

String s_iso88591 = new String("中".getBytes("UTF-8"),"ISO8859-1")

2、上述例子中的s_iso8859-1字符串实际是三个在 ISO8859-1中的字符,在将这些字符传递到目的地后,目的地程序再通过相反的方式:

String s_utf8 = new String(s_iso88591.getBytes("ISO8859-1"),"UTF-8")

来得到正确的中文汉字。这样就既保证了遵守协 议规定、也支持中文。

3、String.getBytes(String decode)方法会根据指定的decode编码返回某字符串在该编码下的byte数组表示这里是encode ,not decode,从字符串到字节数组是编码的过程,从字节数组到字符串(即 new String(byte[] , charsetname))才是解码的过程。

参考资料:百度百科-UTF-8

打开java文件都是乱码怎么解决?

编辑器的编码会影响到所有的项目中的字符的显示,可以说是作用最为广泛的设置,每一个项目都会受到这个设置的影响。点击菜单栏中的窗口(Window)— —选项(Preferences)。

java乱码解析的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java乱码的原因、java乱码解析的信息别忘了在本站进行查找喔。

The End

发布于:2022-11-29,除非注明,否则均为首码项目网原创文章,转载请注明出处。