zoukankan      html  css  js  c++  java
  • response设置编码的三种方式以及比较

    2017年01月03日 14:12:46 Listen_Silently 

    在很多场合会发现我们输出的中文是乱码,这主要可能有两方面的原因:

    一个是浏览器的解析方式,另一个是我们服务器端返回数据的方式。只要我们保证浏览器的解析方式和我们回显的数据的编码格式是一致的,基本上乱码问题就可以得到解决。大多数数情况下,浏览器的默认编码方式是utf-8,因此我们只要设置服务器返回的数据的编码方式也是utf-8即可。

    在Java后台的Action代码或者Servlet代码中用response的方法来设置输出内容的编码方式,主要有以下三个方法:
     

     1、response.setCharacterEncoding("UTF-8");
    
    
     2、response.setContentType("text/html;charset=UTF-8");
    
    
     3、response.setLocale(new java.util.Locale("zh","CN"));


     
    下面对以上3种方法进行差异分析:
          第一种方法只能用来设置out输出流中所采用的编码,但是它的优先权最高,可以覆盖后面两种方法中的设置;


          第二中方法可以设置out输出流中字符的编码方式,也可以设置浏览器接收到这些字符后以什么编码方式来解码,它的优先权低于第一种方法,  
    但高于第三种方法;这种方法通知response以UTF-8输出和浏览器以UTF-8打开。即等价于

    response.setHeader("content-type", "text/html;charset=UTF-8");通知浏览器以utf-8解析

    和response.setCharacterEncoding("UTF-8");注意第二句句需要写在PrintWriter out = response.getWriter();的前面,如果拿到字符流后再设置编码是没有用的。


          第三种方法只能用来设置out输出流中字符的编码方式,但是它的优先权最低,在已经使用前两种方法中的一个设置了编码方式以后,它就被覆盖而不起作用了。

  • 相关阅读:
    数据库插入大量数据时不要忘记先删除索引(小技巧)
    solr入门之权重排序方法初探之使用edismax改变权重
    sql server查看表占用索引空间(小技巧)
    sql server不要插入大数据,开销太大
    MongoDB——更新操作(Update)c#实现
    solr中facet及facet.pivot理解
    Solr --- Group查询与Facet区别
    Solr中的group与facet的区别
    solr之模糊搜索(Fuzzy matching)
    solr之~模糊查询
  • 原文地址:https://www.cnblogs.com/grj001/p/12225649.html
Copyright © 2011-2022 走看看