当前位置: 首页 > ops >正文

JAVA项目中常见的注解总结

以下是 Spring Boot/Spring MVC 项目中按使用频率排序的核心注解总结,包含常用场景和示例,帮助你快速掌握高频开发需求:

一、高频基础注解(框架核心)

1. @SpringBootApplication(启动类注解)
  • 作用:标识 Spring Boot 应用的主类,包含 @Configuration+@EnableAutoConfiguration+@ComponentScan 组合功能。
  • 场景:项目入口类必加,用于开启自动配置和组件扫描。

    java

    @SpringBootApplication
    public class DemoApplication {public static void main(String[] args) {SpringApplication.run(DemoApplication.class, args);}
    }
    
2. @Controller(MVC 控制器)
  • 作用:标识一个 MVC 控制器类,处理 Web 请求。
  • 场景:处理 HTTP 请求的类(如 REST 接口),常配合 @RequestMapping 使用。

    java

    @Controller
    @RequestMapping("/user")
    public class UserController {// ...
    }
    
3. @RestController(REST 控制器)
  • 作用:组合 @Controller+@ResponseBody,直接返回 JSON / 对象(无需视图解析)。
  • 场景:开发 RESTful API 时使用,避免手动添加 @ResponseBody

    java

    @RestController
    @RequestMapping("/api")
    public class ApiController {@GetMapping("/data")public User getData() { return new User("admin"); } // 直接返回 JSON
    }
    
4. @RequestMapping(请求映射)
  • 作用:定义 URL 路径与方法的映射关系,可用于类或方法。
  • 场景:细粒度控制请求路径,支持 GET/POST/PUT/DELETE 等方法。

    java

    @GetMapping("/hello") // 等价于 @RequestMapping(method = GET)
    public String hello() { return "Hello World!"; }
    

二、依赖注入与配置注解(核心机制)

5. @Autowired(自动装配)
  • 作用:按类型自动注入 Bean,可用于字段、构造器、方法。
  • 场景:注入 Service/Repository/ 其他组件。

    java

    @Service
    public class UserService {@Autowiredprivate UserRepository repository; // 注入 DAO
    }
    
6. @Component(通用组件)
  • 作用:标识一个通用组件(如工具类),被 Spring 容器管理。
  • 场景:非 MVC 层的组件(如 @Service/@Repository/@Controller 是其衍生注解)。

    java

    @Component
    public class CacheUtil {// ...
    }
    
7. @Service(服务层组件)
  • 作用:标识服务层(Service)组件,用于业务逻辑处理。
  • 场景:Service 类上必加,配合 @Autowired 注入。

    java

    @Service
    public class UserServiceImpl implements UserService {// ...
    }
    
8. @Repository(数据层组件)
  • 作用:标识数据访问层(DAO)组件,自动处理异常(如 SQLException 转 DataAccessException)。
  • 场景:DAO 类或 MyBatis Mapper 接口上。

    java

    @Repository
    public interface UserRepository extends JpaRepository<User, Long> {// ...
    }
    

三、请求处理与参数注解(Web 开发核心)

9. @PathVariable(路径参数)
  • 作用:从 URL 路径中获取参数(如 /user/{id})。
  • 场景:RESTful 风格接口中获取资源 ID。

    java

    @GetMapping("/user/{id}")
    public User getUser(@PathVariable Long id) {return repository.findById(id).orElse(null);
    }
    
10. @RequestParam(请求参数)
  • 作用:获取请求参数(如 ?name=admin),支持默认值、是否必填等。
  • 场景:处理查询参数或表单参数。

    java

    @GetMapping("/list")
    public List<User> getUsers(@RequestParam(defaultValue = "0") int page) {// ...
    }
    
11. @RequestBody(请求体参数)
  • 作用:读取请求体中的 JSON/XML 数据,反序列化为对象。
  • 场景:处理 POST/PUT 请求的请求体(如前端传递的 JSON 对象)。

    java

    @PostMapping("/create")
    public User createUser(@RequestBody User user) {return repository.save(user);
    }
    
12. @ResponseBody(响应体)
  • 作用:将方法返回值转为 JSON/XML 响应(需配合 @Controller 使用)。
  • 场景:与 @Controller 搭配实现 REST 接口(@RestController 已包含此注解)。

    java

    @Controller
    @RequestMapping("/api")
    public class ApiController {@GetMapping("/data")@ResponseBody // 返回 JSONpublic User getData() { return new User("admin"); }
    }
    

四、配置与属性注入注解(环境配置)

13. @Configuration(配置类)
  • 作用:标识一个配置类,用于替代 XML 配置(如 Bean 定义)。
  • 场景:自定义 Bean 的配置类(如数据源、拦截器等)。

    java

    @Configuration
    public class AppConfig {@Beanpublic DataSource dataSource() {// 配置数据源}
    }
    
14. @Bean(Bean 定义)
  • 作用:在配置类中手动定义 Bean(替代 XML 的 <bean> 标签)。
  • 场景:自定义 Bean(如工具类、第三方库组件)。

    java

    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {RedisTemplate<String, Object> template = new RedisTemplate<>();template.setConnectionFactory(factory);return template;
    }
    
15. @Value(属性注入)
  • 作用:从配置文件(如 application.properties)中读取属性值。
  • 场景:注入自定义配置(如数据库连接参数、第三方服务地址)。

    java

    @Service
    public class EmailService {@Value("${email.server.host}")private String host;
    }
    

五、AOP 与事务注解(切面编程)

16. @Transactional(事务管理)
  • 作用:声明式事务管理,标注在方法或类上开启事务。
  • 场景:服务层方法中需要数据库事务的场景(如新增 / 更新操作)。

    java

    @Service
    public class OrderService {@Transactionalpublic void createOrder(Order order) {// 数据库操作自动加入事务}
    }
    
17. @Aspect(切面)
  • 作用:标识一个切面类,用于定义切点和通知(Advice)。
  • 场景:实现日志记录、权限校验、性能监控等横切逻辑。

    java

    @Aspect
    @Component
    public class LogAspect {@Pointcut("execution(* com.example.service.*.*(..))")public void servicePointcut() {}@Before("servicePointcut()")public void logBefore() {// 方法执行前记录日志}
    }
    

六、其他常用注解(扩展功能)

18. @CrossOrigin(跨域请求)
  • 作用:解决跨域问题(CORS),允许特定来源的请求访问接口。
  • 场景:前后端分离项目中,前端域名与后端不一致时。

    java

    @RestController
    @CrossOrigin(origins = "http://localhost:3000") // 允许前端域名
    @RequestMapping("/api")
    public class ApiController {// ...
    }
    
19. @Valid(参数校验)
  • 作用:结合 JSR-303 校验框架,验证请求参数合法性。
  • 场景:在 @RequestBody 或表单参数中校验数据(如非空、格式匹配)。

    java

    @PostMapping("/register")
    public User register(@Valid @RequestBody User user) { // 校验 User 对象字段return userService.save(user);
    }
    
20. @RequestMapping 衍生注解(快捷方式)
  • @GetMapping:等价于 @RequestMapping(method = GET)
  • @PostMapping:等价于 @RequestMapping(method = POST)
  • @PutMapping:等价于 @RequestMapping(method = PUT)
  • @DeleteMapping:等价于 @RequestMapping(method = DELETE)
  • 场景:简化 HTTP 方法的映射,代码更易读。

总结:按使用场景分类记忆

场景核心注解
启动与配置@SpringBootApplication@Configuration@Bean@Value
MVC 控制器@Controller@RestController@RequestMapping 及其衍生注解
依赖注入@Autowired@Component@Service@Repository
请求参数处理@PathVariable@RequestParam@RequestBody@ResponseBody
事务与 AOP@Transactional@Aspect@Pointcut@Before/@After
跨域与校验@CrossOrigin@Valid

http://www.xdnf.cn/news/7769.html

相关文章:

  • COMPUTEX 2025 | 广和通5G AI MiFi解决方案助力移动宽带终端迈向AI新未来
  • 电商系统搭建的关键细节与技术实践
  • 工作安排小K
  • springboot使用xdoc-report包导出word
  • 四、【API 开发篇 (上)】:使用 Django REST Framework 构建项目与模块 CRUD API
  • EtherNet/IP机柜内解决方案在医疗控制中心智能化的应用潜能和方向分析
  • aws平台s3存储桶夸域问题处理
  • c#中添加visionpro控件(联合编程)
  • 使用脚本备份和还原Windows环境变量
  • 【STM32】自定义打印函数
  • 浪潮服务器配置RAID和JBOD
  • centos系统redis-dump安装
  • Kotlin 极简小炒 P9 - 数组(数组的创建、数组元素的访问与修改、数组遍历、数组操作、多维数组、数组与可变参数)
  • 【JAVA】中文我该怎么排序?
  • Linux系统下nslookup命令的基本使用
  • Python爬虫(32)Python爬虫高阶:动态页面处理与Scrapy+Selenium+BeautifulSoup分布式架构深度解析实战
  • Python包管理工具uv 国内源配置
  • 网感驱动下开源AI大模型AI智能名片S2B2C商城小程序源码的实践路径研究
  • 【数据结构 · 初阶】- 快速排序
  • 基于双通道频谱分析的振动信号故障诊断3
  • Microbiome医口经典思路:退烧药物代谢过程如何进行多组学分析?
  • wps编辑技巧
  • 算子窗口操作
  • 如何使用redis做限流(golang实现小样)
  • 软考 系统架构设计师系列知识点之杂项集萃(66)
  • 信息学奥赛一本通 1853:【08NOIP提高组】传纸条 | 洛谷 P1006 [NOIP 2008 提高组] 传纸条
  • 软件测试知识详解
  • 微服务中API网关作用(统一入口、路由转发、协议转换、认证授权、请求聚合、负载均衡、熔断限流、监控日志)
  • AI护航化工:《山西省危化品视频智能分析指南》下的视频分析重构安全体系
  • elementui初学1