标签分类
技术文章
当前位置:主页 > 计算机编程 > java > JavaWeb乱码问题如何解决

JavaWeb乱码问题的解决方法

  • 发布时间:
  • 作者:码农之家原创
  • 点击:108

JavaWeb乱码问题如何解决

这篇文章主要知识点是关于javaweb中文乱码,java,web乱码,java,web运行乱码,JavaWeb乱码问题如何解决,解决JavaWeb读取本地json文件以及乱码的问题 的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

JavaScript网页动画设计
  • 类型:JavaScript大小:26 MB格式:PDF出版:人民邮电出版社作者:夏皮罗
立即下载

前言

经常有读者在公众号上问 JavaWeb 乱码的问题,昨天又有一个小伙伴问及此事,其实这个问题很简单,但是想要说清楚却并不容易,因为每个人乱码的原因都不一样,给每位小伙伴都把乱码的原因讲一遍也挺费时间的,因此,松哥今天决定写一篇文章,和大伙好好捋捋 JavaWeb 中的乱码问题。

对于一些老司机而言,其实并不太容易遇到乱码问题,但是对于一些新手来说,乱码几乎是家常便饭,而且每当乱码时,网上搜了一大堆解决方案,发现自己的问题还是没能解决,其实这就是平时研究代码不求甚解导致的,乱码问题,也要去分析,然后才能对症下药,才能药到病除。

整体思路

首先出现乱码之后,要先去确认乱码的地方,当一个网页上出现乱码,有可能是浏览器显示问题,也有可能是 Java 编码问题,也有可能数据库中的数据本身就是乱码的,所以我们要做的第一件事就是确认乱码发生的位置,缩小 bug 范围,通过打印日志或者 debug 首先去确认乱码发生的位置,然后再去进一步解决,一般来说,乱码的原因大致上可以分为两类:

  • 请求乱码
  • 响应乱码

请求乱码,可能是因为参数放在 URL 地址中乱码,也有可能是参数放在请求体中乱码,不同传参方案也对应了不同的乱码解决方案。如果是响应乱码,那么原因就会比较多了,一般来说,有如下几种可能的原因:

  • 数据库本身乱码
  • 数据在 Java 代码中乱码
  • 数据在浏览器显示的时候乱码
  • 数据在从 Java 应用传到数据库的过程中乱码

对于不同的乱码原因,会有不同的解决方案,对症下药,才能药到病除,所以当出现乱码时,大家要做的第一件事就是分析乱码发生的原因,找到原因了,才能找到解决方案。

基本原则

发生乱码是因为各自编码不同导致的,所以,大家首先要有一个良好的开发习惯,项目编码,文件编码都要统一起来,松哥有个同事就因为 Freemarker 乱码,找了半天没找到原因,后来在松哥建议下修改了项目编码,乱码问题才解决了,一般来说,公司制度稍微成熟一些,都会对项目编码,文件编码有硬性规定的。在Eclipse 中,设置项目编码方式如下(工程的编码要提前设置,如果项目已经开发一半再去设置,已有的中文就会乱码):

Window->Preferences->General

JavaWeb乱码问题的终极解决方案(推荐)

然后对于 JSP 文件也需要提前设置好编码方式,如下:

JavaWeb乱码问题的终极解决方案(推荐)

这是在 Eclipse 中设置文件编码,如果是在 IntelliJ IDEA中,则不需要设置JSP文件编码,因为默认就是 UTF-8,只需要提前设置下工程编码即可:

JavaWeb乱码问题的终极解决方案(推荐)

除了开发工具的编码,数据库的编码也要统一,一般来说,主要是设置一下数据库的编码和数据表的编码,如下:

设置数据库编码:

CREATE DATABASE `vhr` DEFAULT CHARACTER SET utf8;

设置数据表编码:

DROP TABLE IF EXISTS `adjustsalary`;
CREATE TABLE `adjustsalary` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `eid` int(11) DEFAULT NULL,
 PRIMARY KEY (`id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

这些是准备工作,这些工作做好了,还是有可能会遇到乱码问题,接下来我们就具体问题具体分析。

请求乱码

请求乱码,就是说数据在浏览器中显示是正常的,但是传到 Java 后端之后,就乱码了,这种乱码一般来说,分为两种:

  • 参数放在 URL 地址中导致的乱码
  • 参数放在请求体中导致的乱码

两种乱码原因,对应了两种不同的解决方案。分别来看。

URL 地址中的参数乱码

这种乱码主要发生在 GET 请求中,因为在 GET 请求中我们一般通过 URL 来传递参数,这个问题可以在代码中解决,但是太过于麻烦,因此一般我们直接在Tomcat配置中解决,修改 Tomcat的conf/server.xml 文件,修改 URL 编码格式,如下:

JavaWeb乱码问题的终极解决方案(推荐)

这样就可以搞定 URL 地址中的参数乱码。

请求体中的参数乱码

请求体中的参数乱码,我们可以在解析参数之前通过设置 HttpServletRequest 的编码来解决,如下:

request.setCharacterEncoding("UTF-8");

但是一样也太过于麻烦,所以如果是普通的 Servlet/JSP 项目,我们就可以直接定义一个过滤器来处理,如下:

public class EncodingFilter implements Filter {
 @Override
 public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
  request.setCharacterEncoding("UTF-8");
  chain.doFilter(request, response);
 }
}

过滤器配置:

 <filter>
  <filter-name>encodingFilter</filter-name>
  <filter-class>org.sang.filter.EncodingFilter</filter-class>
 </filter>
 <filter-mapping>
  <filter-name>encodingFilter</filter-name>
  <url-pattern>/*</url-pattern>
 </filter-mapping>

在工程编码和JSP/HTML编码都没问题的情况下,请求乱码基本上就是这两种情况。

响应乱码

如果在浏览器上加载页面看到了乱码,大家首先要确认在从服务端往浏览器写数据的前一刻,这个数据还没有乱码(即数据库中查询出来的数据是OK的,没有发生乱码的问题),那么对于这种乱码,我们只需要设置响应数据的 ContentType 就可以了,如下:

response.setContentType("text/html;charset=UTF-8");

如果从数据库中查询出来的数据就是乱码的,那么就需要去确认数据库中的编码是否 OK 。

框架处理

前面提到的方案,都是在 Servlet/JSP 项目中我们可以采用的方案,在 SSM 框架中当然也可以使用,但是,SpringMVC 框架本身也提供了一个过滤器,我们可以借用这个过滤器更加高效的解决响应乱码问题,如下:

<filter>
 <filter-name>encoding</filter-name>
 <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
 <init-param>
  <param-name>encoding</param-name>
  <param-value>UTF-8</param-value>
 </init-param>
 <init-param>
  <param-name>forceRequestEncoding</param-name>
  <param-value>true</param-value>
 </init-param>
 <init-param>
  <param-name>forceResponseEncoding</param-name>
  <param-value>true</param-value>
 </init-param>
</filter>
<filter-mapping>
 <filter-name>encoding</filter-name>
 <url-pattern>/*</url-pattern>
</filter-mapping>

当然,上面这段配置并不能代替 Tomcat 中 conf/server.xml 中的编码配置,如果是在 Spring Boot 中,配置可以更加简单,只需要在 application.properties 中添加如下配置即可:

server.tomcat.uri-encoding=UTF-8
spring.http.encoding.force-request=true
spring.http.encoding.force-response=true

其他乱码

其他乱码主要是指使用一些第三方框架导致的乱码,例如使用 Alibaba 的 fastjson,开发者就需要在配置 HttpMessageConverter 时指定编码格式,否则就有可能出现乱码,这种第三方框架的乱码松哥没法穷举,大伙在使用时需要注意看官方文档,fastjson 的 HttpMessageConverter 配置如下:

@Bean
FastJsonHttpMessageConverter fastJsonHttpMessageConverter() {
 FastJsonHttpMessageConverter converter = new FastJsonHttpMessageConverter();
 FastJsonConfig config = new FastJsonConfig();
 config.setCharset(Charset.forName("UTF-8"));
 converter.setFastJsonConfig(config);
 converter.setDefaultCharset(Charset.forName("UTF-8"));
 return converter;
}

一个隐蔽的乱码

除了前面介绍的这几种乱码之外,还有一个比较隐蔽的乱码,容易被很多初学者忽略的地方,就是数据在从 Java 应用传递到 MySQL 的过程中,发生了乱码,这种问题一般在 Windows 上不易发生,如果数据库装在 Linux 上,则这个问题就很容易发生,数据在代码中命名没有乱码,存到 MySQL 上就乱码了,但是如果直接使用 Navicat 等工具往 MySQL 上存储数据,又不会乱码,或者 MySQL 中数据没有乱码,但是用 Java 查询出来就乱码了,这种都是数据在 应用 和 数据库 之间传递时发生了乱码,解决方式很简单,在数据库连接地址上指定编码即可,如下:

db.url=jdbc:mysql:///yuetong?useUnicode=true&characterEncoding=UTF-8

大致就这些,还有一些非常偶尔的情况可能会用到 @RequestMapping 注解中的 produces 属性,在这里指定数据类型即可。

好了,差不多就这些,下次有人问你为啥我的又乱码了,直接把这篇文章甩给他。大伙有什么解决乱码的独门密器也可以一起来讨论。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对码农之家的支持。

解决JavaWeb读取本地json文件以及乱码的问题

最近在开发项目的时候遇到一个问题,在myecilpes上使用googlede gson读取项目中的json文件成功,然后把项目发布到tomcat上再使用同样的方法,会提示“系统找不到指定的路径”

文件放在src/config/下

JsonParser parser = new JsonParser();
    JsonObject object = (JsonObject) parser.parse(new FileReader("config/Test.json"));

在找了许多文章以后,发现问题应该是,发布到服务器之后,读取文件的相对路径并不能寻找到文件,所以只能使用绝对路径,找到在tomcat的 webapps下的项目Test

路径是

D:\Program Files\Tomcat 8.0\webapps\Test\WEB-INF\classes\Test.json 

修改读取路径之后可以读取到json文件,以下是通过单独的Java类中获得绝对路径方法,因为文件夹中有空格,所以我把其中空格部分被改变的进行替换

String path = JsonUtil.class.getClassLoader().getResource("/Test.json").getPath().replace("%20", " ");
JsonParser parser = new JsonParser();
    JsonObject object = (JsonObject) parser.parse(new FileReader(path ));

但是这样读取出来的内容却是乱码的,原因可能是系统编码格式和编译器的编码格式不一致,所以我改用流的方式读取文件

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.Reader;
import java.util.ArrayList;
import java.util.List;
import com.google.gson.JsonArray;
import com.google.gson.JsonIOException;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
import com.google.gson.JsonSyntaxException;
/**
 * @author LK 
 */
public class JsonUtil {
/**
   * 读取本地json文件,获取json格式字符串
   * @return
   */
  public static String getJsonString(){
    String path = JsonUtil.class.getClassLoader().getResource("/Test.json").getPath().replace("%20", " ");
    File file = new File(path);
    try {
      FileReader fileReader = new FileReader(file);
      Reader reader = new InputStreamReader(new FileInputStream(file),"utf-8");
      int ch = 0;
      StringBuffer sb = new StringBuffer();
      while ((ch = reader.read()) != -1) {
        sb.append((char) ch);
      }
      fileReader.close();
      reader.close();
      String jsonString = sb.toString();
      return jsonString;
    } catch (IOException e) {
      e.printStackTrace();
      return null;
    }
  }
}

然后再把获取到的json格式的String进行解析

String jsonString = JsonUtil.getJsonString();
JsonParser parser = new JsonParser();
    JsonObject object = (JsonObject) parser.parse(jsonString);

这样就可以获取到正确的JsonObject

以上这篇解决JavaWeb读取本地json文件以及乱码的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。

以上就是本次给大家分享的全部知识点内容总结,大家还可以在下方相关文章里找到等java文章进一步学习,感谢大家的阅读和支持。

上一篇:java对synchronized的优化知识点总结

下一篇:Java基本数据类型不需要进行创建对象的原因

展开 +

收起 -

学习笔记
网友NO.526901

引入JavaScript时alert弹出框显示中文乱码问题

今天在HTML中引入JavaScript文件运行时,alert弹出的提示框中文显示为乱码。 经查有两种可能: 1.JavaScript与HTML文件编码方式不一样 办法:在引入JavaScript的代码中指定其字符集为gb2312,代码如下: script charset="gb2312" type="text/javascript" language="javascript" src="javascript.js"/script 2.HTML的编码方式不支持显示中文 办法:在head/head中添加一个meta标签,指定HTML编码格式为UTF-8,代码如下: meta http-equiv="content-type" content="text/html; charset=UTF-8" 总结 以上所述是小编给大家介绍的引入JavaScript时alert弹出框显示中文乱码问题,希望对大家有所帮助! ……

网友NO.352053

解决JavaWeb读取本地json文件以及乱码的问题

最近在开发项目的时候遇到一个问题,在myecilpes上使用googlede gson读取项目中的json文件成功,然后把项目发布到tomcat上再使用同样的方法,会提示“系统找不到指定的路径” 文件放在src/config/下 JsonParser parser = new JsonParser(); JsonObject object = (JsonObject) parser.parse(new FileReader("config/Test.json")); 在找了许多文章以后,发现问题应该是,发布到服务器之后,读取文件的相对路径并不能寻找到文件,所以只能使用绝对路径,找到在tomcat的 webapps下的项目Test 路径是 D:\Program Files\Tomcat 8.0\webapps\Test\WEB-INF\classes\Test.json 修改读取路径之后可以读取到json文件,以下是通过单独的Java类中获得绝对路径方法,因为文件夹中有空格,所以我把其中空格部分被改变的进行替换 String path = JsonUtil.class.getClassLoader().getResource("/Test.json").getPath().replace("%20", " ");JsonParser parser = new JsonParser(); JsonObject object = (JsonObject) parser.parse(new FileReader(path )); 但是这样读取出来的内容却是乱码的,原因可能是系统编码格式和编译器的编码格式不一致,所以我改用流的方式读取文件 import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileReader;import java.io.IOException;import java.io.InputStreamReader;import java.io.Reader;import java.util.ArrayList;import java.util.List;import com.google.gs……

网友NO.791452

完美解决Java获取文件路径出现乱码的问题

在Java中有时获取文件路径,获取的路径中存在中文或者是空格的时候,路径出现乱码。这个问题困扰了我好久,用过各种的转码都无济于事。在后来终于解决了,在这里和大家分享一下,其实也就是加一行代码的问题。 我在项目的是使用 String path = this.getClass().getClassLoader().getResource("/").getPath().substring(1); 这样来获得当前类的文件路径的。但是这样得到的是乱码。后来经过跟踪 在this.getClass().getClassLoader()返回的url这里的路径还是没错的。只是后面有问题。所以转码的话应该是要转url.所以在后面添加了这样一行代码。 path = java.net.URLDecoder.decode(path, "utf-8"); 这样做获得的路径就没问题了。 呵呵 此问题解决! String path = this.getClass().getClassLoader().getResource("/").getPath().substring(1);path = java.net.URLDecoder.decode(path, "utf-8"); 以上这篇完美解决Java获取文件路径出现乱码的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。 ……

网友NO.620587

Java判断字符串是否含有乱码实例代码

具体代码如下所示: /** * 判断字符是否是中文 * * @param c 字符 * @return 是否是中文 */ public static boolean isChinese(char c) { Character.UnicodeBlock ub = Character.UnicodeBlock.of(c); if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS) { return true; } return false; } /** * 判断字符串是否是乱码 * * @param strName 字符串 * @return 是否是乱码 */ public static boolean isMessyCode(String strName) { Pattern p = Pattern.compile("\s*|t*|r*|n*"); Matcher m = p.matcher(strName); String after = m.replaceAll(""); String temp = after.replaceAll("\p{P}", ""); char[] ch = temp.trim().toCharArray(); float chLength = ch.length; float count = 0; for (int i = 0; i ch.length; i++) { char c = ch[i]; if (!Character.isLetterOrDigit(c)) { if (!isChinese(c)) { count = count + 1; } } } float result = count / chLength; if (result 0.4) { return true; } else { return false; } } public static void main(String[] args) { System.out.println(isMessyCode("")); System.out.println(isMessyCode("你好")); } 总结 以上所述是小编给大家介绍的Java判断字符串是否含有乱码实例代码,希望对大家有所帮助,如果大家有任何疑问请给我……

<
1
>

Copyright 2018-2019 xz577.com 码农之家

版权责任说明