最近作项目时,发现手机客户端经过http协议post方式上传数据到服务端,在服务器端经过request.getInputStream()能获取到相应的数据,但用request.getParameter()却获取不到数据。这是怎么回事呢,后来发现这种状况跟form表单的属性 enctype有关系。php
HTML中的form表单有一个关键属性 enctype=application/x-www-form-urlencoded 或multipart/form-data。html
一、enctype="application/x-www-form-urlencoded"是默认的编码方式,当以这种方式提交数据时,HTTP报文中的内容是:服务器
<span style="font-size: small;">POST /post_test.php HTTP/1.1 Accept-Language: zh-CN User-Agent: Mozilla/4.0 Content-Type: application/x-www-form-urlencoded Host: 192.168.12.102 Content-Length: 42 Connection: Keep-Alive Cache-Control: no-cache title=test&content=%B3%AC%BC%B6%C5%AE%C9%FA&submit=post+article </span>
Servlet的API提供了对这种编码方式解码的支持,只须要调用ServletRequest 类中的getParameter()方法就能够获得表单中提交的数据。app
<span style="font-size: small;">POST /post_test.php?t=1 HTTP/1.1 Accept-Language: zh-CN User-Agent: Mozilla/4.0 Content-Type: multipart/form-data; boundary=---------------------------7dbf514701e8 Accept-Encoding: gzip, deflate Host: 192.168.12.102 Content-Length: 345 Connection: Keep-Alive Cache-Control: no-cache -----------------------------7dbf514701e8 Content-Disposition: form-data; name="title" test -----------------------------7dbf514701e8 Content-Disposition: form-data; name="content" .... -----------------------------7dbf514701e8 Content-Disposition: form-data; name="submit" post article -----------------------------7dbf514701e8--</span>
若是以这种方式提交数据就要用request.getInputStream()或request.getReader()来获取提交的数据,用 request.getParameter()是获取不到提交的数据的。post
最后注意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.getInputStream()和request.getReader()在同一个响应中是不能混合使用的,若是混合使用会抛异常的。编码
来源:http://well-lf.iteye.com/blog/1543807