`@ApiOperation` 并不是 Spring 官方提供的注解,而是 **Swagger(现更名为 **OpenAPI Specification**)** 提供的一个注解,常用于 **Springfox**(Swagger 的 Spring 集成实现)中,用来对 **Controller 中的方法**进行描述,从而生成更友好的 API 文档。
---
### ✅ 基本作用
`@ApiOperation` 用于标注在 **Controller 的方法**上,提供该接口的说明信息,比如接口用途、返回值、是否废弃等。
---
### 📌 常用属性
| 属性名 | 类型 | 说明 |
|----------------|----------|------|
| `value` | String | 接口的简要描述(必填) |
| `notes` | String | 接口的详细说明(可选) |
| `httpMethod` | String | 指定 HTTP 方法,如 "GET", "POST" |
| `response` | Class<?> | 指定返回类型(可选) |
| `hidden` | boolean | 是否隐藏该接口,默认 false |
| `deprecated` | boolean | 标记接口是否已废弃 |
---
### 🧪 示例代码
```java
@RestController
@RequestMapping("/user")
public class UserController {
@ApiOperation(
value = "根据ID查询用户",
notes = "返回单个用户详情,包含用户名、邮箱等信息",
response = UserDTO.class
)
@GetMapping("/{id}")
public UserDTO getUserById(@PathVariable Long id) {
// ...
}
}
```
---
### 📚 注意事项
- 使用 `@ApiOperation` 需要引入 Swagger 相关依赖(如 springfox-swagger2 或 springdoc-openapi-starter-webmvc-ui)。
- Spring 3.x 以后,官方推荐使用 **Springdoc OpenAPI** 替代 Springfox,后者已停止维护。
---
### ✅ 替代方案(Springdoc OpenAPI)
如果你使用的是 Springdoc(推荐),可以用 `@Operation` 替代:
```java
@Operation(summary = "根据ID查询用户", description = "返回单个用户详情")
```
---
### ✅ 总结一句话
> `@ApiOperation` 是 Swagger 的注解,用于给 Spring 接口写文档,**不是 Spring 官方注解**,但在 Swagger 集成中非常常见。
- 环境配置
- window怎么配置java环境变量?
- Java基础语法
- 数据类型
- Java中的数据类型
- Java中的泛型容器
- Java中的JSONObject
- Java高级特性
- Maven
- jib-maven-plugin
- 什么是Spring Boot 的 parent pom?
- maven中各个生命周期的含义
- Spring Boot
- maven与spring boot 的关系
- Java中的连接池
- Spring JDBC
- Spring JDBC的概念
- JdbcTemplate常用的方法
- Spring中Bean的概念
- Spring中的抽象,通俗解释一下
- Spring中的事物
- Spring中的事物,通俗解释一下
- Spring中的事物抽象,常见的有哪些,列举一下
- Spring中常用的事物场景有哪些,列举一下
- Spring事务管理有哪些注解?
- Spring中使用事物处理订单的案例,列举说明一下
- Spring中声明式事务、分布式事务以及编程式事务的区别,列举一下
- 配置文件
- application-properties配置文件
- Spring Boot 的启动
- spring boot项目如何启动?
- 列举一下Spring Boot的启动过程
- SpringApplication.run方法
- Spring Boot 启动时有哪些接口?
- CommandLineRunner
- Spring Boot 的常用注解
- 系统注解
- 表格:系统注解
- @Override
- @Deprecated
- @SuppressWarnnings
- 使用在类名上的注解
- 表格:使用在类名上的注解
- @RestController
- @Controller
- @Service
- @Repository
- @Component
- @Configuration
- @Resource
- @Autowired
- @RequestMapping
- @GetMapping
- @PostMapping
- @Transactional
- @Qualifier
- 使用在方法上的注解
- 表格:使用在方法上的注解
- @RequestBody
- @PathVariable
- @Bean
- @ResponseBody
- @PreAuthorize
- 其他常用注解
- 表格:其他常用注解
- @EnableAutoConfiguration
- @SpringBootApplication
- @EnableScheduling
- @EnableAsync
- @ComponentScan
- @Aspec
- @ControllerAdvice
- @ExceptionHandler
- @Value
- @ConfigurationProperties
- @EnableConfigurationProperties
- @MapperScan
- @ApiOperation
- Validator验证的常用注解
- spring IoC容器
- Spring IoC容器依赖注入实现方式
- MyBatis
- paginationInterceptor
- @TableName
- @TableId
- @Param
- UrlBasedCorsConfigurationSource
- Lombok
- @Data
- @Slf4j
- @EqualsAndHashCode
- @Accessors
- 支付系统
- 1. 初始化mysql数据库流程
- 2. 初始化redis数据库的流程
- 3. 初始化rabbitmq服务
- 环球置业
- 1.模块目录结构分析
- 2. DTO(数据传输层)的核心作用
- 3. VO(视图对象层)
- 4. VO(视图对象层)和 DTO 数据传输层 的区别
