js中ajax常见的contentType,以及application/x-www-form-urlencoded传递List参数

4 篇文章 0 订阅
2 篇文章 0 订阅
$.ajax({
    type:"post",
    url:this.api.treeListUrl,
    dateType:"json",
     contentType : 'application/json',
    success:function(result){
    app.options=result.data;
    console.log(app.treeList);
},
error:function(result){
    }
});

 

1、application/x-www-form-urlencoded

浏览器参数截图:

参数要使用qs.stringify(params)转化为form表格格式,即Key-value。

后端接收参数时,不用加@RequestBody,controller接收可以单个参数接收,如@RequestParam("param") String param;也可以用类接收User user。

且可以完美解决后端springmvc框架中,使用@RequestBody时,就不能再接收单个参数的问题:

缺点:当后端接收List参数时,使用application/x-www-form-urlencoded格式后端无法接收,需要转换为application/json,且后端使用@RequestBody接收(因为测试了几种接收方式都不行)

 

2、application/json

浏览器参数截图:

注意:参数要经过JSON.stringify()转化为json格式

后端接收参数时,需要加@RequestBody

 

3、如果上传文件时使用:multipart/form-data

当action为post时候,浏览器把form数据封装到http body中,然后发送到server。 如果没有type=file的控件,用默认的application/x-www-form-urlencoded就可以了。 但是如果有type=file的话,就要用到multipart/form-data了。浏览器会把整个表单以控件为单位分割,并为每个部分加上Content-Disposition(form-data或者file),Content-Type(默认为text/plain),name(控件name)等信息,并加上分割符(boundary)。

注:

<form enctype="value">

enctype属性值:

描述
application/x-www-form-urlencoded在发送前对所有字符进行编码(默认)。
multipart/form-data不对字符编码。当使用有文件上传控件的表单时,该值是必需的。
text/plain将空格转换为 "+" 符号,但不编码特殊字符。



 

4、如果传递xml格式数据,使用:text/xml

<methodCall>

     <methodName>examples.getStateName</methodName>

    <params>

        <param>

            <value><i4>41</i4></value>

        </param>

    </params>

</methodCall>

 

原文:https://www.javaxxbj.com/personalHomePage.html?id=1605858357886&userId=1578999242684

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使Java接口同时支持application/json和application/x-www-form-urlencoded,可以通过以下步骤实现。 首先,将ajax发送请求的Content-Typeapplication/json改为application/x-www-form-urlencoded。这样浏览器会将form数据转换成一个字串,并将其附加到URL后面(对于GET请求),或者封装到HTTP body(对于POST请求)\[1\]。 其次,在Java的Controller的接口方法上,使用@RequestBody注解来接收application/json格式的数据\[2\]。这样,当请求的Content-Typeapplication/json时,后端可以正确地接收前端提交的JSON格式的数据。 另外,对于application/x-www-form-urlencoded格式的数据,Java的Controller方法可以直接接收表单数据,无需使用@RequestBody注解\[1\]。 通过以上步骤,Java接口就可以同时支持application/json和application/x-www-form-urlencoded两种数据格式了。这样,前端可以根据需要选择合适的数据格式进行请求。 #### 引用[.reference_title] - *1* [application/json与application/x-www-form-urlencoded详解](https://blog.csdn.net/weixin_42039228/article/details/124830035)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [application/x-www-form-urlencoded与application/json](https://blog.csdn.net/weixin_43543882/article/details/117248532)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值