angularjs 与 springmvc 遇到的一些问题

使用angular的$http发送一个请求,data中存放请求数据,后台使用@requestParam获取不到。

使用postman测试后台api,发现把参数以url parameter形式发送@requestParam可以接收;以'application/x-www-form-urlencoded格式也可以接收;以application/json格式接收不到;其它方式也都接收不到。

于是查阅资料发现angularjs 中$http的contentType默认值是application/json;charset=UTF-8。

解决方案(2种)

springmvc中不使用@requestParam接收,改用@requestBody.但是这要求后面紧跟一个对象来接收参数。如果前台传的一些简单参数,根本不必要使用对象接收,那就显得多余。


另一种就是从前端解决,更改angularjs的$http的contentType为application/x-www-form-urlencoded,以及transformRequest,如下

$http({
                method : 'POST',
                url : 'api/delete',
                params : {
                  '_method' : 'DELETE'
                },
                data : {
                  'name' : 'time'
                },
                headers : {
                  'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
                },
                transformRequest : function(data) {
                  return $.param(data);
                }
              })

这样每个方法都要这么写,还可以进行全局的修改

var app = angular.module('myApp');


app.config(function ($httpProvider) {

   $httpProvider.defaults.transformRequest = function(data){

       if (data === undefined) {

           return data;

       }

       return $.param(data);

   }

  $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded; charset=UTF-8';

});

另外附上@requestParam以及@requestBody的使用场合

@RequestParam 

A) 常用来处理简单类型的绑定通过Request.getParameter() 获取的String可直接转换为简单类型的情况( String--> 简单类型的转换操作由ConversionService配置的转换器来完成);因为使用request.getParameter()方式获取参数,所以可以处理get 方式中queryString的值,也可以处理post方式中 body data的值

B)用来处理Content-Type: 为 application/x-www-form-urlencoded编码的内容,提交方式GET、POST;

C) 该注解有两个属性: value、required; value用来指定要传入值的id名称,required用来指示参数是否必须绑定;

如果用@RequestMapping注解的参数是int基本类型,但是required=false,这时如果不传参数值会报错,因为不传值,会赋值为null给int,这个不可以 .建议使用包装类型代替基本类型,如使用“Integer”代替“int”

@RequestBody

作用: 

      i) 该注解用于读取Request请求的body部分数据,使用系统默认配置的HttpMessageConverter进行解析,然后把相应的数据绑定到要返回的对象上;

      ii) 再把HttpMessageConverter返回的对象数据绑定到 controller中方法的参数上。

使用时机:

A) GET、POST方式提时, 根据request header Content-Type的值来判断:

  •     application/x-www-form-urlencoded, 可选(即非必须,因为这种情况的数据@RequestParam, @ModelAttribute也可以处理,当然@RequestBody也能处理);
  •     multipart/form-data, 不能处理(即使用@RequestBody不能处理这种格式的数据);
  •     其他格式, 必须(其他格式包括application/json, application/xml等。这些格式的数据,必须使用@RequestBody来处理);

B) PUT方式提交时, 根据request header Content-Type的值来判断:

  •     application/x-www-form-urlencoded, 必须;
  •     multipart/form-data, 不能处理;
  •     其他格式, 必须;
说明:request的body部分的数据编码格式由header部分的Content-Type指定;



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值