@PathVariable
是spring3.0的一个新功能:接收请求路径中占位符的值
@RequestMapping("show/{id}/{name}")
public ModelAndView test(@PathVariable("id") int ids, @PathVariable("name") String names){}
@PathVariable("")
是将 URL 中占位符处的值绑定到方法参数上
@RequestParam("")
是将 URL 后的请求参数绑定到方法参数上
public String test(@RequestParam(value = "userId", defaultValue = "0", required = false) int userId)
@RequestParam(required = false)
设置为非必传。因为required值默认是true,所以默认必传。
@RequestParam("userId")
或者@RequestParam(value = "userId")
指定参数名
@RequestParam(defaultValue = "0")
指定参数默认值
@RequestBody
和@ResponseBody:
@ResponseBody
的作用其实是将JAVA对象转为JSON格式的数据,并可以返回给JSP直接当对象使用(如果后端直接传对象获取不到)
@ResponseBody
表示该方法的返回结果直接写入 HTTP response body
中,一般在异步获取数据时使用【也就是AJAX】
也就是通过@ResponseBody
的作用后Object对象直接转成了json格式
@RequestBody
一般放在controller层的具体请求方法的入参中,用于读取Http请求的body部分数据——就是我们的请求数据。比如json或者xml。然后把数据绑定到 controller中方法的参数上。
使用时要注意能不能用@RequestBody
把request请求的数据解析,并赋给我们定义的参数上是由请求头的Content-Type
的值来决定的。
限制请求方法URL映射,GET,POST
@RequestMapping(value="/hello", method=RequestMethod.POST)
限制请求参数的URL 映射,
@RequestMapping(value="/user/show", params="userId")
请求参数中必须包含 userId
@RestController
注解相当于@ResponseBody
+ @Controller
合在一起的作用:
1):如果只是使用@RestController
注解Controller,则Controller中的方法无法返回JSP页面,配置的视图解析器InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。
2):如果需要返回到指定页面,则需要用 @Controller
配合视图解析器InternalResourceViewResolver才行.
3):如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody
注解。
SpringBoot
开启驼峰命名匹配规则:
mybatis.configuration.map-underscore-to-camel-case=true
缓存注解**@Cacheable**、@CacheEvict、@CachePut的使用:
@Cacheable("cache1")
value属性指当前方法的返回值是会被缓存在哪个Cache上的,对应Cache的名称
@Cacheable(value="users", key="#id")
@Cacheable(value="users", key="#user.id")
@Cacheable(value="users", key="#p0.id")
key属性是用来指定Spring缓存方法的返回结果时对应的key的。该属性支持SpringEL表达式
@Cacheable(value={"users"}, key="#user.id", condition="#user.id%2==0")
表示只有当user的id为偶数时才会进行缓存,当为true时表示进行缓存处理;当为false时表示不进行缓存处理
@CachePut("cache1")
//每次都会执行方法,并将结果存入指定的缓存中
在执行前不会去检查缓存中是否存在之前执行过的结果,而是每次都会执行该方法,并将执行结果以键值对的形式存入指定的缓存中
@CacheEvict
用来标注在需要清除缓存元素的方法或类上的;value表示清除操作是发生在哪些Cache上的(对应Cache的名称);key表示需要清除的是哪个key,如未指定则会使用默认策略生成的key;condition表示清除操作发生的条件
@CacheEvict(value="users", allEntries=true)
allEntries是boolean类型,表示是否需要清除缓存中的所有元素。默认为false,表示不需要;清除操作默认是在对应方法成功执行之后触发的,即方法如果因为抛出异常而未能成功返回时也不会触发清除操作
@CacheEvict(value="users", beforeInvocation=true)
beforeInvocation可以改变触发清除操作的时间,当我们指定该属性值为true时,Spring会在调用该方法之前清除缓存中的指定元素
@Caching(cacheable = @Cacheable("users"), evict = { @CacheEvict("cache2"),@CacheEvict(value = "cache3", allEntries = true) })
public User find (Integer id){}
@Caching
注解可以让我们在一个方法或者类上同时指定多个Spring Cache相关的注解。其拥有三个属性:cacheable、put和evict,分别用于指定@Cacheable、@CachePut和@CacheEvict。
@MyCacheable
使用自定义注解
Spring Boot热部署:
当发现任何类发生了改变,就会通过 JVM 类加载的方式,加载最新的类到虚拟机中,这样就不需要重新启动也能看到修改后的效果了