前言

用过spring的人都知道,spring简单的通过注解就可以完成很多事情,但这些东西是如何实现的呢以及如何应用到我们自己的代码中?接下来,让我们一起开启注解的旅程。

1. @Controller

标识一个该类是Spring MVC controller处理器,用来创建处理http请求的对象.

@Controller
public class TestController {
@RequestMapping("/test")
public String test(Map<String,Object> map){ return "hello";
}
}

2. @Component、@Repository、@Service、@Controller作用等价相同的

区别:如果 Web 应用程序采用了经典的三层分层结构的话,最好在持久层、业务层和控制层分别采用 @Repository、@Service 和 @Controller 对分层中的类进行注释,而用 @Component 对那些比较中立的类进行注释。

用来装配bean,主要用于标注业务层组件,通过注解的方式将该类加入到spring 中进行管理。

@Service
public interface UserService {
User login(String username,String password);
}
//当把注解写在接口上时,spring容器会注入失败。 //注解写在类上 注入不会失败。
@Service
public class UserServiceImpl implements UserService{
@Autowired
private UserMapper userMapper;
} @Controller
@RequestMapping("user")
public class UserController { @Autowired
private UserService userService
}

3. @Autowired

用来装配bean,可以写在字段上,也可以写在方法上。

默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,例如:@Autowired(required=false)

4. @RequestMapping

类定义处:提供初步的请求映射信息,相对于 WEB 应用的根目录。

方法处:提供进一步的细分映射信息,相对于类定义处的 URL。

说白了,就是例如(“user”)网站上访问localhost:8080/user.html就可以访问这个方法和html页面。

5. @RequestParam

用于将请求参数区数据映射到功能处理方法的参数上

例如:

public Resp test(@RequestParam Integer id){
return Resp.success(customerInfoService.fetch(id));
}

这个id就是要接收从接口传递过来的参数id的值的,如果接口传递过来的参数名和你接收的不一致,也可以如下:

public Resp test(@RequestParam(value="userId") Integer id){
return Resp.success(customerInfoService.fetch(id));
}

其中userId就是接口传递的参数,id就是映射userId的参数名。

6. @ModelAttribute

使用地方有三种:

  1. 标记在方法上。

标记在方法上,会在每一个@RequestMapping标注的方法前执行,如果有返回值,则自动>将该返回值加入到ModelMap中。

A.在有返回的方法上:

当ModelAttribute设置了value,方法返回的值会以这个value为key,以参数接受到的值作为value,存入到Model中,如下面的方法执行之后,最终相当于 model.addAttribute(“user_name”, name);假如 @ModelAttribute没有自定义value,则相当于

model.addAttribute(“name”, name);

1@ModelAttribute(value="user_name")
2 public String before2(@RequestParam(required = false) String name, Model model) {
3 System.out.println("进入了2:" + name);
4 return name;
5 }

B.在没返回的方法上:

需要手动model.add方法

1    @ModelAttribute
2 public void before(@RequestParam(required = false) Integer age, Model model) {
3 model.addAttribute("age", age);
4 System.out.println("进入了1:" + age);
5 }

我们在当前类下建一个请求方法:

 1@RequestMapping(value="/mod")
2 public Resp mod(
3 @RequestParam(required = false) String name,
4 @RequestParam(required = false) Integer age,
5 Model model){
6 System.out.println("进入mod");
7 System.out.println("参数接受的数值{name="+name+";age="+age+"}");
8 System.out.println("model传过来的值:"+model);
9 return Resp.success("1");
10 }

在浏览器中输入访问地址并且加上参数:

http://localhost:8081/api/test/mod?name=我是小菜&age=12

最终输出如下:

1进入了1:40
2进入了2:我是小菜
3进入mod
4参数接受的数值{name=我是小菜;age=12}
5model传过来的值:{age=40, user_name=我是小菜}
  1. 标记在方法的参数上。

标记在方法的参数上,会将客户端传递过来的参数按名称注入到指定对象中,并且会将这个对象自动加入ModelMap中,便于View层使用.

我们在上面的类中加入一个方法如下

 1@RequestMapping(value="/mod2")
2 public Resp mod2(@ModelAttribute("user_name") String user_name,
3 @ModelAttribute("name") String name,
4 @ModelAttribute("age") Integer age,Model model){
5 System.out.println("进入mod2");
6 System.out.println("user_name:"+user_name);
7 System.out.println("name:"+name);
8 System.out.println("age:"+age);
9 System.out.println("model:"+model);
10 return Resp.success("1");
11 }

在浏览器中输入访问地址并且加上参数:

http://localhost:8081/api/test/mod2?name=我是小菜&age=12

最终输出:

1进入了1:40
2进入了2:我是小菜
3进入mod2
4user_name:我是小菜
5name:我是小菜
6age:40
7model:{user_name=我是小菜,

org.springframework.validation.BindingResult.user_name=org.springframework.validation.BeanPropertyBindingResult: 0 errors, name=我是小菜, org.springframework.validation.BindingResult.name=org.springframework.validation.BeanPropertyBindingResult: 0 errors, age=40, org.springframework.validation.BindingResult.age=org.springframework.validation.BeanPropertyBindingResult: 0 errors}

从结果就能看出,用在方法参数中的@ModelAttribute注解,实际上是一种接受参数并且自动放入Model对象中,便于使用。

7. @Cacheable

用来标记缓存查询。可用用于方法或者类中,

当标记在一个方法上时表示该方法是支持缓存的,

当标记在一个类上时则表示该类所有的方法都是支持缓存的。

参数列表

@Cacheable(value="UserCache")// 使用了一个缓存名叫 accountCache
public Account getUserAge(int id) {
//这里不用写缓存的逻辑,直接按正常业务逻辑走即可,
//缓存通过切面自动切入
int age=getUser(id);
return age;
}

8. @CacheEvict

用来标记要清空缓存的方法,当这个方法被调用后,即会清空缓存。 @CacheEvict(value=”UserCache”)

参数列表

9. @Resource

@Resource的作用相当于@Autowired

只不过@Autowired按byType自动注入,

而@Resource默认按 byName自动注入罢了。

@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。

@Resource装配顺序:

如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常

如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常

如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常

如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;

10. @PostConstruct

用来标记是在项目启动的时候执行这个方法。用来修饰一个非静态的void()方法也就是spring容器启动时就执行,多用于一些全局配置、数据字典之类的加载

被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器执行一次。PostConstruct在构造函数之后执行,init()方法之前执行。PreDestroy()方法在destroy()方法执行执行之后执

11. @PreDestroy

被@PreDestroy修饰的方法会在服务器卸载Servlet的时候运行,并且只会被服务器调用一次,类似于Servlet的destroy()方法。被@PreDestroy修饰的方法会在destroy()方法之后运行,在Servlet被彻底卸载之前

12.@Repository

用于标注数据访问组件,即DAO组件

13.@Component

泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注

14.@Scope

用来配置 spring bean 的作用域,它标识 bean 的作用域。

默认值是单例

**singleton:单例模式,全局有且仅有一个实例

prototype:原型模式,每次获取Bean的时候会有一个新的实例

request:request表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP request内有效

session:session作用域表示该针对每一次HTTP请求都会产生一个新的bean,同时该bean仅在当前HTTP session内有效

global session:只在portal应用中有用,给每一个 global http session 新建一个Bean实例。**

15. @SessionAttributes

默认情况下Spring MVC将模型中的数据存储到request域中。当一个请求结束后,数据就失效了。如果要跨页面使用。那么需要使用到session。而@SessionAttributes注解就可以使得模型中的数据存储一份到session域中

参数:

names:这是一个字符串数组。里面应写需要存储到session中数据的名称。

types:根据指定参数的类型,将模型中对应类型的参数存储到session中

value:和names是一样的。

 @Controller
@SessionAttributes(value={"names"},types={Integer.class})
public class ScopeService {
@RequestMapping("/testSession")
public String test(Map<String,Object> map){
map.put("names", Arrays.asList("a","b","c"));
map.put("age", 12);
return "hello";
}
}

16. @Required

适用于bean属性setter方法,并表示受影响的bean属性必须在XML配置文件在配置时进行填充。否则,容器会抛出一个BeanInitializationException异常。

17. @Qualifier

当你创建多个具有相同类型的 bean 时,并且想要用一个属性只为它们其中的一个进行装配,在这种情况下,你可以使用 @Qualifier 注释和 @Autowired 注释通过指定哪一个真正的 bean 将会被装配来消除混乱。

18.@PathVariable

@PathVariable可以用来映射URL中的占位符到目标方法的参数中

@RequestMapping("/testPathVariable/{id}")
public String testPathVariable(@PathVariable("id") Integer id){
System.out.println("testPathVariable:"+id);
return SUCCESS;
}

最后解释一下ajax相关注解:

Ajax相关注解

1.@RestController:定义的控制器所有方法默认返回的都是 @ResponseBody

的方法, 都会将返回值转换为JSON。注意:@RestController=@Controller+@ResponseBody

2.@ResponseBody:设置了 @ResponseBody 以后如果控制器方法返回了Java Bean 对象

则这个JavaBean会被转换为 JSON 对象, 放到响应的正文中发送浏览器

而且响应的 ContentType是 application/json, 表示JSON类型数据

3.@GetMapping:专门处理get类型请求

4.@PostMapping:专门处理post类型请求

注:@GetMapping("/get_test") 和 @RequestMapping(value = “/get_test”,method = RequestMethod.GET)等价的就是为了简化 RequestMapper 专门用于处理Get请求

图解:

19.@Data

类名前面添加@Data注解,lombok(插件,可以节省实体类代码)会在类的编译期间为类添加getter,setter,toString方法。添加全属性笔记equals、hashCode方法。(说白了就是节省实体类的代码,不用再写get、set。。。。。等方法)

测试之后,lombok确实自动生成了以上的一些方法。

最后

感谢你看到这里,看完有什么的不懂的可以在评论区问我,觉得文章对你有帮助的话记得给我点个赞,每天都会分享java相关技术文章或行业资讯,欢迎大家关注和转发文章!

最新文章

  1. 阿里weex学习入门必备
  2. 在ubuntu上安装nodejs[开启实时web时代]
  3. kill
  4. 转:python webdriver API 之下载文件
  5. 为什么web标准中无法设置IE浏览器滚动条颜色了?
  6. MVC开发Markdown编辑器(1)
  7. hmmer 使用(转载)
  8. HDU 5705 Clock (精度控制,暴力)
  9. 缺少编译器要求的成员“System.Runtime.CompilerServices.ExtensionAttribute..ctor” 解决方案
  10. rtsp的东西
  11. android EditText中的inputType
  12. Java层与Jni层的数组传递(转)
  13. [知了堂学习笔记]_用JS制作《飞机大作战》游戏_第4讲(创建敌方飞机、敌方飞机发射子弹、玩家子弹击中敌方小飞机,小飞机死亡)
  14. hive常用操作
  15. mpvue——Error: EPERM: operation not permitted
  16. poj3280
  17. Java:内省(Introspector)
  18. C++ Tips
  19. php5.6.40编译安装
  20. 前端学习 -- Html&amp;Css -- 相对定位 绝对定位 固定定位

热门文章

  1. 用python写一个豆瓣短评通用爬虫(登录、爬取、可视化)
  2. frida框架hook常用字符串模板总结
  3. 今天 1024,为了不 996,Lombok 用起来以及避坑指南
  4. 12 个设计 API 的安全建议,不要等出事儿了“捶胸顿足”
  5. RxJava用法
  6. 印度最大在线食品杂货公司Grofers的数据湖建设之路
  7. scrapy爬取豆瓣电影信息
  8. D. Maximum Distributed Tree 解析(思維、DFS、組合、貪心、DP)
  9. Mybatis---02Mybatis执行过程分析
  10. leo101