zoukankan      html  css  js  c++  java
  • 关于java.net.URLEncoder.encode编码问题

    Q:java.net.URLEncoder.encode里的编码和什么有关的?

    A:使用urlencoder编码会将中文变成你在浏览器地址栏看到的%XX形式,至于选择哪种enc编码跟你jvm的default charset有关,因为java项目一般用的都是UTF-8编码,为了防止你的中文以其他编码方式打开的时候乱码(如果这个时候乱码了,你在编码解码也是乱码),推荐整个项目使用同一编码解码,如果你的项目用的是GBK的,那么java.net.URLEncoder.encode("中文.zip","GBK")也是完全没问题的,但如果你用其他编码比如iso8859-1就会解出来乱码了

    Q:至于选择哪种enc跟你jvm的default charset有关 默认是UTF-8? 和tomcat目录下的conf目录下的设置端口号那个标签里的URIEncoding="UTF-8"这个属性有关么?

    A:有的,如果你用的是tomcat的话,因为你网络传输需要经过tomcat处理的,tomcat会将你的网络流编码转换成配置中的编码,如果两边不对应的话,有可能会出现乱码,但如果编码站位较长转为短码也不会乱码

    Q:为什么我将URIEncoding改成GBK也没见它乱码呢?

    A:那要看你的项目编码设置咯,你的项目是GBK的话,tomcat的传输编码会以你运行project为准,你可以改成iso的试试的嘛

    在Web的浏览器中,不同的浏览器的编码和解码规则是不一样的.

       对于W3C浏览器:遵循W3C组织规范的浏览器,(非IE).

                   编码:byte[] data = “任小龙”.getByte(String charsetName);

                   解码:String  str = new String(data, String charsetName);

       对于IE浏览器:

                  编码使用的application/x-www-form-urlencodedMIME机制.

  • 相关阅读:
    JVM(一)--Java内存区域
    leetcode33 搜索旋转排序数组
    二叉树的相关算法(一)
    分别求二叉树前、中、后序的第k个节点
    【蓝桥杯】历届试题 买不到的数目
    JAVA的JVM的内存可分为3个区:堆(heap)、栈(stack)和方法区(method)
    【蓝桥杯】核桃的数量
    Java内存分析之对象实例化操作初步分析
    【蓝桥杯】算法训练 K好数
    【蓝桥杯】基础练习试题
  • 原文地址:https://www.cnblogs.com/JSD1207ZX/p/10264883.html
Copyright © 2011-2022 走看看