自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

28個SpringBoot項目中常用注解,日常開發(fā)、求職面試不再懵圈

開發(fā) 項目管理
@SpringBootApplication是組合注解。相當(dāng)于@Configuration、@EnableAutoConfiguration、@ComponentScan的組合。

前言

在使用SpringBoot開發(fā)中或者在求職面試中都會使用到很多注解或者問到注解相關(guān)的知識。本文主要對一些常用的注解進(jìn)行了總結(jié),同時也會舉出具體例子,供大家學(xué)習(xí)和參考。

注解一覽表

啟動類以及配置類相關(guān)

@SpringBootApplication

解釋:

  • @SpringBootApplication是組合注解。相當(dāng)于@Configuration、@EnableAutoConfiguration、@ComponentScan的組合。
  • 用于標(biāo)記啟動類,指出應(yīng)用入口
@SpringBootApplication
public class MyApplication {
    public static void main(String[] args) {
        SpringApplication.run(MyApplication.class, args);
    }
}

@Configuration

解釋:

  • 聲明當(dāng)前類為配置類。相當(dāng)于xml配置中的beans標(biāo)簽。
@Configuration
public class MyConfig {
    @Bean
    public MyBean myBean() {
        return new MyBean();
    }
}

@EnableAutoConfiguration

解釋:

  • 開啟SpringBoot自動裝配功能。
@SpringBootApplication
@EnableAutoConfiguration
public class MyApplication {
    // ...
}

@ComponentScan

解釋:

  • 配置SpringBoot掃描包路徑。
@SpringBootApplication
@ComponentScan("com.example")
public class MyApplication {
    // ...
}

控制層相關(guān)

@RestController

解釋:

  • @RestController注解用于定義控制器類,將其返回的結(jié)果自動轉(zhuǎn)換為JSON格式
@RestController
public class UserController {
    @GetMapping("/users")
    public List<User> getAllUsers() {
        // 返回所有用戶列表的邏輯
    }
}

@RequestMapping

解釋:

  • 用于映射HTTP請求到處理器上,指定處理器方法的URL路徑和HTTP請求方法。
@RestController
@RequestMapping("/users")
public class UserController {
    @GetMapping("/{id}")
    public User getUserById(@PathVariable("id") Long id) {
        // 根據(jù)id獲取用戶的邏輯
    }
}

@GetMapping、@PostMapping、@DeleteMapping、@PutMapping

解釋:

  • @GetMapping注解用于處理HTTP的GET請求,并將請求映射到相應(yīng)的處理器方法上。
  • @PostMapping注解用于處理HTTP的POST請求,并將請求映射到相應(yīng)的處理器方法上。
  • @DeleteMapping注解用于處理HTTP的DELETE請求,并將請求映射到相應(yīng)的處理器方法上。
  • @PutMapping是Spring框架中用于處理HTTP的PUT請求的注解。PUT請求通常用于更新資源,即將新的數(shù)據(jù)替換掉指定的資源。
@RestController
@RequestMapping("/users")
public class UserController {
    @GetMapping("/{id}")
    public User getUserById(@PathVariable("id") Long id) {
        // 根據(jù)id獲取用戶的邏輯
    }
}


@RestController
@RequestMapping("/users")
public class UserController {
    @PostMapping
    public User createUser(@RequestBody User user) {
        // 創(chuàng)建用戶的邏輯
    }
}


@RestController
@RequestMapping("/users")
public class UserController {
    @DeleteMapping("/{id}")
    public void deleteUser(@PathVariable("id") Long id) {
        // 刪除用戶的邏輯
    }
}


@RestController
@RequestMapping("/users")
public class UserController {
    @PutMapping("/{id}")
    public User updateUser(@PathVariable("id") Long id, @RequestBody User user) {
        // 更新用戶信息的邏輯
    }
}

@RequestParam

解釋:

  • @RequestParam注解用于獲取請求參數(shù)的值,并將其綁定到處理器方法的形參上。一般用于路徑中?傳參形式。
@RestController
@RequestMapping("/users")
public class UserController {
    @GetMapping
    public List<User> getUsersByPage(@RequestParam("page") int page, 
                                     @RequestParam(value = "size", defaultValue = "10") int size) {
        // 分頁查詢用戶列表的邏輯
    }
}

@PathVariable

解釋:

  • 用于獲取URL路徑中的變量值,并將其綁定到處理器方法的形參上。一般用于/傳參的形式。
@RestController
@RequestMapping("/users")
public class UserController {
    @GetMapping("/{id}")
    public User getUserById(@PathVariable("id") Long id) {
        // 根據(jù)id獲取用戶的邏輯
    }
}

@RequestBody

解釋:

  • 用于接收HTTP請求的請求體內(nèi)容,并將其轉(zhuǎn)化為對應(yīng)的Java對象或其他類型的參數(shù)。
@RestController
@RequestMapping("/users")
public class UserController {
    @PostMapping
    public User createUser(@RequestBody User user) {
        // 創(chuàng)建用戶的邏輯
    }
}

@Valid

解釋:

  • @Valid用于開啟數(shù)據(jù)驗證功能,對方法參數(shù)進(jìn)行校驗,確保其滿足定義的驗證規(guī)則
@RestController
@RequestMapping("/users")
public class UserController {
    @PostMapping
    public ResponseEntity<User> createUser(@Valid @RequestBody User user) {
        // 創(chuàng)建用戶的邏輯
        return ResponseEntity.status(HttpStatus.CREATED).body(user);
    }
}

Bean管理相關(guān)

  • @Autowired: 自動裝配,用于自動注入依賴的Bean實例。
  • @Service: 用于標(biāo)識一個服務(wù)類,表示它是業(yè)務(wù)邏輯層的組件。
  • @Repository: 用于標(biāo)識一個數(shù)據(jù)訪問類,表示它是數(shù)據(jù)訪問層的組件。
  • @Component: 通用的Spring組件注解,用于標(biāo)識一個普通的Bean組件。
  • @Value: 注入配置文件中的值到對應(yīng)的變量中。

異步和定時相關(guān)

@EnableScheduling、@Scheduled

解釋:

  • @EnableScheduling:啟動類添加@EnableScheduling開啟任務(wù)調(diào)度功能。
  • @Scheduled:定時任務(wù)注解,用于標(biāo)識定時任務(wù)的方法。
@SpringBootApplication
@EnableScheduling
public class MyApp {
    public static void main(String[] args) {
        SpringApplication.run(MyApp.class, args);
    }
}


@Component
public class MyScheduler {
    @Scheduled(fixedRate = 5000)
    public void myTask() {
        // 每個5秒執(zhí)行一次的任務(wù)邏輯
    }
}


@Component
public class MyScheduler {
    @Scheduled(cron = "0 0 8 * * ?")
    public void myTask() {
        // 每天早上8點(diǎn)執(zhí)行的任務(wù)邏輯
    }
}

@EnableAsync、@Async

解釋:

  • @EnableAsync:啟動類添加,開啟異步任務(wù)。
  • @Async:標(biāo)識異步任務(wù)方法。
@SpringBootApplication
@EnableAsync
public class MyApp {
    public static void main(String[] args) {
        SpringApplication.run(MyApp.class, args);
    }
}


@Service
public class MyService {
    @Async
    public CompletableFuture<String> asyncTask() {
        // 異步執(zhí)行的任務(wù)邏輯
        // 返回一個CompletableFuture以支持異步結(jié)果的處理
    }
}

緩存和事務(wù)管理

解釋:

  • @EnableCaching: 開啟Spring的緩存支持,用于緩存方法的結(jié)果,提高性能。
  • @Transactional: 提供聲明式事務(wù)管理,用于標(biāo)識需要使用事務(wù)的方法或類。
  • @EnableTransactionManagement: 開啟事務(wù)管理支持,用于啟用Spring的聲明式事務(wù)管理功能
@SpringBootApplication
@EnableCaching
@EnableTransactionManagement
public class MyApp {
    public static void main(String[] args) {
        SpringApplication.run(MyApp.class, args);
    }
}
@Service
public class MyService {
    @Transactional
    public void performTransaction() {
        // 執(zhí)行數(shù)據(jù)庫操作等需要事務(wù)管理的邏輯
    }
}

異常處理相關(guān)

@RestControllerAdvice、@ExceptionHandler

  • @RestControllerAdvice:結(jié)合了@ControllerAdvice和@ResponseBody注解的功能。它用于定義全局的異常處理和統(tǒng)一的響應(yīng)處理。
  • @ExceptionHandler:指定類型的異常進(jìn)行統(tǒng)一處理。
@RestControllerAdvice
public class GlobalExceptionHandler {
    @ExceptionHandler(Exception.class)
    public ResponseEntity<String> handleException(Exception e) {
        // 異常處理邏輯,可以根據(jù)實際需求進(jìn)行對異常的處理和返回相應(yīng)的錯誤信息
        return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Internal Server Error");
    }
}

寫在最后

有關(guān)于SpringBoot常用注解到此就結(jié)束了。

責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2025-01-15 09:00:20

2024-08-02 17:19:36

2020-04-17 20:58:34

MySQLSQL優(yōu)化

2017-11-27 11:25:36

MySQL優(yōu)化數(shù)據(jù)

2017-12-06 09:00:14

2024-01-30 10:11:00

SpringBoot項目開發(fā)

2023-05-17 08:34:27

開發(fā)技術(shù)應(yīng)用

2023-12-14 17:24:20

Linux開源項目

2019-11-21 10:40:54

MySQLMySQL優(yōu)化MySQL索引

2014-05-04 16:39:49

開源項目開源產(chǎn)品

2022-06-26 09:56:50

HttpUtil工具類模式

2017-09-06 12:42:45

AndroidGradle開發(fā)技巧

2024-07-03 13:03:30

Spring注解項目

2017-01-10 19:06:39

Android日常開發(fā)技術(shù)經(jīng)驗

2021-08-03 15:26:56

代碼智能阿里云

2020-09-24 10:00:50

SpringBoo

2022-12-19 08:30:51

ViteWebpack

2022-03-17 08:34:47

TypeScript項目類型

2023-11-15 14:34:05

MySQL悲觀鎖

2023-08-10 17:23:39

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號