示例代码:
@Controller
@RequestMapping("/params")
public class ParamsController{
@RequestMapping("/testParam")
public String testParam(@RequestParam(value ="username") String aaa, String password){
System.out.println(aaa);
System.out.println(password);
return "success";
}
@RequestMapping("/testListOrMapBeanParam")
public String testListOrMapBeanParam(AccountIncludeList accountIncludeList,@RequestBody String body,@RequestHeader String header){
System.out.println(accountIncludeList);
System.out.println(body);
System.out.println(header);
return "success";
}
@RequestMapping("/testProtoParam")
public String testProtoParam(String username, String password, HttpServletRequest request, HttpServletResponse response){
System.out.println(username);
System.out.println(password);
System.out.println(request);
System.out.println(response);
return "success";
}
}
/分割分割//
@Controller
@RequestMapping("/params")
public class ParamsControllerModelAttribute {
@RequestMapping(value = "/modelAttribute")
public String modelAttribute(User user){
System.out.println(user);
return "success";
}
@ModelAttribute
public void init(User user){
System.out.println(user);
//这里可以直接设置,因为用的是同一个user对象
//控制器拿到的会和这里的同步变化
user.setDate(new Date());
System.out.println("我在所有方法之前执行");
}
}
方法形参的使用:
String:
要用String类型的值,可以直接在方法中定义一个类型为String 名字和请求的key一样的变量,个别可以自动转换,例如String和int,date等。若不能自动转换,则需要自己配置。
JavaBean:
方法的形参是自定义javaBean时,其javaBean的属性名必须和请求的参数名对应(自动封装)。若javaBean中有list,前端可以在表单中写name[0].properties。Map可以写name[‘key’].properties。这里首先去request域中找名字相同的,有就直接用,没有再从request中解析。
HttpServletRequest && HttpServletResponse
可以在方法形参中写HttpServletRequest和HttpServletResponse来进行原始的servlet的操作。(JavaEE)
Model :
用这个可以向request域对象添加属性
model.addAttribute(“msg”,“啦啦啦”);
ModelMap :
用这个可以向session域对象获得值。
String msg=(String)modelMap.getAttribute(“msg”);
Annotation的使用:
@Controller {ElementType.TYPE}:
向spring注册一个控制器Bean。
@RequestMapping {ElementType.TYPE, ElementType.METHOD}:
声明页面的映射,可以在网页中通过对应的映射来访问对应的方法。
对应上图 /params/testParam
@RequestParam(value[,required]){ElementType.PARAMETER} :
使得传入的参数和将要使用的变量匹配,其中的required属性,默认true,代表必须存在其value指定的参数,否则返回错误。
@RequestBody(required default true){ElementType.PARAMETER}
获得请求体。
可以看作get请求 ?后的所有
例如: https://editor.csdn.net/md?not_checkout=1&asdfa=16516156
就是 not_checkout=1&asdfa=16516156
@RequestHeader(value){ElementType.PARAMETER}
获得请求头 value就获取名字为value的请求头。必须写value。
@CookieValue(value){ElementType.PARAMETER}
获得cookie 里的数据。必须写value。
@ModelAttribute{ElementType.PARAMETER, ElementType.METHOD}
在方法上时,表示该方法会在别的控制器方法执行之前执行。
该方法的作用是将一些变量保存到request域对象中。
当提交的JavaBean数据不完整时,可以进行一些补全操作。但不会修改已经设置的数据。
其用法可以和普通的控制器方法相同。
当中有一个隐晦的知识点------
会把其返回值和参数列表里的非基本类型(依据自己的javaBean和Map的推测)写入request域对象中!分类是依据其类名!不是变量名!也就是说,如果有返回值和参数列表其中一个类型相同,就会冲突,此时以参数列表中的为准,返回值无效。原因很简单,解析参数列表的时候就会抢先向request中写数据。之后获取返回值时域中已经有了数据,就会直接跳过。
用在参数上时,表示从request域对象中拿到一个值。
例如:@ModelAttribute(“one”) user(这里是从request域中拿一个名字为one的user对象,用JSON表示的,可以在@ModelAttribute修饰的方法中,将Map写入request域对象)。
@SessionAttributes{ElementType.TYPE}
用于向Session域写入数据,前提是要在request域中,可以用model.addAttribute()向request添加数据。