关于Request

       在编写web应用时,通常会使用表单提交数据至后台,那么就涉及request请求,下面来简单介绍request请求

       首先表单在申明的时候,其默认的编码格式是:enctype=application/x-www-form-urlencoded 

       1.当表单是默认提交方式enctype=application/x-www-form-urlencoded,我们debug看其请求详情:

       

      Servlet的API提供了对这种编码方式解码的支持,只需要在提交到Controller时,通过HttpServletRequest类中的getParameter()方法获取表单信息即可

    2.在传输大数据量的二进制数据时,必须将编码方式设置成enctype="multipart/form-data",当以这种方式提交数据时,HTTP报文中的内容是:


     如果以这种方式提交数据就要用request.getInputStream()或request.getReader()来获取提交的数据 ,用 request.getParameter()是获取不到提交的数据的

    3.通过Ajax来提交表单时,我们自己设置了Content-Type:application/json; charset=utf-8时,那么情况又是什么样的呢?

    Ajax提交信息:

  

     此时我们发现了X-Requested-With这个属性可以区分前端的提交方式;这是通过request.

    总结:      

      当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()在同一个响应中是不能混合使用的,如果混合使用会抛异常的。

      

       当form表单内容采用ajax的提交方式Content-Type:application/json;charset=UTF-8时,我们已经request.getParameterMap()获取不到任何信息了


        ------未完待续

    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值