转自:https://blog.csdn.net/mhmyqn/article/details/25561535

HTTP请求中,如果是get请求,那么表单参数以name=value&name1=value1的形式附到url的后面,如果是post请求,那么表单参数是在请求体中,也是以name=value&name1=value1的形式在请求体中。通过chrome的开发者工具可以看到如下(这里是可读的形式,不是真正的HTTP请求协议的请求格式):

get请求:

[plain] view plain copy
  1. RequestURL:http://127.0.0.1:8080/test/test.do?name=mikan&address=street
  2. RequestMethod:GET
  3. StatusCode:200OK
  4. RequestHeaders
  5. Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
  6. Accept-Encoding:gzip,deflate,sdch
  7. Accept-Language:zh-CN,zh;q=0.8,en;q=0.6
  8. AlexaToolbar-ALX_NS_PH:AlexaToolbar/alxg-3.2
  9. Connection:keep-alive
  10. Cookie:JSESSIONID=74AC93F9F572980B6FC10474CD8EDD8D
  11. Host:127.0.0.1:8080
  12. Referer:http://127.0.0.1:8080/test/index.jsp
  13. User-Agent:Mozilla/5.0(WindowsNT6.1)AppleWebKit/537.36(KHTML,likeGecko)Chrome/33.0.1750.149Safari/537.36
  14. querystringparameters
  15. name:mikan
  16. address:street
  17. ResponseHeaders
  18. Content-Length:2
  19. Date:Sun,11May201410:42:38GMT
  20. Server:Apache-Coyote/1.1

Post请求:

RequestURL:http://127.0.0.1:8080/test/test.do
  • RequestMethod:POST
  • Cache-Control:max-age=0
  • Connection:keep-alive
  • Content-Length:25
  • Content-Type:application/x-www-form-urlencoded
  • Cookie:JSESSIONID=74AC93F9F572980B6FC10474CD8EDD8D
  • Host:127.0.0.1:8080
  • Origin:http://127.0.0.1:8080
  • FormData
  • ottom:none;border-left:3px solid rgb(108,11May201411:05:33GMT
  • 这里要注意post请求的Content-Type为application/x-www-form-urlencoded,参数是在请求体中,即上面请求中的Form Data。

    在servlet中,可以通过request.getParameter(name)的形式来获取表单参数。

    而如果使用原生AJAX POST请求的话:

    [javascript] view plain copy
    1. functiongetXMLHttpRequest(){
    2. varxhr;
    3. if(window.ActiveXObject){
    4. xhr=newActiveXObject("Microsoft.XMLHTTP");
    5. }elseif(window.XMLHttpRequest){
    6. newXMLHttpRequest();
    7. else{
    8. null;
    9. }
    10. returnxhr;
    11. functionsave(){
    12. varxhr=getXMLHttpRequest();
    13. xhr.open("post","http://127.0.0.1:8080/test/test.do");
    14. vardata="name=mikan&address=street...";
    15. xhr.send(data);
    16. xhr.onreadystatechange=function(){
    17. if(xhr.readyState==4&&xhr.status==200){
    18. alert("returned:"+xhr.responseText);
    19. };
    20. }

    通过chrome的开发者工具看到请求头如下:

    Accept:*/*
  • Content-Length:28
  • Content-Type:text/plain;charset=UTF-8
  • Cookie:JSESSIONID=C40C7823648E952E7C6F7D2E687A0A89
  • Origin:http://127.0.0.1:8080
  • Referer:http://127.0.0.1:8080/test/index.jsp
  • ottom:none;border-left:3px solid rgb(108,likeGecko)Chrome/33.0.1750.149Safari/537.36
  • RequestPayload
  • name=mikan&address=street
  • ottom:none;border-left:3px solid rgb(108,11May201411:49:23GMT
  • 注意请求的Content-Type为text/plain;charset=UTF-8,而请求表单参数在RequestPayload中。

    那么servlet中通过request.getParameter(name)却是空。为什么呢?而这样的参数又该怎么样获取呢?

    为了搞明白这个问题,查了些资料,也看了Tomcat7.0.53关于请求参数处理的源码,终于搞明白了是怎么回事。

    tomcat源码下载:

    https://tomcat.apache.org/download-80.cgi

    http://mirrors.hust.edu.cn/apache/tomcat/tomcat-8/v8.0.50/src/apache-tomcat-8.0.50-src.tar.gz

    HTTP POST表单请求提交时,使用的Content-Type是application/x-www-form-urlencoded,而使用原生AJAX的POST请求如果不指定请求头RequestHeader,默认使用的Content-Type是text/plain;charset=UTF-8。

    由于Tomcat对于Content-Type multipart/form-data(文件上传)和application/x-www-form-urlencoded(POST请求)做了“特殊处理”。下面来看看相关的处理代码。

    Tomcat的HttpServletRequest类的实现类为org.apache.catalina.connector.Request(实际上是org.apache.coyote.Request),而它对处理请求参数的方法为protected void parseParameters(),这个方法中对Content-Type multipart/form-data(文件上传)和application/x-www-form-urlencoded(POST请求)的处理代码如下:

    [java] view plain copy
    1. protected voidparseParameters(){
    2. //省略部分代码......
    3. parameters.handleQueryParameters();//这里是处理url中的参数
    4. if("multipart/form-data".equals(contentType)){//这里是处理文件上传请求
    5. parseParts();
    6. success=true;
    7. return;
    8. if(!("application/x-www-form-urlencoded".equals(contentType))){//这里如果是非POST请求直接返回,不再进行处理
    9. true;
    10. return;
    11. }
    12. //下面的代码才是处理POST请求参数
    13. try{
    14. if(readPostBody(formData,len)!=len){//读取请求体数据
    15. catch(IOExceptione){
    16. //Clientdisconnect
    17. if(context.getLogger().isDebugEnabled()){
    18. context.getLogger().debug(
    19. sm.getString("coyoteRequest.parseParameters"),e);
    20. parameters.processparameters(formData,0,len);//处理POST请求参数,把它放到requestparametermap中(即request.getParameterMap获取到的Map,request.getParameter(name)也是从这个Map中获取的)
    21. protectedintreadPostBody(bytebody[],intlen)
    22. throwsIOException{
    23. intoffset=0;
    24. do{
    25. intinputLen=getStream().read(body,offset,len-offset);
    26. if(inputLen<=0){
    27. returnoffset;
    28. offset+=inputLen;
    29. while((len-offset)>0);
    30. returnlen;
    31. }

    AJAX POST请求中ContentType参数以form data和request payload形式在servlet中的获取方式的更多相关文章

    1. HTML5 WebSocket实现点对点聊天的示例代码

      这篇文章主要介绍了HTML5 WebSocket实现点对点聊天的示例代码的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    2. ios – 将视频分享到Facebook

      我正在编写一个简单的测试应用程序,用于将视频从iOS上传到Facebook.由于FacebookSDK的所有文档都在Objective-C中,因此我发现很难在线找到有关如何使用Swift执行此操作的示例/教程.到目前为止我有这个在我的UI上放置一个共享按钮,但它看起来已禁用,从我读到的这是因为没有内容设置,但我看不出这是怎么可能的.我的getVideoURL()函数返回一个NSURL,它肯定包含视

    3. ios – 错误域= NSURLErrorDomain代码= -1003“找不到具有指定主机名的服务器

      当我尝试在设备上运行应用程序时出现此错误.当我在模拟器上运行它并且post请求正常工作时,我没有收到此错误.这是我的代码片段:任何帮助表示赞赏.谢谢解决方法此错误通常会提示DNS相关问题.检查设备上的DNS设置并确认您可以使用Safari或其他浏览器浏览互联网.如果有一个url,你可以在同一台服务器上获取,尝试直接在设备上的Safari中访问它.

    4. ios – Xcode Bot:如何在post触发器脚本上获得.ipa路径?

      我正在使用机器人来存档iOS应用程序,我需要获取.ipa产品路径才能将其发布到我们的分发系统中.机器人设置:并使用脚本打印所有env变量,其中不包含ipa文件的路径.此外,一些变量指向不存在的目录,即:XCS_OUTPUT_DIR这里的env变量输出:除此之外,我还能够确认.ipa文件是在另一个文件夹中创建的(/IntegrationAssets//

    5. ios – 使用CocoaPods post install hook将自定义路径添加到HEADER_SEARCH_PATHS

      解决方法在Podfile中定义一个方法:然后在post_install中调用该方法:

    6. iOS7 Safari中的全屏模式

      我正在使用SenchaTouch开发移动网站.在iOS7Safari中,我无法创建顶级地址栏和下面的工具栏消失了.Sencha过去常常处理iOS6,但iOS7最近的一些变化导致了这个问题.http://java.dzone.com/articles/safari-ios-7-and-html5我阅读了上面的链接&对于HTML5游戏而言,这似乎也是一个问题.一些其他应用程序.适用于iOS6的旧win

    7. ios – 如何使用新的Apple Swift语言发布JSON

      本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

    8. ios – POST请求使用application / x-www-form-urlencoded

      后端开发人员在POST请求中给出了这些说明:>路线:{url}/{app_name/{controller}/{action}控制器和动作应该是小帽子.>API测试链接:http:****************>请求应该使用POST方法.>参数应通过请求内容体(FormUrlEncodedContent)传递.>参数应该是json格式.>参数是关键的.在协议中没有经验5,我搜索并结束了我的代码.

    9. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

      我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

    10. ios – 在HTTPBody中设置NSDictionary并使用POST方法发送

      我想用POST方法调用Web服务.我需要发布一个带有URL的字典.我的Web服务参数如下:以下是我的要求:但是我收到以下错误:服务器拒绝此请求,因为请求实体的格式不受所请求方法所请求资源的支持解决方法请找到以下代码,将数据发布到Web服务.请注意这是我在我的一个申请中使用的样本.希望这可以帮助.从您的评论“服务器拒绝此请求”服务器是否支持JSON或XML格式.

    随机推荐

    1. xe-ajax-mock 前端虚拟服务

      最新版本见Github,点击查看历史版本基于XEAjax扩展的Mock虚拟服务插件;对于前后端分离的开发模式,ajax+mock使前端不再依赖后端接口开发效率更高。CDN使用script方式安装,XEAjaxMock会定义为全局变量生产环境请使用xe-ajax-mock.min.js,更小的压缩版本,可以带来更快的速度体验。

    2. vue 使用 xe-ajax

      安装完成后自动挂载在vue实例this.$ajaxCDN安装使用script方式安装,VXEAjax会定义为全局变量生产环境请使用vxe-ajax.min.js,更小的压缩版本,可以带来更快的速度体验。cdnjs获取最新版本点击浏览已发布的所有npm包源码unpkg获取最新版本点击浏览已发布的所有npm包源码AMD安装require.js安装示例ES6Module安装通过Vue.use()来全局安装示例./Home.vue

    3. AJAX POST数据中文乱码解决

      前端使用encodeURI进行编码后台java.net.URLDecoder进行解码编解码工具

    4. Koa2框架利用CORS完成跨域ajax请求

      实现跨域ajax请求的方式有很多,其中一个是利用CORS,而这个方法关键是在服务器端进行配置。本文仅对能够完成正常跨域ajax响应的,最基本的配置进行说明。这样OPTIONS请求就能够通过了。至此为止,相当于仅仅完成了预检,还没发送真正的请求呢。

    5. form提交时,ajax上传文件并更新到&lt;input&gt;中的value字段

    6. ajax的cache作用

      filePath="+escape;},error:{alert;}});解决方案:1.加cache:false2.url加随机数正常代码:网上高人解读:cache的作用就是第一次请求完毕之后,如果再次去请求,可以直接从缓存里面读取而不是再到服务器端读取。

    7. 浅谈ajax上传文件属性contentType = false

      默认值为contentType="application/x-www-form-urlencoded".在默认情况下,内容编码类型满足大多数情况。在这里,我们主要谈谈contentType=false.在使用ajax上传文件时:在其中先封装了一个formData对象,然后使用post方法将文件传给服务器。说到这,我们发现在JQueryajax()方法中我们使contentType=false,这不是冲突了吗?这就是因为当我们在form标签中设置了enctype=“multipart/form-data”,

    8. 909422229_ajaxFileUpload上传文件

      ajaxFileUpload.js很多同名的,因为做出来一个很容易。我上github搜AjaxFileUpload出来很多类似js。ajaxFileUpload是一个异步上传文件的jQuery插件传一个不知道什么版本的上来,以后不用到处找了。语法:$.ajaxFileUploadoptions参数说明:1、url上传处理程序地址。2,fileElementId需要上传的文件域的ID,即的ID。3,secureuri是否启用安全提交,默认为false。4,dataType服务器返回的数据类型。6,error

    9. AJAX-Cache:一款好用的Ajax缓存插件

      原文链接AJAX-Cache是什么Ajax是前端开发必不可少的数据获取手段,在频繁的异步请求业务中,我们往往需要利用“缓存”提升界面响应速度,减少网络资源占用。AJAX-Cache是一款jQuery缓存插件,可以为$.ajax()方法扩展缓存功能。

    10. jsf – Ajax update/render在已渲染属性的组件上不起作用

      我试图ajax更新一个有条件渲染的组件。我可以确保#{user}实际上是可用的。这是怎么引起的,我该如何解决呢?必须始终在ajax可以重新呈现之前呈现组件。Ajax正在使用JavaScriptdocument.getElementById()来查找需要更新的组件。但是如果JSF没有将组件放在第一位,那么JavaScript找不到要更新的内容。解决方案是简单地引用总是渲染的父组件。

    返回
    顶部