SpringMVC注解@RequestParam全面解析

在SpringMVC后台控制层获取参数的方式主要有两种,[color=blue][b]一种是request.getParameter("name"),另外一种是用注解@RequestParam[/b][/color]直接获取。这里主要讲这个注解

[color=blue][b]一、基本使用,获取提交的参数 [/b][/color]
[size=medium][color=black][b]后端代码: [/b][/color][/size]

@RequestMapping(value = "/item/{configId}", method = RequestMethod.PUT)
@ResponseBody
public JsonObjectBase updateItem(@PathVariable long configId, @RequestParam(value = "value") String value) {

// 业务校验
configValidator.validateUpdateItem(configId, value);

LOG.info("start to update config: " + configId);

//
// 更新, 并写入数据库
//
String emailNotification = "";
emailNotification = configMgr.updateItemValue(configId, value);

//
// 通知ZK
//
configMgr.notifyZookeeper(configId);

return buildSuccess(emailNotification);
}


[size=medium][color=black][b]前端代码: [/b][/color][/size]

// 提交
$("#submit").on("click", function (e) {
$("#error").addClass("hide");
var me = this;
var value = $("#value").val();
// 验证
if (!value) {
$("#error").removeClass("hide");
$("#error").html("表单不能为空或填写格式错误!");
return;
}
$.ajax({
type: "PUT",
url: "/api/web/config/item/" + configId,
data: {
"value": value
}
}).done(function (data) {
$("#error").removeClass("hide");
if (data.success === "true") {
$("#error").html(data.result);
} else {
Util.input.whiteError($("#error"), data);
}
});
});


可以看到spring会自动根据参数名字封装进入,我们可以直接拿这个参数名来用

二、各种异常情况处理
[color=black][b]1、可以对传入参数指定参数名 [/b][/color]
public JsonObjectBase updateItem(@PathVariable long configId, 
// 下面的对传入参数指定为value,如果前端不传value参数名,会报错
@RequestParam(value = "value") String value)


[color=black][b]错误信息:
HTTP Status 400 - Required String parameter 'value' is not present [/b][/color]

[color=black][b]2、可以通过required=false或者true来要求@RequestParam配置的前端参数是否一定要传 [/b][/color]
// required=false表示不传的话,会给参数赋值为null,required=true就是必须要有  
public JsonObjectBase updateItem(@PathVariable long configId, @RequestParam(value = "myValue", required = true) String value)


[color=black][b]3、如果用@RequestMapping注解的参数是int基本类型,但是required=false,这时如果不传参数值会报错,因为不传值,会赋值为null给int,这个不可以 [/b][/color]

参考:http://825635381.iteye.com/blog/2196911
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值