
博主打算从0-1讲解下java进阶篇教学,今天教学第七篇:Spring中常用注解
在Java Spring框架中,注解(Annotation)是一种元数据,它提供了关于程序代码的额外信息,这些信息可以用于编译时检查、运行时处理或者在部署时生成配置文件。注解可以被应用在类、方法、字段等地方,用于提供额外的配置信息或者标记某些特性。下面我将介绍几个常用的Spring注解,并提供详细说明和代码示例。
目录
一、常用注解
1.@Component
2.@Autowired
3.@Controller
4.@Service
5.@Repository
6.@RequestMapping
7.@Configuration
8.@Bean
9.@Value
10.@Profile
11.@Qualifier
12.@Transactional
13.@Aspect
14.@ResponseBody
15.@RestController
16.@PathVariable
17.@RequestParam
18.@RequestBody
19.@GetMapping
20.@PostMapping
一、常用注解
1.@Component
@Component 是 Spring 框架中最常用的注解之一,它用于将一个 Java 类标识为 Spring 管理的组件,让 Spring 容器自动扫描并注册该组件。
@Component
public class MyComponent {
    // 类的具体实现
}
2.@Autowired
@Autowired 注解用于自动装配 Spring Bean,它可以在需要依赖注入的地方使用,让 Spring 框架自动将符合类型的 Bean 注入到对应的变量中。
@Component
public class MyComponent {
    private MyService myService;
    @Autowired
    public MyComponent(MyService myService) {
        this.myService = myService;
    }
    // 其他方法使用 myService
}
3.@Controller
@Controller 注解用于标识一个类是 Spring MVC 中的 Controller,它处理用户请求并返回相应的视图或数据。
@Controller
public class MyController {
    @GetMapping("/hello")
    public String hello() {
        return "hello";
    }
}
4.@Service
@Service 注解用于标识一个类是服务层组件,通常用于业务逻辑的处理。
@Service
public class MyService {
    public void doSomething() {
        // 业务逻辑处理
    }
}
5.@Repository
@Repository 注解用于标识一个类是数据访问层的组件,通常用于数据库操作。
@Repository
public class MyRepository {
    public void save(MyEntity entity) {
        // 数据库操作
    }
}
6.@RequestMapping
@RequestMapping 注解用于映射请求路径到具体的处理方法,可以用在 Controller 类或方法上。
@Controller
@RequestMapping("/api")
public class MyController {
    @GetMapping("/hello")
    public String hello() {
        return "hello";
    }
}
7.@Configuration
@Configuration 注解用于标识一个类是配置类,它通常和 @Bean 注解一起使用,用于配置 Spring 容器。
@Configuration
public class AppConfig {
    @Bean
    public MyService myService() {
        return new MyServiceImpl();
    }
}
8.@Bean
@Bean 注解用于在配置类中定义一个 Bean,Spring 容器会根据该方法返回的对象来注册 Bean。
@Configuration
public class AppConfig {
    @Bean
    public MyService myService() {
        return new MyServiceImpl();
    }
}
9.@Value
@Value 注解用于将配置文件中的值注入到变量中。
@Component
public class MyComponent {
    @Value("${my.property}")
    private String myProperty;
    // 其他方法使用 myProperty
}
10.@Profile
@Profile 注解用于指定在特定环境下才激活的 Bean。
@Configuration
@Profile("dev")
public class DevConfig {
    @Bean
    public MyService myService() {
        return new MyServiceImpl();
    }
}
11.@Qualifier
@Qualifier 注解用于指定注入的 Bean 的名称。
@Component
public class MyComponent {
    @Autowired
    @Qualifier("myService")
    private MyService myService;
    // 其他方法使用 myService
}
12.@Transactional
@Transactional 注解用于声明事务管理。
@Service
public class MyService {
    @Autowired
    private MyRepository myRepository;
    @Transactional
    public void saveEntity(MyEntity entity) {
        myRepository.save(entity);
    }
}
13.@Aspect
@Aspect 注解用于声明一个切面,用于定义横切关注点和通知类型(例如前置通知、后置通知等)。
@Aspect
@Component
public class LoggingAspect {
    @Before("execution(* com.example.service.*.*(..))")
    public void beforeAdvice(JoinPoint joinPoint) {
        // 在方法执行前执行的逻辑
    }
}
14.@ResponseBody
@ResponseBody 注解用于将方法的返回值直接作为 HTTP 响应体返回。
@Controller
public class MyController {
    @GetMapping("/hello")
    @ResponseBody
    public String hello() {
        return "Hello, world!";
    }
}
15.@RestController
@RestController 注解是 @Controller 和 @ResponseBody 的组合,用于标识一个类是 RESTful 控制器。
@RestController
public class MyRestController {
    @GetMapping("/api/hello")
    public String hello() {
        return "Hello, world!";
    }
}
16.@PathVariable
@PathVariable 注解用于从 URL 中获取参数值。
@RestController
@RequestMapping("/api")
public class MyRestController {
    @GetMapping("/hello/{name}")
    public String hello(@PathVariable String name) {
        return "Hello, " + name + "!";
    }
}
17.@RequestParam
@RequestParam 注解用于从请求参数中获取值。
@RestController
@RequestMapping("/api")
public class MyRestController {
    @GetMapping("/hello")
    public String hello(@RequestParam String name) {
        return "Hello, " + name + "!";
    }
}
18.@RequestBody
@RequestBody 注解用于将 HTTP 请求体中的数据绑定到方法的参数上,通常用于处理 POST 或 PUT 请求中的 JSON 数据。
@RestController
@RequestMapping("/api")
public class MyRestController {
    @PostMapping("/user")
    public String createUser(@RequestBody User user) {
        // 处理接收到的用户信息
        return "User created successfully!";
    }
}
19.@GetMapping
@GetMapping 注解用于将 HTTP GET 请求映射到特定的处理方法上。
@Controller
public class MyController {
    @GetMapping("/hello")
    public String hello() {
        return "hello";
    }
}
20.@PostMapping
@PostMapping 注解用于将 HTTP POST 请求映射到特定的处理方法上。
@RestController
@RequestMapping("/api")
public class UserController {
    @PostMapping("/user")
    public String createUser(@RequestBody User user) {
        // 处理接收到的用户信息
        return "User created successfully!";
    }
}
以上是一些常用的 Spring 注解,它们可以帮助我们更方便地开发和管理 Spring 应用程序。通过合理地使用注解,可以让代码更简洁、可读性更高,同时提高开发效率。



















![[C++] 类和对象 _ 剖析构造、析构与拷贝](https://img-blog.csdnimg.cn/img_convert/0980a36b43766541867344fa64655988.png)