您的位置:首页 > 理论基础 > 计算机网络

HTTP的GET和POST

2015-09-29 15:34 405 查看
Http定义了与服务器交互的不同方法,最基本的有四种,分别是GET,POST,PUT,DELETE。 URL全称是资源描述符,我们可以认为:一个URL地址,他用于描述一个网上的资源,而HTTP中的GET,POST,PUT,DELETE就对应着这个资源的查,改,增,删四个操作。GET一般用于获取/查询资源信息,而POST一般用于更新资源信息。

一,GET 和 POST 的原理
1,根据HTTP规范,GET用于信息获取,而且应该是安全和幂等的。
(1),所谓安全的,意味着该操作用于获取信息而非修改信息。换句话说,GET请求一般不产生副作用,他仅仅是获取资源信息,不会修改或者增加数据,不会影响资源的状态。
*注意:这里安全的含义仅仅是指不修改信息。
(2),幂等意味着堆同一URL的多个请求应该返回同样的结果。

在实际应用中,以上两条规定并没有那么严格。引用例子:比如,一个新闻站点的头条不断更新,虽然第二次请求返回的新闻跟第一次不同,该操作任然被认为是安全和幂等的,一位它总是返回当前的新闻。从根本来说,如果一个用户打开一个链接时,他可以确定从自身的角度来看没有改变资源即可。

2,根据HTTP规范,POST表示可能改变服务器的资源请求。
继续引用上面的例子:读者堆新闻发表自己的评论应该通过POST来实现,因为评论提交后站点的资源已经不同了,或者说资源已经被修改了。

小结:上面大概说了HTTP规范中GET和POST的一些原理性问题,但在实际做的时候,很多人却没有按照HTTP规范去做,导致这个问题的原因有很多,如下:
1,很多人贪便宜,更新资源用了GET,因为POST必须要到FROM表单,这样会麻烦一点;
2,堆资源的增删改查,其实都可以通过GET/POST完成,不需要要到PUT和DELETE;
3,早起的Web MVC框架设计者们并没有有意识地将URL当做抽象的资源来看待和设计,所以导致了一个比较严重的问题是传统的Web MVC基本框架只支持GET和POST,而不支持PUT和DELETE

*MVC: MVC本来是存在于Desktop程序中的,M是指数据模型,V是用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。

二,GET 和 POST 的表象
1,GET请求的数据会附在URL之后;POST则把提交的数据放置在HTTP的包体中
*注:GET请求的URL,以?分割URL和传输数据,参数间以&相连,如:login.action?name=nike&passward=idontknow&verify=%E4%BD%jGH%bd。如果数据是英文字母或者数字,原样发送;如果是空格,转换为+;如果是中文或者其他字符,则直接把字符串用Base64加密。

2,POST的安全性比GET要高,但并非绝对的安全
比如,通过GET提交数据,用户名和密码静明文出现在URL中,别人很容易拿到你的账号和密码;除此之外,使用GET提交数据还可能会造成Cross-site request forgery攻击。

小结:GET是向服务器发送索取数据的一种请求;POST是想服务器提交数据的一种请求。在FORM(表单)中,Method默认未”GET”.而实质上,GET和POST只是发送机制不同。

参考资料:
[1]./article/1306158.html
[2].http://www.cnblogs.com/hyddd/archive/2009/03/31/1426026.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: