编码总结(java)

一,字符编码

字符在存入的时候,都会被转换成二进制的字节,如果存的时候,按照一个规范来存,取得时候按照另一个规范来取得话,就会出现乱码

–> iso-8859-1(国际标准化组织命名的不支持中文,在ASCII码基础上扩充了一些拉丁字符);

–> gbk(系统默认编码,中国的国际码,是在gb2312基础上的扩展规范),gb18030是gbk的基础上的又一次扩充

–> utf-8(万国码,支持全世界的编码,使用这个就可以了)

二, 响应编码

–> 当使用response.getWriter()来向客户端发送字符数据时,如果在之前没有设置编码,那么默认使用iso,因为iso不支持中文,一定会乱码

–> 在使用response.getWriter()之前,可以使用response.setCharacterEncoding()来设置字符流的编码为gbk或utf-8,一般都会设置成utf-8;

–>在使用response.getWriter()之前,可以使用response.setHeader(“Context-type”,”text/html;charset=utf-8”);来通知浏览器,服务器使用的是utf-8编码

–> setHeader(“Context-Type”,”text/html;charset=utf-8”)可以完成设置服务器编码和通知浏览器服务器是什么编码两步,快捷写法是:
response.setContentType(“text/thml;charset=utf-8”);
这里写图片描述

三, 请求编码

客户端发送给服务器的请求参数是什么编码?
–>客户端首先打开一个页面,然后在页面中提交表单或点击超链接,在请求这个页面时,服务器响应的编码是什么,那么客户端发送请求时的编码就是什么.
服务器默认使用什么编码来解码参数?
–> 服务器端默认使用ISO-8859-1来解码,所以这里一定会出现乱码,因为iso-8859-1是不支持中文的.
请求编码处理分为两种:GET和POST:GET请求参数不在请求体重,而POST请求参数在请求体中,所以他们的处理方式是不同的
GET请求编码处理:

String name = new String(request.getParameter("name").getBytes("iso-8859-1"),"utf-8");

–> 也可以在/conf/server.xml中配置端口号的标签中添加配置:URIEncoding=utf-8;但是这种修改只是本地的修改

POST请求编码处理:

–> 在获取参数之前调用request.setCharacterEncoding(“utf-8”);
这里写图片描述

四, URL编码

–> 首先URL编码不是字符编码

–> URL编码,是客户端与服务端之间传递参数的一种方式

–> URL编码需要先指定一种字符编码,把字符串解码后,得到byte数组,然后把小于0的字节+256,再转换成16进制,前面再添加一个%.

–> 就是讲中文转换成%后面跟随两位16进制的格式

–> POST请求默认就使用URL编码,tomcat会自动使用URL编码.

//URl编码
String username = URLEncoder.encode(username, "utf-8");
//URL解码:
String username = URLDecoder.encode(username, "utf-8");

为什么使用URL编码

在客户端和服务器之间传递非英文时需要将文本转换成网络适合的方式.(传中文,有时会丢一个半个字节的),使用URL编码可以方便,安全的传输

public class UrlEncodeDemo{

   public static void main(String[] args) throws UnsupportedEncodingException{

    String name = "社会王";
    //得到name进行utf-8编码后的字节数组
    byte[] bytes = name.getBytes("utf-8");
    //[-27, -68, -96, -28, -72, -119]
    System.out.println(Arrays.toString(bytes));
   //对name字符串,以utf-8编码的格式进行url编码得到
   //un:%E5%BC%A0%E4%B8%89
   //对[-27, -68, -96, -28, -72, -119]中的负数
   //加255后,再转换成16进制,再在前面加上%得到最终结果
   String un = URLEncoder.encode(name,"utf-8");
   System.out.println(un);
   //将url编码生成的带%的字符串解码成正常的字符串:社会王
   un = URLDecoder.decode(un, "utf-8");
   System.out.println(un);

   {
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章