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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

構(gòu)建RESTful Web服務(wù)的過(guò)程

「Spring」認(rèn)證安全架構(gòu) ? 來(lái)源:「Spring」認(rèn)證安全架構(gòu) ? 作者:「Spring」認(rèn)證安全 ? 2022-09-06 15:47 ? 次閱讀

本指南將引導(dǎo)您完成使用 Spring 創(chuàng)建“Hello, World”RESTful Web 服務(wù)的過(guò)程。

你將建造什么

您將構(gòu)建一個(gè)接受 HTTP GET 請(qǐng)求的服務(wù)
http://localhost:8080/greeting

它將以 JSON 表示的問(wèn)候進(jìn)行響應(yīng),如以下清單所示:

{"id":1,"content":"Hello, World!"}復(fù)制

您可以在查詢字符串中使用可選name參數(shù)自定義問(wèn)候語(yǔ),如以下清單所示:

http://localhost:8080/greeting?name=User復(fù)制

name參數(shù)值覆蓋默認(rèn)值World并反映在響應(yīng)中,如以下清單所示:

{"id":1,"content":"Hello, User!"}復(fù)制

你需要什么

  • 約15分鐘
  • 最喜歡的文本編輯器或 IDE
  • JDK 1.8或更高版本
  • Gradle 4+或Maven 3.2+
  • 您還可以將代碼直接導(dǎo)入 IDE:
    • 彈簧工具套件 (STS)
    • IntelliJ IDEA

如何完成本指南

像大多數(shù) Spring入門(mén)指南一樣,您可以從頭開(kāi)始并完成每個(gè)步驟,也可以繞過(guò)您已經(jīng)熟悉的基本設(shè)置步驟。無(wú)論哪種方式,您最終都會(huì)得到工作代碼。

從頭開(kāi)始,請(qǐng)繼續(xù)從 Spring Initializr 開(kāi)始。

跳過(guò)基礎(chǔ)知識(shí),請(qǐng)執(zhí)行以下操作:

  • 下載并解壓縮本指南的源存儲(chǔ)庫(kù),或使用Git克隆它:git clone https://github.com/spring-guides/gs-rest-service.git
  • 光盤(pán)進(jìn)入gs-rest-service/initial
  • 繼續(xù)創(chuàng)建資源表示類。

完成后,您可以對(duì)照中的代碼檢查結(jié)果gs-rest-service/complete。

從 Spring Initializr 開(kāi)始

您可以使用這個(gè)預(yù)先初始化的項(xiàng)目并單擊 Generate 下載 ZIP 文件。此項(xiàng)目配置為適合本教程中的示例。

手動(dòng)初始化項(xiàng)目:

  1. 導(dǎo)航到https://start.spring.io。該服務(wù)提取應(yīng)用程序所需的所有依賴項(xiàng),并為您完成大部分設(shè)置。
  2. 選擇 Gradle 或 Maven 以及您要使用的語(yǔ)言。本指南假定您選擇了 Java。
  3. 單擊Dependencies并選擇Spring Web。
  4. 單擊生成。
  5. 下載生成的 ZIP 文件,該文件是根據(jù)您的選擇配置的 Web 應(yīng)用程序的存檔。

如果您的 IDE 具有 Spring Initializr 集成,您可以從您的 IDE 完成此過(guò)程。

你也可以從 Github 上 fork 項(xiàng)目并在你的 IDE 或其他編輯器中打開(kāi)它。

創(chuàng)建資源表示類

現(xiàn)在您已經(jīng)設(shè)置了項(xiàng)目和構(gòu)建系統(tǒng),您可以創(chuàng)建您的系統(tǒng) Web 服務(wù)。

從考慮服務(wù)交互開(kāi)始這個(gè)過(guò)程。

該服務(wù)將處理對(duì) 的GET請(qǐng)求/greeting,可以選擇name在查詢字符串中使用參數(shù)。該GET請(qǐng)求應(yīng)200 OK在表示問(wèn)候的正文中返回帶有 JSON 的響應(yīng)。它應(yīng)該類似于以下輸出:

{
    "id": 1,
    "content": "Hello, World!"
}復(fù)制

id字段是問(wèn)候語(yǔ)的唯一標(biāo)識(shí)符,是問(wèn)候語(yǔ)content的文本表示。

要對(duì)問(wèn)候表示建模,請(qǐng)創(chuàng)建一個(gè)資源表示類。為此,請(qǐng)?zhí)峁┮粋€(gè)普通的方法 Java 對(duì)象,其中包含用于idcontent數(shù)據(jù)的字段、構(gòu)造函數(shù)和訪問(wèn)器,如以下清單(來(lái)自
src/main/java/com/example/restservice/Greeting.java)所示:

package com.example.restservice;

public class Greeting {

	private final long id;
	private final String content;

	public Greeting(long id, String content) {
		this.id = id;
		this.content = content;
	}

	public long getId() {
		return id;
	}

	public String getContent() {
		return content;
	}
}

此應(yīng)用程序使用Jackson JSON庫(kù)將類型的實(shí)例自動(dòng)編組Greeting為 JSON。網(wǎng)絡(luò)啟動(dòng)器默認(rèn)包含 Jackson。

創(chuàng)建資源控制器

在 Spring 構(gòu)建 RESTful Web 服務(wù)的方法中,HTTP 請(qǐng)求由控制器處理。這些組件由@RestController注釋標(biāo)識(shí),GreetingController下面的清單 (from )通過(guò)返回類的新實(shí)例來(lái)
src/main/java/com/example/restservice/GreetingController.java處理GET請(qǐng)求:/greetingGreeting

package com.example.restservice;

import java.util.concurrent.atomic.AtomicLong;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class GreetingController {

	private static final String template = "Hello, %s!";
	private final AtomicLong counter = new AtomicLong();

	@GetMapping("/greeting")
	public Greeting greeting(@RequestParam(value = "name", defaultValue = "World") String name) {
		return new Greeting(counter.incrementAndGet(), String.format(template, name));
	}
}復(fù)制

這個(gè)控制器簡(jiǎn)潔明了,但引擎蓋下有很多事情要做。我們一步一步分解。

@GetMapping注釋確保 HTTP GET 請(qǐng)求/greeting映射到greeting()方法。

有其他 HTTP 動(dòng)詞的伴隨注釋(例如@PostMappingPOST)。還有一個(gè)@RequestMapping它們都源自的注釋,并且可以用作同義詞(例如@RequestMapping(method=GET))。

@RequestParam將查詢字符串參數(shù)的值綁定name到方法的name參數(shù)中greeting()。如果name請(qǐng)求中沒(méi)有參數(shù),則使用defaultValueof World。

方法體的實(shí)現(xiàn)創(chuàng)建并返回一個(gè)新Greeting對(duì)象,該對(duì)象具有idcontent基于下一個(gè)值的屬性,并使用 greetingcounter格式化給定的格式。nametemplate

傳統(tǒng) MVC 控制器和前面顯示的 RESTful Web 服務(wù)控制器之間的一個(gè)關(guān)鍵區(qū)別是 HTTP 響應(yīng)主體的創(chuàng)建方式。這個(gè) RESTful Web 服務(wù)控制器不是依靠視圖技術(shù)來(lái)執(zhí)行服務(wù)器端將問(wèn)候數(shù)據(jù)呈現(xiàn)為 HTML,而是填充并返回一個(gè)Greeting對(duì)象。對(duì)象數(shù)據(jù)將作為 JSON 直接寫(xiě)入 HTTP 響應(yīng)。

此代碼使用 Spring@RestController注釋,它將類標(biāo)記為控制器,其中每個(gè)方法都返回域?qū)ο蠖皇且晥D。它是同時(shí)包含@Controller和的簡(jiǎn)寫(xiě)@ResponseBody。

Greeting對(duì)象必須轉(zhuǎn)換為 JSON。感謝 Spring 的 HTTP 消息轉(zhuǎn)換器支持,您無(wú)需手動(dòng)進(jìn)行此轉(zhuǎn)換。因?yàn)镴ackson 2在類路徑上,所以會(huì)自動(dòng)選擇 Spring
MappingJackson2HttpMessageConverterGreeting實(shí)例轉(zhuǎn)換為 JSON。

@SpringBootApplication是一個(gè)方便的注釋,它添加了以下所有內(nèi)容:

  • @Configuration: 將類標(biāo)記為應(yīng)用程序上下文的 bean 定義源。
  • @EnableAutoConfiguration:告訴 Spring Boot 根據(jù)類路徑設(shè)置、其他 bean 和各種屬性設(shè)置開(kāi)始添加 bean。例如,如果spring-webmvc位于類路徑上,則此注釋將應(yīng)用程序標(biāo)記為 Web 應(yīng)用程序并激活關(guān)鍵行為,例如設(shè)置DispatcherServlet.
  • @ComponentScan: 告訴 Spring 在包中查找其他組件、配置和服務(wù)com/example,讓它找到控制器。

main()方法使用 Spring Boot 的SpringApplication.run()方法來(lái)啟動(dòng)應(yīng)用程序。您是否注意到?jīng)]有一行 XML?也沒(méi)有web.xml文件。這個(gè) Web 應(yīng)用程序是 100% 純 Java,您不必處理任何管道或基礎(chǔ)設(shè)施的配置。

構(gòu)建一個(gè)可執(zhí)行的 JAR

您可以使用 Gradle 或 Maven 從命令行運(yùn)行應(yīng)用程序。您還可以構(gòu)建一個(gè)包含所有必要依賴項(xiàng)、類和資源的單個(gè)可執(zhí)行 JAR 文件并運(yùn)行它。構(gòu)建可執(zhí)行 jar 可以在整個(gè)開(kāi)發(fā)生命周期、跨不同環(huán)境等中輕松地作為應(yīng)用程序交付、版本化和部署服務(wù)。

如果您使用 Gradle,則可以使用./gradlew bootRun. 或者,您可以使用構(gòu)建 JAR 文件./gradlew build,然后運(yùn)行 ?JAR 文件,如下所示:

java -jar build/libs/gs-rest-service-0.1.0.jar

如果您使用 Maven,則可以使用./mvnw spring-boot:run. 或者,您可以使用構(gòu)建 JAR 文件,./mvnw clean package然后運(yùn)行該 JAR 文件,如下所示:

java -jar 目標(biāo)/gs-rest-service-0.1.0.jar

此處描述的步驟創(chuàng)建了一個(gè)可運(yùn)行的 JAR。您還可以構(gòu)建經(jīng)典的 WAR 文件。

顯示記錄輸出。該服務(wù)應(yīng)在幾秒鐘內(nèi)啟動(dòng)并運(yùn)行。

測(cè)試服務(wù)

現(xiàn)在服務(wù)已經(jīng)啟動(dòng),訪問(wèn)
http://localhost:8080/greeting,您應(yīng)該會(huì)看到:

{"id":1,"content":"Hello, World!"}復(fù)制

通過(guò)訪問(wèn)提供name查詢字符串參數(shù)
http://localhost:8080/greeting?name=User。content請(qǐng)注意屬性的值如何從Hello, World!變?yōu)?span style="color:rgb(0,0,153);">Hello, User!,如以下清單所示:

{"id":2,"content":"Hello, User!"}復(fù)制

這一變化表明,@RequestParam安排在GreetingController按預(yù)期工作。該name參數(shù)已被賦予默認(rèn)值,World但可以通過(guò)查詢字符串顯式覆蓋。

還要注意id屬性是如何從1變?yōu)?的2。這證明您正在GreetingController跨多個(gè)請(qǐng)求處理同一個(gè)實(shí)例,并且其counter字段在每次調(diào)用時(shí)都按預(yù)期遞增。

概括

恭喜!您剛剛使用 Spring 開(kāi)發(fā)了一個(gè) RESTful Web 服務(wù)。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Web
    Web
    +關(guān)注

    關(guān)注

    2

    文章

    1269

    瀏覽量

    69617
  • spring
    +關(guān)注

    關(guān)注

    0

    文章

    340

    瀏覽量

    14368
  • Restful
    +關(guān)注

    關(guān)注

    0

    文章

    11

    瀏覽量

    3552
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    請(qǐng)問(wèn)LabVIEW通過(guò)無(wú)線WiFi采集數(shù)據(jù) 基于restful

    本帖最后由 eehome 于 2013-1-5 09:47 編輯 求助,有沒(méi)有兄弟做過(guò)相關(guān)的項(xiàng)目啊,labview編寫(xiě)一個(gè)程序作為一個(gè)web service,基于restful。 需要將采集到
    發(fā)表于 03-22 18:08

    編寫(xiě)restful

    求助,有沒(méi)有兄弟做過(guò)相關(guān)的項(xiàng)目啊,現(xiàn)在寫(xiě)了一個(gè)程序作為一個(gè)web service,基于restful。 需要將采集到的數(shù)據(jù)經(jīng)過(guò)wifi傳輸,數(shù)據(jù)傳輸想用到restful。有沒(méi)有推薦的自帶的re
    發(fā)表于 03-22 18:12

    基于ARM和Linux的嵌入式Web服務(wù)器的構(gòu)建及應(yīng)用

    摘要:本文主要研究了基于ARM和Linux的嵌入式Web服務(wù)器的構(gòu)建及應(yīng)用.隨著互聯(lián)網(wǎng)的飛速發(fā)展,越來(lái)越多的信息化產(chǎn)品需要接入互聯(lián)網(wǎng)并通過(guò)Web頁(yè)面進(jìn)行遠(yuǎn)程訪問(wèn)和控制,嵌入式
    發(fā)表于 11-05 06:07

    如何在ARM上構(gòu)建一個(gè)web服務(wù)

    本人現(xiàn)在在做ARM上構(gòu)建一個(gè)web服務(wù)器,就是將網(wǎng)頁(yè)放在這個(gè)服務(wù)器上,然后接入internet可以通過(guò)PC機(jī)上網(wǎng)訪問(wèn)即可。用的是C#編程,實(shí)際實(shí)現(xiàn)上還是有些模糊,希望有心人能教教俺,最
    發(fā)表于 10-28 10:55

    在4.3.1版的restful_server示例中找不到npm是怎么回事?

    /../front/web-demo/dist doesn't exit.Please run 'npm run build' inC:/esp-431/ws431/restful_server/main
    發(fā)表于 02-17 07:31

    基于TLA的Web服務(wù)組合研究

    隨著以Web服務(wù)為基礎(chǔ)的面向服務(wù)的體系結(jié)構(gòu)的發(fā)展,如何有效地組合自治的、分布的、不同功能的Web服務(wù)構(gòu)
    發(fā)表于 11-10 16:28 ?22次下載

    基于.NET的XML Web服務(wù)構(gòu)建

    以一個(gè)ShoppingAssistant案例的ASP.NET Web服務(wù)為例,構(gòu)建新的基于事件的編程模型,利用XmlSerializer類的XML串行化功能,將對(duì)象的內(nèi)容串行化到XML文件中,在
    發(fā)表于 03-21 10:46 ?16次下載

    構(gòu)建實(shí)戰(zhàn):Nginx+IIS構(gòu)筑Web服務(wù)器集群負(fù)載均衡

    構(gòu)建實(shí)戰(zhàn):Nginx+IIS構(gòu)筑Web服務(wù)器集群負(fù)載均衡
    發(fā)表于 09-05 10:56 ?4次下載
    <b class='flag-5'>構(gòu)建</b>實(shí)戰(zhàn):Nginx+IIS構(gòu)筑<b class='flag-5'>Web</b><b class='flag-5'>服務(wù)</b>器集群負(fù)載均衡

    Web服務(wù)推薦SOA系統(tǒng)

    為解決Web服務(wù)決策過(guò)程中新增信息多且信息不精確的問(wèn)題,提出一種基于Web服務(wù)推薦的面向服務(wù)體系
    發(fā)表于 02-24 14:59 ?0次下載
    <b class='flag-5'>Web</b><b class='flag-5'>服務(wù)</b>推薦SOA系統(tǒng)

    Web服務(wù)組合匹配框架研究

    在現(xiàn)有服務(wù)發(fā)現(xiàn)方法中,單一考慮原子服務(wù)服務(wù)組合的方式難以滿足用戶日益增長(zhǎng)的需求。針對(duì)該問(wèn)題,設(shè)計(jì)一個(gè)基于模型轉(zhuǎn)換的Web服務(wù)匹配框架。在
    發(fā)表于 03-05 13:35 ?0次下載
    <b class='flag-5'>Web</b><b class='flag-5'>服務(wù)</b>組合匹配框架研究

    ASP NET MVC和WEB與API的知識(shí)點(diǎn)總結(jié)

     一、理解WEB API:提供基于RESTful架構(gòu)的WEB服務(wù),通過(guò)HTTP請(qǐng)求方法(GET, PUT, POST, DELETE)映射到服務(wù)
    發(fā)表于 11-27 16:43 ?13次下載
    ASP NET MVC和<b class='flag-5'>WEB</b>與API的知識(shí)點(diǎn)總結(jié)

    基于Web云端應(yīng)用服務(wù)構(gòu)建等的齒輪云測(cè)量終端系統(tǒng)

    基于Web云端應(yīng)用服務(wù)構(gòu)建等的齒輪云測(cè)量終端系統(tǒng)
    發(fā)表于 06-30 11:39 ?9次下載

    如何使用Spring構(gòu)建REST服務(wù)(一)

    關(guān)于 REST 如何適應(yīng)微服務(wù)世界還有一個(gè)更大的討論,但是——對(duì)于本教程——讓我們看看構(gòu)建 RESTful 服務(wù)
    的頭像 發(fā)表于 07-28 15:59 ?939次閱讀

    如何使用Spring構(gòu)建REST服務(wù)(三)

    到目前為止,您擁有一個(gè)基于 Web 服務(wù)來(lái)處理涉及員工數(shù)據(jù)的核心操作。但這還不足以讓事情變得“RESTful”。
    的頭像 發(fā)表于 07-28 16:01 ?874次閱讀

    使用RESTful Web服務(wù)過(guò)程

    本指南將引導(dǎo)您完成創(chuàng)建使用#spring# #spring認(rèn)證# RESTful Web 服務(wù)的應(yīng)用程序的過(guò)程。
    的頭像 發(fā)表于 09-06 15:47 ?734次閱讀