0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Spring Boot中常見的各類型注解的使用方式

Android編程精選 ? 來源:ramostear.com ? 作者:ramostear.com ? 2022-06-20 16:38 ? 次閱讀
  • 一、Spring Web MVC 與 Spring Bean 注解
    • Spring Web MVC 注解
  • 二、Spring Bean 注解
  • 三、Spring Dependency Inject 與 Bean Scops注解
    • Spring DI注解
    • Scops注解
  • 四、容器配置注解
    • @Autowired
    • @Primary
    • @PostConstruct與@PreDestroy
    • @Qualifier
  • 五、Spring Boot注解
  • 總結

大家好,我是程序汪,企業(yè)開發(fā)項目SpringBoot已經是必備框架了,其中注解是開發(fā)中的小工具(誰處可見哦),用好了開發(fā)效率大大提升,當然用錯了也會引入缺陷。

一、Spring Web MVC 與 Spring Bean 注解

Spring Web MVC 注解

@RequestMapping

@RequestMapping注解的主要用途是將Web請求與請求處理類中的方法進行映射。Spring MVC和Spring WebFlux都通過RquestMappingHandlerMappingRequestMappingHndlerAdapter兩個類來提供對@RequestMapping注解的支持。

@RequestMapping注解對請求處理類中的請求處理方法進行標注;@RequestMapping注解擁有以下的六個配置屬性:

  • value:映射的請求URL或者其別名
  • method:兼容HTTP的方法名
  • params:根據HTTP參數(shù)的存在、缺省或值對請求進行過濾
  • header:根據HTTP Header的存在、缺省或值對請求進行過濾
  • consume:設定在HTTP請求正文中允許使用的媒體類型
  • product:在HTTP響應體中允許使用的媒體類型

提示:在使用@RequestMapping之前,請求處理類還需要使用@Controller或@RestController進行標記

下面是使用@RequestMapping的兩個示例:

707990b2-ee32-11ec-ba43-dac502259ad0.png圖片

@RequestMapping還可以對類進行標記,這樣類中的處理方法在映射請求路徑時,會自動將類上@RequestMapping設置的value拼接到方法中映射路徑之前,如下:

708474b4-ee32-11ec-ba43-dac502259ad0.png圖片

@RequestBody

@RequestBody在處理請求方法的參數(shù)列表中使用,它可以將請求主體中的參數(shù)綁定到一個對象中,請求主體參數(shù)是通過HttpMessageConverter傳遞的,根據請求主體中的參數(shù)名與對象的屬性名進行匹配并綁定值。此外,還可以通過@Valid注解對請求主體中的參數(shù)進行校驗。

下面是一個使用@RequestBody的示例:

7091d546-ee32-11ec-ba43-dac502259ad0.jpg圖片

@GetMapping

@GetMapping注解用于處理HTTP GET請求,并將請求映射到具體的處理方法中。具體來說,@GetMapping是一個組合注解,它相當于是@RequestMapping(method=RequestMethod.GET)的快捷方式。

下面是@GetMapping的一個使用示例:

70ab5624-ee32-11ec-ba43-dac502259ad0.jpg圖片

@PostMapping

@PostMapping注解用于處理HTTP POST請求,并將請求映射到具體的處理方法中。@PostMapping與@GetMapping一樣,也是一個組合注解,它相當于是@RequestMapping(method=HttpMethod.POST)的快捷方式。

下面是使用@PostMapping的一個示例:

7091d546-ee32-11ec-ba43-dac502259ad0.jpg圖片

@PutMapping

@PutMapping注解用于處理HTTP PUT請求,并將請求映射到具體的處理方法中,@PutMapping是一個組合注解,相當于是@RequestMapping(method=HttpMethod.PUT)的快捷方式。

下面是使用@PutMapping的一個示例:

70c2889e-ee32-11ec-ba43-dac502259ad0.jpg圖片

@DeleteMapping

@DeleteMapping注解用于處理HTTP DELETE請求,并將請求映射到刪除方法中。@DeleteMapping是一個組合注解,它相當于是@RequestMapping(method=HttpMethod.DELETE)的快捷方式。

下面是使用@DeleteMapping的一個示例:

70df6d42-ee32-11ec-ba43-dac502259ad0.jpg圖片

@PatchMapping

@PatchMapping注解用于處理HTTP PATCH請求,并將請求映射到對應的處理方法中。@PatchMapping相當于是@RequestMapping(method=HttpMethod.PATCH)的快捷方式。

下面是一個簡單的示例:

70ec5c8c-ee32-11ec-ba43-dac502259ad0.jpg圖片

@ControllerAdvice

@ControllerAdvice是@Component注解的一個延伸注解,Spring會自動掃描并檢測被@ControllerAdvice所標注的類。@ControllerAdvice需要和@ExceptionHandler、@InitBinder以及@ModelAttribute注解搭配使用,主要是用來處理控制器所拋出的異常信息。

首先,我們需要定義一個被@ControllerAdvice所標注的類,在該類中,定義一個用于處理具體異常的方法,并使用@ExceptionHandler注解進行標記。

此外,在有必要的時候,可以使用@InitBinder在類中進行全局的配置,還可以使用@ModelAttribute配置與視圖相關的參數(shù)。使用@ControllerAdvice注解,就可以快速的創(chuàng)建統(tǒng)一的,自定義的異常處理類。

下面是一個使用@ControllerAdvice的示例代碼:

70f93f2e-ee32-11ec-ba43-dac502259ad0.jpg圖片

@ResponseBody

@ResponseBody會自動將控制器中方法的返回值寫入到HTTP響應中。特別的,@ResponseBody注解只能用在被@Controller注解標記的類中。如果在被@RestController標記的類中,則方法不需要使用@ResponseBody注解進行標注。@RestController相當于是@Controller@ResponseBody的組合注解。

下面是使用該注解的一個示例

71037228-ee32-11ec-ba43-dac502259ad0.png圖片

@ExceptionHandler

@ExceptionHander注解用于標注處理特定類型異常類所拋出異常的方法。當控制器中的方法拋出異常時,Spring會自動捕獲異常,并將捕獲的異常信息傳遞給被@ExceptionHandler標注的方法。

下面是使用該注解的一個示例:

7112d0e2-ee32-11ec-ba43-dac502259ad0.jpg圖片

@ResponseStatus

@ResponseStatus注解可以標注請求處理方法。使用此注解,可以指定響應所需要的HTTP STATUS。特別地,我們可以使用HttpStauts類對該注解的value屬性進行賦值。

下面是使用@ResponseStatus注解的一個示例:

712dbfa6-ee32-11ec-ba43-dac502259ad0.jpg圖片

@PathVariable

@PathVariable注解是將方法中的參數(shù)綁定到請求URI中的模板變量上??梢酝ㄟ^@RequestMapping注解來指定URI的模板變量,然后使用@PathVariable注解將方法中的參數(shù)綁定到模板變量上。

特別地,@PathVariable注解允許我們使用value或name屬性來給參數(shù)取一個別名。下面是使用此注解的一個示例:

713b5f8a-ee32-11ec-ba43-dac502259ad0.jpg圖片

模板變量名需要使用{ }進行包裹,如果方法的參數(shù)名與URI模板變量名一致,則在@PathVariable中就可以省略別名的定義。

下面是一個簡寫的示例:

714776a8-ee32-11ec-ba43-dac502259ad0.jpg圖片

提示:如果參數(shù)是一個非必須的,可選的項,則可以在@PathVariable中設置require = false

@RequestParam

@RequestParam注解用于將方法的參數(shù)與Web請求的傳遞的參數(shù)進行綁定。使用@RequestParam可以輕松的訪問HTTP請求參數(shù)的值。

下面是使用該注解的代碼示例:

715c86ec-ee32-11ec-ba43-dac502259ad0.png圖片

該注解的其他屬性配置與@PathVariable的配置相同,特別的,如果傳遞的參數(shù)為空,還可以通過defaultValue設置一個默認值。示例代碼如下:

716992a6-ee32-11ec-ba43-dac502259ad0.jpg圖片

@Controller

@Controller@Component注解的一個延伸,Spring 會自動掃描并配置被該注解標注的類。此注解用于標注Spring MVC的控制器。下面是使用此注解的示例代碼:

71755bea-ee32-11ec-ba43-dac502259ad0.jpg圖片

@RestController

@RestController是在Spring 4.0開始引入的,這是一個特定的控制器注解。此注解相當于@Controller@ResponseBody的快捷方式。當使用此注解時,不需要再在方法上使用@ResponseBody注解。

下面是使用此注解的示例代碼:

7183589e-ee32-11ec-ba43-dac502259ad0.jpg圖片

@ModelAttribute

通過此注解,可以通過模型索引名稱來訪問已經存在于控制器中的model。下面是使用此注解的一個簡單示例:

7190eb6c-ee32-11ec-ba43-dac502259ad0.png圖片

@PathVariable@RequestParam注解一樣,如果參數(shù)名與模型具有相同的名字,則不必指定索引名稱,簡寫示例如下:

71b45f0c-ee32-11ec-ba43-dac502259ad0.png圖片

特別地,如果使用@ModelAttribute對方法進行標注,Spring會將方法的返回值綁定到具體的Model上。示例如下:

71c5d5d4-ee32-11ec-ba43-dac502259ad0.png圖片

在Spring調用具體的處理方法之前,被@ModelAttribute注解標注的所有方法都將被執(zhí)行。

@CrossOrigin

@CrossOrigin注解將為請求處理類或請求處理方法提供跨域調用支持。如果我們將此注解標注類,那么類中的所有方法都將獲得支持跨域的能力。使用此注解的好處是可以微調跨域行為。使用此注解的示例如下:

71d04b22-ee32-11ec-ba43-dac502259ad0.jpg圖片

@InitBinder

@InitBinder注解用于標注初始化WebDataBinider 的方法,該方法用于對Http請求傳遞的表單數(shù)據進行處理,如時間格式化、字符串處理等。下面是使用此注解的示例:

71df9df2-ee32-11ec-ba43-dac502259ad0.png圖片

二、Spring Bean 注解

在本小節(jié)中,主要列舉與Spring Bean相關的4個注解以及它們的使用方式。

@ComponentScan

@ComponentScan注解用于配置Spring需要掃描的被組件注解注釋的類所在的包??梢酝ㄟ^配置其basePackages屬性或者value屬性來配置需要掃描的包路徑。value屬性是basePackages的別名。此注解的用法如下:

@Component

@Component注解用于標注一個普通的組件類,它沒有明確的業(yè)務范圍,只是通知Spring被此注解的類需要被納入到Spring Bean容器中并進行管理。此注解的使用示例如下:

71edbacc-ee32-11ec-ba43-dac502259ad0.png圖片

@Service

@Service注解是@Component的一個延伸(特例),它用于標注業(yè)務邏輯類。與@Component注解一樣,被此注解標注的類,會自動被Spring所管理。下面是使用@Service注解的示例:

71f6dd28-ee32-11ec-ba43-dac502259ad0.jpg圖片

@Repository

@Repository注解也是@Component注解的延伸,與@Component注解一樣,被此注解標注的類會被Spring自動管理起來,@Repository注解用于標注DAO層的數(shù)據持久化類。此注解的用法如下:

7206938a-ee32-11ec-ba43-dac502259ad0.jpg圖片?Java項目分享 ?最新整理全集,找項目不累啦 07版

三、Spring Dependency Inject 與 Bean Scops注解

Spring DI注解

@DependsOn

@DependsOn注解可以配置Spring IoC容器在初始化一個Bean之前,先初始化其他的Bean對象。下面是此注解使用示例代碼:

72198bac-ee32-11ec-ba43-dac502259ad0.jpg圖片

@Bean

@Bean注解主要的作用是告知Spring,被此注解所標注的類將需要納入到Bean管理工廠中。@Bean注解的用法很簡單,在這里,著重介紹@Bean注解中initMethoddestroyMethod的用法。示例如下:

7230e3a6-ee32-11ec-ba43-dac502259ad0.jpg圖片

Scops注解

@Scope

@Scope注解可以用來定義@Component標注的類的作用范圍以及@Bean所標記的類的作用范圍。@Scope所限定的作用范圍有:singleton、prototyperequest、session、globalSession或者其他的自定義范圍。這里以prototype為例子進行講解。

當一個Spring Bean被聲明為prototype(原型模式)時,在每次需要使用到該類的時候,Spring IoC容器都會初始化一個新的改類的實例。在定義一個Bean時,可以設置Bean的scope屬性為prototype:scope=“prototype”,也可以使用@Scope注解設置,如下:

@Scope(value=ConfigurableBeanFactory.SCOPE_PROPTOTYPE)

下面將給出兩種不同的方式來使用@Scope注解,示例代碼如下:

723e6f08-ee32-11ec-ba43-dac502259ad0.jpg圖片

@Scope 單例模式

當@Scope的作用范圍設置成Singleton時,被此注解所標注的類只會被Spring IoC容器初始化一次。在默認情況下,Spring IoC容器所初始化的類實例都為singleton。同樣的原理,此情形也有兩種配置方式,示例代碼如下:

724c56ae-ee32-11ec-ba43-dac502259ad0.png圖片

四、容器配置注解

@Autowired

@Autowired注解用于標記Spring將要解析和注入的依賴項。此注解可以作用在構造函數(shù)、字段和setter方法上。

作用于構造函數(shù)

下面是@Autowired注解標注構造函數(shù)的使用示例:

7257af0e-ee32-11ec-ba43-dac502259ad0.png圖片

作用于setter方法

下面是@Autowired注解標注setter方法的示例代碼:

7268b29a-ee32-11ec-ba43-dac502259ad0.png圖片

作用于字段

@Autowired注解標注字段是最簡單的,只需要在對應的字段上加入此注解即可,示例代碼如下:

727538ee-ee32-11ec-ba43-dac502259ad0.png圖片

@Primary

當系統(tǒng)中需要配置多個具有相同類型的bean時,@Primary可以定義這些Bean的優(yōu)先級。下面將給出一個實例代碼來說明這一特性:

7288267a-ee32-11ec-ba43-dac502259ad0.png圖片

輸出結果:

thisissendDingDingmethodmessage.

@PostConstruct與@PreDestroy

值得注意的是,這兩個注解不屬于Spring,它們是源于JSR-250中的兩個注解,位于common-annotations.jar中。@PostConstruct注解用于標注在Bean被Spring初始化之前需要執(zhí)行的方法。@PreDestroy注解用于標注Bean被銷毀前需要執(zhí)行的方法。下面是具體的示例代碼:

72991b06-ee32-11ec-ba43-dac502259ad0.png圖片

@Qualifier

當系統(tǒng)中存在同一類型的多個Bean時,@Autowired在進行依賴注入的時候就不知道該選擇哪一個實現(xiàn)類進行注入。此時,我們可以使用@Qualifier注解來微調,幫助@Autowired選擇正確的依賴項。下面是一個關于此注解的代碼示例:

72b3baf6-ee32-11ec-ba43-dac502259ad0.png圖片

五、Spring Boot注解

@SpringBootApplication

@SpringBootApplication注解是一個快捷的配置注解,在被它標注的類中,可以定義一個或多個Bean,并自動觸發(fā)自動配置Bean和自動掃描組件。此注解相當于@Configuration、@EnableAutoConfiguration@ComponentScan的組合。

在Spring Boot應用程序的主類中,就使用了此注解。示例代碼如下:

@SpringBootApplication
publicclassApplication{
publicstaticvoidmain(String[]args){
SpringApplication.run(Application.class,args);
}
}

@EnableAutoConfiguration

@EnableAutoConfiguration注解用于通知Spring,根據當前類路徑下引入的依賴包,自動配置與這些依賴包相關的配置項。

@ConditionalOnClass與@ConditionalOnMissingClass

這兩個注解屬于類條件注解,它們根據是否存在某個類作為判斷依據來決定是否要執(zhí)行某些配置。下面是一個簡單的示例代碼:

@Configuration
@ConditionalOnClass(DataSource.class)
classMySQLAutoConfiguration{
//...
}

@ConditionalOnBean與@ConditionalOnMissingBean

這兩個注解屬于對象條件注解,根據是否存在某個對象作為依據來決定是否要執(zhí)行某些配置方法。示例代碼如下:

@Bean
@ConditionalOnBean(name="dataSource")
LocalContainerEntityManagerFactoryBeanentityManagerFactory(){
//...
}
@Bean
@ConditionalOnMissingBean
publicMyBeanmyBean(){
//...
}

@ConditionalOnProperty

@ConditionalOnProperty注解會根據Spring配置文件中的配置項是否滿足配置要求,從而決定是否要執(zhí)行被其標注的方法。示例代碼如下:

@Bean
@ConditionalOnProperty(name="alipay",havingValue="on")
Alipayalipay(){
returnnewAlipay();
}

@ConditionalOnResource

此注解用于檢測當某個配置文件存在使,則觸發(fā)被其標注的方法,下面是使用此注解的代碼示例:

@ConditionalOnResource(resources="classpath:website.properties")
PropertiesaddWebsiteProperties(){
//...
}

@ConditionalOnWebApplication與@ConditionalOnNotWebApplication

這兩個注解用于判斷當前的應用程序是否是Web應用程序。如果當前應用是Web應用程序,則使用Spring WebApplicationContext,并定義其會話的生命周期。下面是一個簡單的示例:

@ConditionalOnWebApplication
HealthCheckControllerhealthCheckController(){
//...
}

@ConditionalExpression

此注解可以讓我們控制更細粒度的基于表達式的配置條件限制。當表達式滿足某個條件或者表達式為真的時候,將會執(zhí)行被此注解標注的方法。

@Bean
@ConditionalException("${localstore}&&${local=='true'}")
LocalFileStorestore(){
//...
}

@Conditional

@Conditional注解可以控制更為復雜的配置條件。在Spring內置的條件控制注解不滿足應用需求的時候,可以使用此注解定義自定義的控制條件,以達到自定義的要求。下面是使用該注解的簡單示例:

@Conditioanl(CustomConditioanl.class)
CustomPropertiesaddCustomProperties(){
//...
}

總結

本次課程總結了Spring Boot中常見的各類型注解的使用方式,讓大家能夠統(tǒng)一的對Spring Boot常用注解有一個全面的了解。

由于篇幅的原因,關于Spring Boot不常用的一些注解,將在下一次分享中進行補充和說明

原文標題:40 個 SpringBoot 常用注解:讓生產力爆表!

文章出處:【微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • HTTP
    +關注

    關注

    0

    文章

    499

    瀏覽量

    30978
  • spring
    +關注

    關注

    0

    文章

    338

    瀏覽量

    14295
  • MVC
    MVC
    +關注

    關注

    0

    文章

    73

    瀏覽量

    13831
  • 注解
    +關注

    關注

    0

    文章

    18

    瀏覽量

    2663

原文標題:40 個 SpringBoot 常用注解:讓生產力爆表!

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    檢測系統(tǒng)中常見的信號類型有哪些

    在檢測系統(tǒng)中,常見的信號類型多種多樣,這些信號類型根據被測物理量的不同而有所區(qū)別。以下是一些常見的信號類型: 位移信號 :位移信號是檢測系統(tǒng)
    的頭像 發(fā)表于 10-15 13:57 ?284次閱讀

    Spring Cloud Gateway網關框架

    SpringCloud Gateway功能特征如下: (1) 基于Spring Framework 5, Project Reactor 和 Spring Boot 2.0 進行構建; (2) 動態(tài)路由:能夠匹配任何請求屬性;
    的頭像 發(fā)表于 08-22 09:58 ?413次閱讀
    <b class='flag-5'>Spring</b> Cloud Gateway網關框架

    PCBA加工中常見的兩種焊接方式詳解

    一站式PCBA智造廠家今天為大家講講PCBA加工手工焊接有哪幾種方式?PCBA加工過程中常用焊接方式。在PCBA(印刷電路板組裝)加工過程中,焊接是一個關鍵的步驟。而手工焊接作為一種常見
    的頭像 發(fā)表于 06-14 09:18 ?471次閱讀

    使用Spring Boot 3.2虛擬線程搭建靜態(tài)文件服務器

    Spring Boot 3.2 于 2023 年 11 月大張旗鼓地發(fā)布,標志著 Java 開發(fā)領域的一個關鍵時刻。這一突破性的版本引入了一系列革命性的功能。
    的頭像 發(fā)表于 01-09 09:34 ?1071次閱讀
    使用<b class='flag-5'>Spring</b> <b class='flag-5'>Boot</b> 3.2虛擬線程搭建靜態(tài)文件服務器

    伺服電機應用中常見干擾類型和產生途徑

    伺服電機應用中常見干擾類型和產生途徑
    的頭像 發(fā)表于 01-07 17:56 ?1331次閱讀

    Spring事務失效的十種常見場景

    Spring的聲明式事務功能更是提供了極其方便的事務配置方式,配合Spring Boot的自動配置,大多數(shù)Spring
    的頭像 發(fā)表于 12-11 15:03 ?834次閱讀

    如何在Spring Boot應用程序中整合ZXing庫

    在數(shù)字化時代,二維碼已經成為了信息交流的一種常見方式。它們被廣泛用于各種應用,從產品標簽到活動傳單,以及電子支付。本文將向您展示如何在Spring Boot應用程序中整合ZXing庫,以創(chuàng)建和解析QR碼。
    的頭像 發(fā)表于 12-03 17:39 ?1048次閱讀

    springboot的全局配置文件有幾種

    、服務器端口等等。本文將詳細介紹Spring Boot的全局配置文件,包括其類型、常見的配置項以及使用方法。 第一部分:Spring
    的頭像 發(fā)表于 12-03 15:28 ?1483次閱讀

    Spring中依賴注入的四種方式

    詳細介紹四種常見的依賴注入方式。 第一種方式是構造函數(shù)注入。構造函數(shù)注入是最基礎也是最常用的依賴注入方式之一。它通過在對象創(chuàng)建時將依賴的對象作為參數(shù)傳遞給構造函數(shù)來實現(xiàn)注入。在
    的頭像 發(fā)表于 12-03 15:11 ?1826次閱讀

    SpringBoot核心注解由幾個注解組成

    Spring Boot 是一個開源的 JavaEE 開發(fā)框架,它以簡化 Spring 框架的配置與開發(fā)為目標,旨在讓開發(fā)者能快速構建獨立、生產級別的應用程序。Spring
    的頭像 發(fā)表于 12-03 15:09 ?685次閱讀

    springboot自動裝配原理簡述

    自動裝配的原理,并解釋它是如何實現(xiàn)的。 一、自動裝配的背景和意義 在傳統(tǒng)的Spring開發(fā)中,我們需要手動配置大量的XML或Java注解來定義各個組件的依賴關系、配置信息等。這種方式繁瑣且容易出錯,特別是對于大型項目而言,需要花
    的頭像 發(fā)表于 12-03 14:57 ?1685次閱讀

    Spring Boot 3.2支持虛擬線程和原生鏡像

    Spring Boot 3.2 前幾日發(fā)布,讓我們用 Java 21、GraalVM 和虛擬線程來嘗試一下。
    的頭像 發(fā)表于 11-30 16:22 ?671次閱讀

    springboot核心注解

    Spring Boot 是基于 Spring 框架的開源框架,它可以幫助開發(fā)者快速構建、部署和運行獨立的、生產級的 Spring 應用程序。Spri
    的頭像 發(fā)表于 11-23 09:23 ?481次閱讀

    Spring依賴注入的方式

    可維護性和可測試性。同時,Spring 提供了多種依賴注入的方式,以滿足不同場景下的需求。本文將詳細介紹 Spring 依賴注入的方式。 構造函數(shù)注入(Constructor Inje
    的頭像 發(fā)表于 11-22 15:12 ?443次閱讀

    Spring布能用來搭建基礎架構嗎

    Spring Boot 是一個用于簡化 Spring 應用程序開發(fā)的框架,它利用 Spring 框架的強大功能,使得基礎架構的搭建變得更加簡單、輕量級、易于維護。在本文中,我們將詳細討
    的頭像 發(fā)表于 11-16 10:56 ?362次閱讀