java参数action_Spring MVC之Action输入参数

第一部分:Action输入参数

Spring MVC 通过@RequestMapping注解映射请求,最终的真正执行代码为处理器方法,即@RequestMapping注解的方法。Spring MVC方法可以接受的参数包含:

1.1)基本数据类型,如int,String,double...

1.2)自定义数据类型,如自定义的pojo对象

1.3)Servlet API中的Request和Response。如:ServletRequest或HttpServletRequest。

1.4)Session对象。如:HttpSession。注意此对象不是线程安全的,可设置RequestMappingHandlerAdapter的 “synchronizeOnSession”属性为true来同步。

1.5)org.springframework.web.context.request.WebRequest或org.springframework.web.context.request.NativeWebRequest。

1.6)java.util.Locale对象。需要在Servlet环境中配置 LocaleResolver。

1.7)java.io.InputStream / java.io.Reader用于访问请求输入流。

1.8)java.io.OutputStream / java.io.Writer用于生成的输出流。

1.9)java.security.Principal用于保存当前的认证用户。

1.10)@PathVariable注解的参数。

1.11)@MatrixVariable注解的参数。

1.12)@RequestParam注解的请求参数。

1.13)@RequestHeader注解的请求头参数。

1.14)@RequestBody注解的请求体参数。

1.15)@RequestPart注解的上传文件请求体参数。请求类型为”multipart/form-data”。

1.16)HttpEntity>:请求实体对象,可以访问头信息和内容体。

1.17)java.util.Map / org.springframework.ui.Model / org.springframework.ui.ModelMap:用于响应模型类,存储响应数据。

1.18)org.springframework.web.servlet.mvc.support.RedirectAttributes:用于在redirect的重定向中传递数据。

1.19)命令或 表单对象。

1.20)org.springframework.validation.Errors / org.springframework.validation.BindingResult对象。

1.21)org.springframework.web.bind.support.SessionStatus可以用来控制Session的清理。

1.22)org.springframework.web.util.UriComponentsBuilder可以用来查询当前请求的主机名、端口号、Schema、Context Path、Servlet Mapping信息。

1、基本数据类型

方法的参数可以是任意基本数据类型,如果方法参数名与http中请求的参数名称相同时会进行自动映射。

public String index(Model model, int id, String name) {

}

2、自定义数据类型

Spring MVC会通过反射把请求中的参数设置到自定义类型的对象中。

public String index(Model model, Member member) {

}

3、集合类型

Spring MVC中不能直接在方法的参数中使用集合类型(List 和 Map),必须使用集合类型的包装类。

//人员集合

public class MemberList {

private List items;

public List getItems() {

return items;

}

public void setItems(List items) {

this.items = items;

}

}

然后使用

public String index(Model model, MemberList members) {

}

4、使用@RequestParam注解的请求参数。

@RequestMapping(value="/index.do")

public String index(@RequestParam(value="code", required=true) String code,@RequestParam(value="pwd", required=true) String pwd, ModelMap model) {

Member member = authService.validate(code,pwd);

model.addAttribute("member", member);

return "index";

}

使用 @RequestParam 可以处理一些细节逻辑,如默认值、是否必须、别名等。

5、使用@RequestBody注解的请求体参数。

@RequestMapping(value="/index.do", method = RequestMethod.PUT)

public void index(@RequestBody String body, Writer writer) throws IOException {

writer.write(body);

}

由HttpMessageConverter来转换body至对象。它可以被转换成支持的任意类型。 RequestMappingHandlerAdapter 默认的支持有:

5.1)ByteArrayHttpMessageConverter :byte[]转换。

5.2)StringHttpMessageConverter :转换成String。

5.3)FormHttpMessageConverter :转换成MultiValueMap。

5.4)SourceHttpMessageConverter :转换成javax.xml.transform.Source。

转换的参数还可以加上@Valid注解,以进行转换校验,如果校验失败将抛出MethodArgumentNotValidException,此异常默认情况由 DefaultHandlerExceptionResolver进行管理,将会向客户端发送400错误码。

6、使用HttpEntity>

@RequestMapping(value="/index.do")

public ResponseEntity index(HttpEntity requestEntity) throws Exception {

String requestHeader = requestEntity.getHeaders().getFirst("MyRequestHeader");

byte[] requestBody = requestEntity.getBody();

HttpHeaders responseHeaders = new HttpHeaders();

responseHeaders.set("MyResponseHeader", "MyValue");

return new ResponseEntity("Hello World", responseHeaders, HttpStatus.CREATED);

}

7、使用@ModelAttribute

@ModelAttribute使用在方法上,就相当于一个公共model池一样(前提是在同一个Controller中),在同一个Controller中,所有@RequestMapping注解的方法执行前,都要先执行这些由@ModelAtrribute注解的方法,将数据存入到当前请求的Model中。它可以单个添加属性,也可以批量地添加。

@ModelAttribute

public void bindModel(@RequestParam String code,@RequestParam String pwd, Model model){

model.addAttribute(authService.validate(code,pwd));

}

@ModelAttribute使用在方法参数上,被注解的参数会先从请求的Model中查找,如果未找到,则会实例化一个新对象,放入请求的Model中。

查找路径:

存在于@SessionAttributes中。

存在于同一个Controller中的注解于方法级别上的@ModelAttribute中。

Url的模式匹配和转换中。

@RequestMapping(value="/member/{member}", method = RequestMethod.PUT)

public void bind(@ModelAttribute("member") Member member){

}

8、使用@SessionAttributes

在Controller类上使用此注解,会从请求的model中查找@SessionAttributes指定的属性名或属性类型,将它们保存到Session中。

/**

* @功能 权限控制器

* @作者 Davee.Yuan

* @日期 2017-01-16

* @说明 http://localhost:8080/auth/index

*/

@Controller

@RequestMapping("/sso")

@SessionAttributes("member")

public class SsoController{

}

9、使用@RedirectAttributes

方法的签名中指定一个RedirectAttributes 类型的参数,用于在请求返回 RedirectView时传递数据。

@RequestMapping(value="/redirect.do")

public String redirect(RedirectAttributes attr){

attr.addAttribute("status",9999);

return "redirect:/toLogin";

}

10、使用@CookieValue

@RequestMapping(value="/display.do")

public String display(@CookieValue("JSESSIONID") String cookie){

//---------------------

return "";

}

第二部分:类型转换

Spring MVC控制器接收到的原始请求数据都是文本类型,而先前使用的@RequestParam、@CookieValue等注解的参数可以为String类型,也可以是其它,Spring默认支持一些简单的数据类型如int、long、Date等类型的自动转换,如果需要对自定义的类型或复杂类型进行转换的话,需要自定义转换器绑定。绑定的方式有两种:局部绑定、全局绑定(它还有两种实现形式):

局部绑定:在@Controller中使用@InitBinder注解方法进行转换器的绑定,用它绑定的方法返回类型应设置成void,方法参数WebDataBinder集合了WebRequest和java.util.Locale,它可以将转换器绑定至Context中:

@InitBinder

public void initBinder(WebDataBinder binder) {

SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");

dateFormat.setLenient(false);

binder.registerCustomEditor(Date.class, new CustomDateEditor(dateFormat, false));

}

全局绑定:一种方式是实现一个WebBindingInitializer 接口类,将它绑定至全局配置中,如实现类ClinicBindingInitializer:

全局绑定:另一种方式是使用@InitBinder注解于@ControllerAdvice注解的类中,来实现全局绑定

内容主要来自于:https://blog.zenfery.cc/archives/131.html?replytocom=14

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值