SpringBoot入门教程(三):SpringBoot 常用注解
一、基本介绍
@SpringBootApplication:
包含@Configuration、@EnableAutoConfiguration、@ComponentScan
@Repository:
用于标注数据访问组件,即DAO组件。
@Service:
用于标注业务层组件。
@Controller:
用于标注控制器组件
@RestController:
用于标注控制层组件,包含@Controller和@ResponseBody。
@ResponseBody:
表示该方法的返回结果直接写入HTTP response body中
一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径,加上@responsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如异步获取json数据,加上@responsebody后,会直接返回json数据。
@Component:
泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
@ComponentScan:
组件扫描。个人理解相当于<context:component-scan>,如果扫描到有@Component @Controller @Service等这些注解的类,则把这些类注册为bean。
@Configuration:
指出该类是 Bean 配置的信息源,相当于XML中的<beans></beans>,一般加在主类上。
@Bean:
相当于XML中的<bean></bean>,放在方法的上面,而不是类,意思是产生一个bean,并交给spring管理。
@EnableAutoConfiguration:
让 Spring Boot 根据应用所声明的依赖来对 Spring 框架进行自动配置,一般加在主类上。
@AutoWired:
byType方式。把配置好的Bean拿来用,完成属性、方法的组装,它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。
当加上(required=false)时,就算找不到bean也不报错。
@Qualifier:
当有多个同一类型的Bean时,可以用@Qualifier("name")来指定。与@Autowired配合使用
@Resource(name="name",type="type"):
没有括号内内容的话,默认byName。与@Autowired干类似的事。
@RequestMapping:
RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
该注解有六个属性:
params:指定request中必须包含某些参数值是,才让该方法处理。
headers:指定request中必须包含某些指定的header值,才能让该方法处理请求。
value:指定请求的实际地址,指定的地址可以是URI Template 模式
method:指定请求的method类型, GET、POST、PUT、DELETE等
consumes:指定处理请求的提交内容类型(Content-Type),如application/json,text/html;
produces:指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回
@RequestParam:
用在方法的参数前面。
@RequestParam String a =request.getParameter("a")。
下面将对上面常用注解进行介绍
二、举例介绍
1、@ComponentScan
SpringBoot 默认是扫描启动类所在包下的所有含有 @Component、@Repository、@Service、@Controller 的类
当然也相当于在启动类上加了
- @ComponentScan(basePackages = {"com.liuyanzhao.demo"})
2、@Component、@Repository、@Service、@Controller
为了控制反转(将创建对象的控制权交给Spring容器),而不需要去 new,而且创建的对象还是单例的,一举多得。
这几个注解作用是通用的,几乎一样,通常我们根据它的含义来写
注解 | 含义 |
@Component | 最普通的组件,可以被注入到spring容器进行管理 |
@Repository | 作用于持久层 |
@Service | 作用于业务逻辑层 |
@Controller | 作用于表现层(spring-mvc的注解) |
注意:这些注解都是写在类上面的,不可以写在接口上,默认是创建类名首字母小写的 Bean
3、@AutoWired 和 @Resource
这两个注解都是注入依赖的作用
比如在 UserController 里注入 UserService,在 UserService 注入 UserDao
通常用法如下
UserServiceImpl 类
@Service
//相当于 @Service(value = "userServiceImpl")
public class UserServiceImpl implements UserService{
@Override
public String sayHi() {
return "Hi!";
}
}
利用@Service注解自动将类 UserServiceImpl 注解为bean,id为 userServiceImpl,即类 UserServiceImpl 第一个字母小写的id。
@Authwired 使用
//方法一、寻找可以扫描到的实现了 UserService 接口的类
@Autowired
private UserService userService;
//方法二、如果有多个类实现了 UserService,需要指定时哪个实现类
@Autowired
@Qualifier("userServiceImpl")
private UserService userService;
@Resource 使用
//方法三、寻找可以扫描到的实现了 UserService 接口的类
@Resource
private UserService userService;
//方法四、如果有多个类实现了 UserService,需要指定时哪个实现类
@Resource(name = "userServiceImpl")
private UserService userService;
区别
1)利用@Service注解自动将类 UserServiceImpl 注解为bean,id为 userServiceImpl,即类 UserServiceImpl 第一个字母小写的id。
2)@Resource按byName自动注入,@Autowired按byType自动注入;
3)@Resource可用@Autowired替换
4、@RequestMapping
该注解可以加在方法上,也可以加在类上;如下面例子,加在类上,表示该类所有的方法都加前缀 /user
下面两种方法都是映射到 /user/list
方法一、
@RestController
public class UserController {
@Autowired
private UserService userService;
@RequestMapping(value = "/user/list",method = RequestMethod.GET)
//相当于 @GetMapping("/user/list")
public List<User> userList() {
return userService.listUsers();
}
}
方法二、
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
@RequestMapping(value = "/list",method = RequestMethod.GET)
//相当于 @GetMapping("/list")
public List<User> userList() {
return userService.listUsers();
}
}
5、@RequestParam
@RequestParam 是修饰参数的,默认是必须传该参,也可以设置不是必须和未传参的默认值
/**
* URL例子:/user/list?page=1&size=10
* <p>
* 参数加了 @RequestParam("page")表示
* 1、默认该参数必选
* 2、参数名为page(而pageIndex只是形参,随便啥都可以)
* 3、可以设置参数是否必须,默认值
*
* @param pageIndex
* @param pageSize
* @return
*/
@GetMapping("/list")
public List<User> userList(@RequestParam("page") Integer pageIndex,
@RequestParam(value = "size", required = false, defaultValue = "10") Integer pageSize) {
System.out.println(pageIndex);
System.out.println(pageSize);
return userService.listUsers(pageIndex, pageSize);
}
6、@PathVariable
@PathVariable是绑定URL上的变量值的(注意是URL上的,不是参数)
/**
* /user/{id} 中花括号里的 id 和 @PathVariable("id") 中的id匹配
* @param id
* @return
*/
@GetMapping("/user/{id}")
public User getUser(@PathVariable("id") Integer id) {
return userService.getUserById(id);
}
7、@Controller 和 @RestController
使用 @Controller,视图解析器可以在 return 的 jsp 或 html 页面上渲染内容,然后返回给对应的 URL
假如我们使用 Thymeleaf 作为模板引擎,我们最好在配置文件 application.properties 里添加如下代码
spring.thymeleaf.prefix=classpath:/templates/
spring.thymeleaf.suffix=.html
这样设置,可以让我们在 controller 设置映射的模板页面的路径减少一点,就是避免以下不必要的公共的部分
(1)@Controller (返回渲染后的 HTML 页面)
然后我们的 controller 可以这样
@Controller
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/user/list")
public ModelAndView userList() {
ModelAndView modelAndView = new ModelAndView();
List<User> userList = userService.listUsers();
modelAndView.addObject("userList",userList);
//表示渲染在 templates/user/list.html
modelAndView.setViewName("user/list");
return modelAndView;
}
}
使用 ModelAndView 需要传入 model 和 view,可以通过构造器传入,也可以直接通过 Getter/Setter传入。
当然,其实也可以直接返回 String 类型,像这样
@Controller
public class UserController {
@Autowired
private UserService userService;
@GetMapping("/user/list")
public String userList(Model model) {
List<User> userList = userService.listUsers();
model.addAttribute("userList", userList);
return "user/list";//表示渲染在 templates/user/list.html
}
}
是不是优雅点。
(2)@Controller + @ResponseBody (直接返回字符串/JSON字符串)
返回String类型的话,直接返回原字符;返回对象的话,会返回 JSON 格式
@Controller
public class UserController {
@GetMapping("/user/list")
@ResponseBody
public User userList() {
User user = new User();
user.setId(001);
user.setAge(19);
user.setName("张三");
return user;
}
}
在浏览器访问 localhost:8080/user/list
使用 Chrome 浏览器,建议安装一个插件 JSON Viewer,可以在浏览器格式化 JSON 字符串,显示更有结构
(3)@RestController
效果和(2)是一模一样的,都是返回字符串
@RestController
public class UserController {
@GetMapping("/user/list")
public User userList() {
User user = new User();
user.setId(001);
user.setAge(19);
user.setName("张三");
return user;
}
}