一个通过request.getParameterMap方法获取不到请求参数的问题

  今天在前后端联调开发过程中,出现了一个后端通过request.getParameterMap()方法获取不到请求参数的问题,所以在此做一个记录,并提出解决方案。

  首先,出现问题是因为数据格式为Request Payload,是在react使用axios进行ajax请求的时候出现的js获取请求头信息,原来,axios中默认请求头的编码为application/json;charset=UTF-8,即Content-Type = "application/json;charset=UTF-8",这个时候可以通过数据流的读取进行参数解析,经测试,方法为通用方法,对于ajax请求适用,代码如下

  <pre class="has">`//将请求参数类型为request payload格式的请求参数封装成一个Map

  1. //该方法为通用方法
  2. public static Map requestPayload2Map(HttpServletRequest request){
  3. Map reqParams = new HashMap();
  4. StringBuilder sb = new StringBuilder();
  5. //从请求流中读取数据
  6. try( BufferedReader reader = request.getReader();)
  7. {
  8. char[] buffer = new char[1024];
  9. int len = 0;
  10. while((len = reader.read(buffer))!=-1){
  11. sb.append(buffer,0,len);
  12. }
  13. } catch (IOException e) {
  14. e.printStackTrace();
  15. }
  16. System.out.println("数据为:"+sb.toString());
  17. JSONObject object = JSONObject.fromObject(sb.toString());
  18. for (Object key :object.keySet()) {
  19. reqParams.put((String)key,(String)object.get(key));
  20. }
  21. return reqParams;
  22. }`</pre>

  但是,再后来,通过如下编码对Content-Type进行设置

  <pre class="has">` axios({

  1. url:url,
  2. data:{
  3. userName:username,
  4. password:password
  5. },
  6. method:&#39;post&#39;,
  7. headers:{&#39;Content-Type&#39;:&#39;application/x-www-form-urlencoded&#39;}
  8. })
  9. .then(response=>{
  10. const result = response.data
  11. console.log(result)
  12. }).catch(error=>{
  13. console.log(error)
  14. })`</pre>

  这里,我们修改了Content-Type的值,application/x-www-form-urlencoded是窗体数据被编码为名称/值对。这是标准的编码格式我们就有一个疑问,为什么我们的那个方法依然失效呢,经过多种方式测试,发现,我们要使用的方法如果在后台的得到的数据格式为XX1=XXX1&XX2=XXX2js获取请求头信息,那么我们就可以使用成功了,即通过表单的action方式

  当使用表单的action提交的时候,如果设置了属性encType = "multipart/form-data",那么后台获取到的数据格式为:

  <pre class="has">`数据为:------WebKitFormBoundaryN4vBMLIkQoIBjLqe
Content-Disposition: form-data; name="usename"
liming
------WebKitFormBoundaryN4vBMLIkQoIBjLqe
Content-Disposition: form-data; name="password"
123456
------WebKitFormBoundaryN4vBMLIkQoIBjLqe--
`</pre>

  此时的Content-Type为Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryN4vBMLIkQoIBjLqe,所以建议在使用ajax的时候,最好使用通用方法进行参数获取,以便少走弯路。。。

文章由官网发布,如若转载,请注明出处:https://www.veimoz.com/1312
0 评论
1.5k

发表评论

!