`
xudongcsharp
  • 浏览: 467032 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

form表单中get与post的区别

    博客分类:
  • HTML
阅读更多
Form中的get和post方法,在数据传输过程中分别对应了HTTP协议中的GET和POST方法。二者主要区别如下:

1、Get是用来从服务器上获得数据,而Post是用来向服务器上传递数据。
2、Get将表单中数据的按照variable=value的形式,添加到action所指向的URL后面,并且两者使用“?”连接,而各个变量之间使用“&”连接;Post是将表单中的数据放在form的数据体中,按照变量和值相对应的方式,传递到action所指向URL。
3、Get是不安全的,因为在传输过程,数据被放在请求的URL中,而如今现有的很多服务器、代理服务器或者用户代理都会将请求URL记录到日志文件中,然后放在某个地方,这样就可能会有一些隐私的信息被第三方看到。另外,用户也可以在浏览器上直接看到提交的数据,一些系统内部消息将会一同显示在用户面前。Post的所有操作对用户来说都是不可见的。
4、Get传输的数据量小,这主要是因为受URL长度限制;而Post可以传输大量的数据,所以在上传文件只能使用Post(当然还有一个原因,将在后面的提到)。
5、Get限制Form表单的数据集的值必须为ASCII字符;而Post支持整个ISO10646字符集。
6、Get是Form的默认方法。

============================================================
研究一阵子乱码问题,得到点经验:
form方式提交get与post
一、.get方式提交会把参数拼接到url后面,所以你在action中request.setCharacterEncoding("utf-8");是没有用的!
解决方法2种:
1.修改server.xml的< Connector port="8080" 节点,添加一个属性URIEncoding="utf-8"
2.服务器端new String(request.getParameter("title").getBytes("iso-8859-1"), "utf-8");

二.post方式提交form表单的内容,pageEncoding指定了它的编码,所以他会按照指定编码传递。 request.setCharacterEncoding("utf-8");即可解决

参考:http://read.newbooks.com.cn/info/169649.html
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics