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 的类

当然也相当于在启动类上加了

  1. @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;
    }

}