Spring标签及使用知识

@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 类加载的方式,加载最新的类到虚拟机中,这样就不需要重新启动也能看到修改后的效果了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值