• 不同浏览器中URL的编码方式


    一、直接在地址栏中输入URL的情况 
    在中文Windows环境下,本地编码为GB2312: 
    这里写图片描述 
    这里写图片描述 
    假如在浏览器地址栏中直接输入以下URL:

    http://localhost:8080/servletTest/中国.do?name=中国

    1、IE浏览器 
    版本: 
    这里写图片描述 
    默认情况下,总是以UTF-8发送URL: 
    这里写图片描述 
    这里要用到一个抓包工具Fiddler,安装后启动就行。

    打开IE,输入URL: 
    这里写图片描述 
    此时,Fiddler中会抓取到数据: 
    这里写图片描述
    会发现,pathInfo中的“中国”两个字被编码为:%E4%B8%AD%E5%9B%BD。这个是UTF-8编码。而queryString中的‘中国’两个字是乱码:name=�й�。在Fiddler中切换到十六进制可以看到真实的编码: 
    这里写图片描述
    这个十六进制编码D6 D0 B9 FA,就是‘中国’两个字的GB2312编码。

    现在将默认修改为不以UTF-8发送: 
    这里写图片描述 
    再次在IE的地址栏中输入请求URL: 
    这里写图片描述 
    发现pathInfo部分的”中国”两个字的编码是%D6%D0%B9%FA。但是queryString部分依旧是乱码,按照十六进制查看,也是按照GB2312。

    小结:IE9 中的编码方式 
    这里写图片描述

    二、利用FireFox浏览器直接在地址栏输入URL进行访问 
    浏览器版本: 
    这里写图片描述
    在默认的情况下,输入URL:

    http://localhost:8080/servletTest/中国.do?name=中国

    这里写图片描述
    发现URL中pathInfo和queryString中“中国”两个字的编码是:%E4%B8%AD%E5%9B%BD,这是UTF-8编码。

    小结:火狐浏览器默认utf-8编码(浏览器版本可能会有差异) 
    这里写图片描述

    3、Chrome浏览器直接访问URL 
    这里写图片描述 
    这里写图片描述
    发现URL中pathInfo和queryString中“中国”两个字的编码是:%E4%B8%AD%E5%9B%BD,这是UTF-8编码。

    小结:Chrome浏览器默认utf-8编码(浏览器版本可能会有差异) 
    这里写图片描述

    二、根据页面的编码,各种浏览器的URL编码 
    1、使用Get请求,页面设置为:

    <%@ page contentType="text/html;charset=GBK" language="java" %>
     <form action="中国.do?contry=中国" method="get" enctype="multipart/form-data">
                 <table>
                     <tr>
                         <td>姓名</td>
                         <td><input name="name" type="text"></td>
                         <td>年龄</td>
                         <td><input name="age" type="text"></td>
    
                     </tr>
                     <tr><input type="submit" value="提交"></tr>
                 </table>

    1.1 firefox浏览器(默认设置) 
    这里写图片描述 
    输入以下内容,提交: 
    这里写图片描述 
    这里写图片描述 
    火狐浏览器在页面是GBK编码的情况下,采用GET提交,发现pathInfo部分是UTF-8编码,但是queryString是GBK编码(也就是页面数据部分)。

    1.2、将页面编码修改为UTF-8:

    <%@ page contentType="text/html;charset=UTF-8" %>

    重新提交 GET请求: 
    这里写图片描述 
    火狐浏览器在页面是UTF-8编码的情况下,采用GET提交,发现pathInfo部分是UTF-8编码,但是queryString是UTF-8编码(也就是页面数据部分)。

    1.3、用Chrome浏览器(默认) 
    这里写图片描述 
    Chrome浏览器在页面是GBK编码的情况下,发现pathInfo部分是UTF-8编码,但是queryString是GBK编码(也就是页面数据部分)。

    1.4、采用Chrome浏览器采用PostT提交: 
    这里写图片描述 
    Chrome浏览器在页面是UTF-8编码的情况下,采用GET提交,发现pathInfo部分是UTF-8编码,但是queryString是UTF-8编码(也就是页面数据部分)。

    小结:1、页面编码是GBK,提交是GET 的情况下: 
    这里写图片描述

    2、页面编码是UTF-8,提交是GET的情况下: 
    这里写图片描述

    2、采用Post提交,但是页面还是设置GBK:

    <%@ page contentType="text/html;charset=GBK" %>
    <form action="中国.do?contry=中国" method="post" enctype="multipart/form-data">
                 <table>
                     <tr>
                         <td>姓名</td>
                         <td><input name="name" type="text"></td>
                         <td>年龄</td>
                         <td><input name="age" type="text"></td>
    
                     </tr>
                     <tr><input type="submit" value="提交"></tr>
                 </table>

    2.1、火狐浏览器 

    这里写图片描述 
    这里写图片描述 
    火狐浏览器在页面是GBK编码的情况下,采用POST提交,发现pathInfo部分是UTF-8编码,但是queryString是GBK编码(也就是页面数据部分)。

    2.2、修改页面编码格式为UTF-8,: 
    这里写图片描述 
    火狐浏览器在页面是UTF-8编码的情况下,采用POST提交,发现pathInfo部分是UTF-8编码,但是queryString是UTF-8编码(也就是页面数据部分)。

    2.3、Chrome浏览器 
    这里写图片描述 
    Chrome浏览器在页面是GBK编码的情况下,采用POST提交,发现pathInfo部分是UTF-8编码,但是queryString是GBK编码(也就是页面数据部分)。

    2.4、页面也修改为UTF-8编码: 
    这里写图片描述 
    Chrome浏览器在页面是UTF-8编码的情况下,采用POST提交,发现pathInfo部分是UTF-8编码,但是queryString是UTF-8编码(也就是页面数据部分)。

    小结:1、页面编码是GBK,提交是POST 的情况下: 
    这里写图片描述

    2、页面编码是UTF-8,提交是POST 的情况下: 
    这里写图片描述

  • 相关阅读:
    【洛谷p1309】瑞士轮
    【洛谷p1190】接水问题
    KMP算法小记
    【洛谷p1051】谁拿了最多奖学金
    【洛谷p1781】宇宙总统
    【6.12校内test】T2 子集
    【6.12校内test】T3 城市交通费
    【6.12校内test】T1单词序列
    【洛谷p1464】 Function
    IOS基础之 (十二) 类的扩展
  • 原文地址:https://www.cnblogs.com/iqian/p/9018727.html
Copyright © 2020-2023  润新知