## 一,字符编码
字符在存入的时候,都会被转换成二进制的字节,如果存的时候,按照一个规范来存,取的时候按照另一个规范来取的话,就会出现乱码.
- 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("Content-Type","text/html;charset=utf-8");来通知浏览器,服务器使用的是utf-8编码.
- setHeader("Content-Type","text/html;charset=utf-8");可以完成设置服务器编码和通知浏览器服务器是什么编码两步,快捷写法是:response.setContentType("text/html;charset=utf-8");
![响应编码流程图](http://ww4.sinaimg.cn/large/006tNbRwly1feyr25ijhxj319k0y8qax.jpg)
## 三,请求编码
- 客户端发送给服务器的请求参数是什么编码:
- 客户端首先打开一个页面,然后在页面中提交表单或点击超链接,在请求这个页面时,服务器响应的编码是什么,那么客户端发送请求时的编码就是什么.
- 服务器默认使用什么编码来解码参数:
- 服务器端默认使用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");
![请求编码流程图](http://ww4.sinaimg.cn/large/006tNbRwly1feyrsgody7j318m1067bg.jpg)
## 四,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编码!通过jsp实现.
### 为什么要使用URL编码?
在客户端和服务器之间传递非英文时需要将文本转换成网络适合的方式.(传中文,有时会丢一个半个字节的);
使用URL编码可以方便,安全的传输;
```java
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);
}
}
```