1)Get, 它用于获取信息,注意,他只是获取、查询数据,也就是说它不会修改服务器上的数据,从这点来说,它是数据安全的,而稍后会提到的Post它是能够修改数据的,因此这也是二者差异之一了。html
2) Post,它是能够向服务器发送修改请求,从而修改服务器的,比方说,咱们要在论坛上回贴、在博客上评论,这就要用到Post了,固然它也是能够仅仅获取数据的。浏览器
3)Delete 删除数据。能够经过Get/Post来实现。用的很少,暂很少写,之后扩充。安全
4)Put,增长、放置数据,能够经过Get/Post来实现。用的很少,暂很少写,之后扩充。服务器
下面简述一下Get和Post区别:oop
1) GET请求的数据是放在HTTP包头中的,也就是URL以后,一般是像下面这样定义格式的,(而Post是把提交的数据放在HTTP正文中的)。大数据
login.action?name=hyddd&password=idontknow&verify=%E4%BD%E5%A5%BD编码
a,以 ? 来分隔URL和数据; 加密
b,以& 来分隔参数;spa
c,若是数据是英文或数字,原样发送;操作系统
d,若是数据是中文或其它字符,则进行BASE64编码。
2)GET提交的数据比较少,最多1024B,由于GET数据是附在URL以后的,而URL则会受到不一样环境的限制的,好比说IE对其限制为2K+35,而POST能够传送更多的数据(理论上是没有限制的,但通常也会受不一样的环境,如浏览器、操做系统、服务器处理能力等限制,IIS4可支持80KB,IIS5可支持100KB)。
3)Post的安全性要比Get高,由于Get时,参数数据是明文传输的,并且使用GET的话,还可能形成Cross-site request forgery攻击。而POST数据则能够加密的,但GET的速度可能会快些。
因此综上几点,总结成下表:
操做方式 |
数据位置 |
明文密文 |
数据安全 |
长度限制 |
应用场景 |
GET |
HTTP包头 |
明文 |
不安全 |
长度较小 |
查询数据 |
POST |
HTTP正文 |
可明可密 |
安全 |
支持较大数据传输 |
修改数据 |
转自
http://blog.csdn.net/wangzhilife/article/details/12440089
客户端get请求解决乱码问题
客户端经过Get方式向服务器发送中文数据,需先对中文数据进行转码操做
URLEncoder.encode(name,"utf-8")
服务端解决乱码
new String(name.getBytes("iso-8859-1"),"utf-8")//字符转码操做,防止中文乱码 response.setContentType("text/html;charset=utf-8")//显示转码