multipart/form-data;application/x-www-form-urlencoded;text/plain;怎么接收
来源:互联网 发布:怎样注册公司域名 编辑:程序博客网 时间:2024/05/22 01:39
我们经常用servlet和jsp, 经常用request.getParameter() 来得到数据。
request.getParameter()
request.getInputStream()
request.getReader()
这三个方法都是从request对象中得到提交的数据,但是用途不同。
要根据表单提交数据的编码方式选择不同的方法。
HTML中的form表单的一个关键属性 enctype:
enctype=application/x- www-form-urlencoded
这种编码方式是默认的编码方式。
编码后的结果通常是field1=value2&field2=value2&… 的形式,如 name=aaaa&password=bbbb。
通常使用的表单也是采用这种方式编码的,Servlet 的 API 提供了对这种 编码方式解码的支持,只需要调用 ServletRequest 类中的 getParameter()方法就可以得到用户表单中的字段和数据。
不足:
这种编码方式( application/x-www-form-urlencoded )虽然简单,但对于传输大块的二进制数据显得力不从心。
对于传输大块的二进制数这类数据,浏览器采用了另一种编码方式,即 “multipart/form-data” 的编码方式:
浏览器可以很容易将表单内的数据和文件放在一起发送。这种编码方式先定义好一个不可能在数据中出现的字符串作为 分界符,然后用它将各个数据段分开,而对于每个数据段都对应着 HTML 页面表单中的一个 Input 区,包括一个 content-disposition 属性,说明了这个数据段的一些信息,如果这个数据段的内容是一个文件,还会有 Content-Type 属性,然后就是数据本身,如果以这种方式提交数据就要用request.getInputStream()或request.getReader()得到 提交的数据,用 request.getParameter()是得不到提交的数据的。
3.需要注意的是:
request.getParameter()、 request.getInputStream()、request.getReader()这三种方法是有冲突的,因为流只能被读一次。
比如:
当form表单内容采用 enctype=application/x-www-form-urlencoded编码时,先通过调用request.getParameter() 方法得到参数后,再调用request.getInputStream()或request.getReader()已经得不到流中的内容,因为在调用 request.getParameter()时系统可能对表单中提交的数据以流的形式读了一次,反之亦然。
当form表单内容采用enctype=multipart/form-data编码时,即使先调用request.getParameter()也得不到数据,所以这时调用request.getParameter()方法对 request.getInputStream()或request.getReader()没有冲突,即使已经调用了 request.getParameter()方法也可以通过调用request.getInputStream()或request.getReader()得 到表单中的数据,而request.getInputStream()和request.getReader()在同一个响应中是不能混合使用的,如果混合使用就会抛异常。
- multipart/form-data;application/x-www-form-urlencoded;text/plain;怎么接收
- application/x-www-form-urlencoded multipart/form-data text/plain
- application/x-www-form-urlencoded、multipart/form-data、text/plain
- application/x-www-form-urlencoded、multipart/form-data、text/plain
- application/x-www-form-urlencoded、multipart/form-data、text/plain
- application/x-www-form-urlencoded、multipart/form-data、text/plain
- application/x-www-form-urlencoded、multipart/form-data、text/plain
- application/x-www-form-urlencoded、multipart/form-data、text/plain
- application/x-www-form-urlencoded、multipart/form-data、text/plain
- 对application/x-www-form-urlencoded、multipart/form-data和text/plain的认识
- application/x-www-form-urlencoded & multipart/form-data & text/plain
- 设置form表单传输的编码格式 application/x-www-form-urlencoded、multipart/form-data、text/plain
- 设置form表单传输的编码格式 application/x-www-form-urlencoded、multipart/form-data、text/plain
- application/x-www-form-urlencoded 与multipart/form-data
- application/x-www-form-urlencoded and multipart/form-data
- multipart/form-data和application/x-www-form-urlencoded
- application/x-www-form-urlencoded和multipart/form-data
- application/x-www-form-urlencoded与multipart/form-data
- 一维数组子数组的最大和
- 链表逆转和Fib队列(面试题)
- UCOSIII消息传递
- Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1
- UVA 327-Evaluating Simple C Expressions
- multipart/form-data;application/x-www-form-urlencoded;text/plain;怎么接收
- Jstree的使用
- 第一个QML简单动画
- 一文读懂卷积神经网络(Convolutional Neural Network,CNN)
- 《分布式》:paxos算法和一致性Hash算法相关记录
- 数据结构实验之查找四:二分查找
- 2016七夕奇葩礼物第一名,不服来辩!
- 【fix issue】jsp连接SQL2000数据库出错解决办法@2010-05-05
- C++虚函数(1)