99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

簡述后端應(yīng)用程序的工作原理

jf_78858299 ? 來源:IT大咖說 ? 作者:IT大咖說 ? 2023-05-05 16:45 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

后端應(yīng)用程序的工作原理

成功運行一個簡單的后端應(yīng)用程序后,接下來介紹后端應(yīng)用程序的工作原理。

一個Java后端應(yīng)用程序要想運行起來需要兩步,第一步是搭建Web應(yīng)用服務(wù)器,為后端應(yīng)用程序提供運行環(huán)境,第二步是把后端應(yīng)用程序放到Web應(yīng)用服務(wù)器上。

相應(yīng)地,后端應(yīng)用軟件的工作原理我們也分為兩部分來介紹。一部分是Web應(yīng)用服務(wù)器運行后端應(yīng)用程序,介紹Web應(yīng)用服務(wù)器與后端應(yīng)用程序的關(guān)系;另一部分是后端應(yīng)用程序處理接口請求,介紹后端應(yīng)用程序與接口請求端(如網(wǎng)頁、App等)的關(guān)系。在介紹這兩部分內(nèi)容之前,我們先介紹一下Java程序的運行原理。

注意:本小節(jié)默認以Tomcat作為Web應(yīng)用服務(wù)器軟件,以Java作為編程語言,以Spring Boot作為基礎(chǔ)框架。在介紹原理時會省略很多內(nèi)部細節(jié),我們只需要大體了解即可。

◆1.Java程序運行原理

編譯型語言通過專門的編譯器,一次性地將源代碼編譯成可執(zhí)行文件(機器碼),可執(zhí)行文件可直接運行在特定的平臺上。由于可執(zhí)行文件(機器碼)是根據(jù)特定平臺編譯而成的,所以運行效率較高,但是不能跨平臺使用。比較流行的編譯型語言有C和C++等。

解析型語言不需要編譯,但是在每次運行的時候都需要解析器把源碼翻譯成機器碼,即每個運行程序的機器都需要安裝一個解析器,解析器會根據(jù)自身平臺把源碼翻譯成對應(yīng)的機器碼。解析型語言具有跨平臺性,但是運行效率不高(每次運行都需要翻譯成機器碼)。比較流行的解析型語言有Python、Ruby和JavaScript等。

編譯型語言和解析型語言的對比如圖4.29所示。

圖4.29 編譯型語言與解析型語言

而Java比較特別一些,Java既是編譯型語言,又是解析型語言,因為Java既需要編譯器又需要解析器。Java具備跨平臺特性的同時,也比傳統(tǒng)的解析型語言運行效率要高。Java編寫的源碼經(jīng)過編譯器編譯之后,轉(zhuǎn)換成.class文件(字節(jié)碼,一種Java獨有的源碼與機器碼之間的格式)。這些.class文件中的字節(jié)碼在運行時需要解析器把字節(jié)碼翻譯成機器碼才能運行。Java的編譯運行過程如圖4.30所示。

注意:一般情況下,Java源碼編譯輸出的是.jar文件,而.class文件是.jar文件的主要部分。這里為了講解方便,省去了對.jar文件的描述。

圖4.30 Java編譯運行過程

Java的編譯器和解析器就是在4.1.2小節(jié)搭建Web應(yīng)用服務(wù)器中提到的JDK,想要編譯或者運行Java程序都需要安裝JDK。JDK的內(nèi)部結(jié)構(gòu)如圖4.31所示,它包含一些開發(fā)工具和JRE(Java Runtime Environment,運行環(huán)境),其中開發(fā)工具里有編譯器,而JRE是運行Java程序的環(huán)境。JRE包含JVM(JavaVirtual Machine,Java虛擬機)和一些基礎(chǔ)類庫,其中JVM包含解析器,負責翻譯字節(jié)碼等工作,而基礎(chǔ)庫類是Java調(diào)用操作系統(tǒng)功能的橋梁。

注意:如果只需要運行Java程序,那么可以單獨安裝JRE。JDK 9版本發(fā)布以后,不再提供單獨的JRE安裝包。由于引入了新技術(shù),JDK 9及后續(xù)版本的內(nèi)部也沒有了JRE(可以手動生成),而JVM是仍然存在的。這是因為JRE在運行Java程序時會加載所有的基礎(chǔ)類庫,這樣比較損耗資源,而JDK 9及后續(xù)版本在運行程序時是按需要加載基礎(chǔ)類庫的。

圖4.31 JDK內(nèi)部結(jié)構(gòu)

2.Web應(yīng)用服務(wù)器運行后端應(yīng)用程序

本小節(jié)以Tomcat作為Web應(yīng)用服務(wù)器軟件進行說明。Tomcat本身是一個Java程序,啟動Tomcat服務(wù)相當于啟動一個Java程序。那么,Tomcat是怎么運行后端應(yīng)用程序的?一個Java程序怎么運行另外一個Java程序呢?

首先,在Tomcat中運行的后端應(yīng)用程序是.war文件而不是.jar文件。.war文件與.jar文件不同,.war文件是Web模塊,其內(nèi)部除了編譯好的.class文件、依賴包和配置文件以外,還可以包含網(wǎng)頁資源(HTML、CSS文件等)和JSP動態(tài)網(wǎng)頁等。.war文件一般需要依賴Tomcat等Web應(yīng)用服務(wù)器軟件才能運行。

以4.1.3小節(jié)構(gòu)造一個簡單的后端應(yīng)用程序中的demo.war為例,Tomcat運行demo.war其實不是一個Java程序運行另外一個Java程序的關(guān)系,而是一個Java程序使用編譯好的.class文件的關(guān)系。更具體地說,當demo.war放到Tomcat的webapps文件夾中后,Tomcat會自動把demo.war解壓成demo目錄。解壓完成后,Tomcat會對demo進行解析并加載相關(guān)的.class文件。當接收到請求時,Tomcat會調(diào)用對應(yīng)的接口函數(shù)(TestController.java文件中的方法,見代碼4.11),經(jīng)由這些代碼處理后再將結(jié)果返回。Tomcat運行后端應(yīng)用程序的工作原理如圖4.32所示。

說明:Tomcat加載并引用.class文件利用了Java的反射機制。一般情況下,Java程序引用類文件只能在編寫代碼時通過import引用其他類文件,而Java反射機制是允許在運行狀態(tài)中通過給定類的名字加載指定類文件的。

Tomcat是通過圖4.21中ServletInitializer這個固定類名加載相關(guān)文件的。

圖4.32 Tomcat運行后端應(yīng)用程序的工作原理

最后值得一提的是,Tomcat運行后端應(yīng)用程序的工作原理其實是非常復(fù)雜的,特別是對相關(guān)文件加載的機制,本小節(jié)只對其做了最簡單的陳述,有興趣的讀者可以通過官方文檔和開源代碼進行更深入的研究。

◆3.后端應(yīng)用程序處理接口請求

發(fā)送一個請求至少需要明確4個部分:請求的URL、請求方式、請求數(shù)據(jù)的格式和請求數(shù)據(jù)。以4.1.3小節(jié)構(gòu)造一個簡單的后端應(yīng)用程序中的接口一為例,以Postman為測試工具,發(fā)送請求的設(shè)置如圖4.33所示。

圖4.33 接口一請求的設(shè)置

注意:當請求方式為GET時,則請求數(shù)據(jù)一般只能寫在URL里,如4.1.3小節(jié)構(gòu)造一個簡單的后端應(yīng)用程序中的接口二。

由圖4.33中請求的URL可知,請求是基于HTTP發(fā)送的。HTTP的通信過程如圖4.34所示,其中,不是每次請求都會做一次連接的建立與斷開,存在多次請求會共用一個連接通道的情況,這與HTTP版本和相關(guān)設(shè)置有關(guān)。

注意:接口請求一般是使用HTTP或HTTPS。HTTP是TCP/IP的應(yīng)用層協(xié)議,也就是說,HTTP其實只是在TCP/IP之上做了規(guī)則限定和封裝,其底層技術(shù)還是TCP/IP的相關(guān)技術(shù)。而HTTPS只是在HTTP的基礎(chǔ)上做了通信加密,暫且不對其進行介紹。

圖4.34 HTTP通信過程

在圖4.33所示的請求例子中,客戶端會以URL的IP地址和端口(127.0.0.1:8080)與Web應(yīng)用服務(wù)器建立連接。建立連接之后,客戶端會把剩下的信息(URL剩下的部分、請求方式、請求數(shù)據(jù)的格式、請求數(shù)據(jù))按照規(guī)則放到報文里,再把報文發(fā)送到Web應(yīng)用服務(wù)器上。發(fā)送的報文如代碼4.14所示。其中,報文由三部分組成,分別是請求行、報文頭信息和報文體。

·請求行:是報文的第一行,其由三部分組成,分別是請求方法、請求URL剩余的部分(除協(xié)議、IP地址、端口外)和HTTP版本。

·報文頭信息:其范圍是報文的第二行到空行。報文頭可以設(shè)置多個屬性,其作用是記錄相關(guān)的請求信息。其中,Conten-Type屬性對應(yīng)的是請求數(shù)據(jù)的格式。

·報文體:其范圍是空行到最后,對應(yīng)的是請求數(shù)據(jù)。需要注意的是,當請求方式為GET時,一般不使用報文體。因此4.1.3小節(jié)中的接口二的請求參數(shù)只能寫在URL中。

代碼4.14接口一的請求報文

POST /demo/test/test HTTP/1.1

Host: 127.0.0.1:8080

Content-Type: text/plain

{

"language":"chinese",

"text":"你好,世界"

}

當Web應(yīng)用服務(wù)器接收到請求的報文后,會對報文進行解析并轉(zhuǎn)換成對應(yīng)的Java對象。Web應(yīng)用服務(wù)器會根據(jù)報文的請求行(POST/demo/test/test)找到對應(yīng)的后端應(yīng)用程序并調(diào)用相應(yīng)的處理函數(shù)。

其中,請求行(POST/demo/test/test)會被分成兩段(/demo和POST/test/test)處理,Web應(yīng)用服務(wù)器會根據(jù)第一段(/demo)內(nèi)容找到對應(yīng)的后端應(yīng)用程序,demo對應(yīng)的是demo.war文件名。Web應(yīng)用服務(wù)器會根據(jù)第二段(POST/test/test)內(nèi)容調(diào)用后端應(yīng)用程序?qū)?yīng)的處理函數(shù),后端應(yīng)用程序?qū)?yīng)的標記如代碼4.15所示,其中,@RequestMapping("/test")標記了Controller的路徑,@RequestMapping(value="/test",method=RequestMethod.POST)標記了對應(yīng)方法的路徑和請求方式,函數(shù)create()的參數(shù)String requestParam會被自動注入請求的數(shù)據(jù)(報文體)中。

說明:Java中以@開頭的是Java注解,也稱為Java標注,其相當于一個標簽。@Request-Mapping、@Controller是Java Servlet標準中定義的注解。

代碼4.15接口一的代碼

@Controller

@RequestMapping("/test")

@RequestMapping(value="/test",method = RequestMethod.POST)

public JSONObject create(@RequestBody String requestParam) {

}

當代碼4.15的處理函數(shù)被執(zhí)行完畢之后,會把結(jié)果返回給Web應(yīng)用服務(wù)器,Web應(yīng)用服務(wù)器會把返回的Java對象轉(zhuǎn)換成HTTP報文,再把報文發(fā)送給客戶端。返回的報文如代碼4.16所示。其中,報文由三部分組成,分別是狀態(tài)行、報文頭信息和報文體。

圖4.35 接口一返回的結(jié)果

·狀態(tài)行:是報文的第一行,其由三部分組成,分別是HTTP版本、狀態(tài)碼和狀態(tài)碼描述。狀態(tài)碼及其信息一般是由Web應(yīng)用服務(wù)器自動填充的,如狀態(tài)碼為200,即為成功,狀態(tài)碼為404,即為無法尋找對應(yīng)資源等。當然,后端應(yīng)用程序也可以對其進行修改。

·報文頭信息:其范圍是報文的第二行到空行。報文頭可以設(shè)置多個屬性,作用是記錄相關(guān)的請求信息。其中,Conten-Type屬性對應(yīng)的是請求數(shù)據(jù)的格式。后端應(yīng)用程序也可以添加一些自定義的屬性。

·報文體:其范圍是空行到最后,對應(yīng)的是后端應(yīng)用程序的處理函數(shù)返回的結(jié)果。

代碼4.16接口一返回的報文

HTTP/1.1 200 OK

Date: Tue, 31 Mar 2020 10:59:51 GMT

Content-Type: application/json

{"message":"你好,世界"}

以上介紹了后端應(yīng)用程序的工作原理,當然這只是一些表面的認識,還有很多內(nèi)容沒有鋪開陳述。這是因為在實際項目開發(fā)過程中,無論是HTTP請求還是Web應(yīng)用服務(wù)器軟件,都是現(xiàn)成的工具,我們多是去使用它們而不是去改造它們,因此對原理的了解不需要完全透徹,具體的細節(jié)可以等問題出現(xiàn)時再去了解。

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

    關(guān)注

    2

    文章

    1287

    瀏覽量

    71472
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    13

    文章

    9797

    瀏覽量

    88029
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    2989

    瀏覽量

    109933
  • 后端
    +關(guān)注

    關(guān)注

    0

    文章

    32

    瀏覽量

    2403
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    BootLoader程序工作原理是什么?怎么使用這個程序?

    BootLoader程序工作原理是什么?怎么使用這個程序?
    發(fā)表于 11-09 06:16

    什么是晶閘管?簡述晶閘管的工作原理

    保持導(dǎo)通,即晶閘管導(dǎo)通后,門極失去作用。門極只起觸發(fā)作用。  4. 晶閘管在導(dǎo)通情況下,當主回路電壓(或電流)減小到接近于零時,晶閘管關(guān)斷。晶閘管的工作原理:  晶閘管在工作過程中,它的陽極(A)和陰極
    發(fā)表于 02-22 15:40

    磁盤碎片整理的工作原理是什么?

    磁盤碎片整理的工作原理是什么? “磁盤碎片整理”這個術(shù)語通常用于指代Microsoft Windows中稱為磁盤碎片整理程序應(yīng)用程序。它的設(shè)計目的是解決一個由于硬盤存儲
    發(fā)表于 07-30 08:17 ?4397次閱讀

    蓄電池工作原理簡述

    蓄電池工作原理簡述   鉛酸蓄電池充、放電化學(xué)反應(yīng)的原理方程式如下: 1.放電:蓄電池對
    發(fā)表于 11-16 14:17 ?1.8w次閱讀

    Windows XP SP2防火墻的工作原理

    Windows XP SP2防火墻的工作原理 ★Windows XP SP2防火墻的工作原理  對于只使用瀏覽、電子郵件等系統(tǒng)自帶的網(wǎng)絡(luò)應(yīng)用程序,Windows防火墻根本
    發(fā)表于 01-11 11:41 ?1699次閱讀

    電腦芯片的工作原理簡述

    本文為您講述電腦芯片的工作原理,包括電腦芯片的基本構(gòu)成與工作邏輯,基礎(chǔ)參數(shù)。希望能提供大家參考:
    發(fā)表于 08-09 16:39 ?2.8w次閱讀

    基于區(qū)塊鏈的應(yīng)用程序“DApp”介紹

    DApps是分散式應(yīng)用程序的縮寫。這些應(yīng)用程序實際上不應(yīng)該對最終用戶進行區(qū)分。關(guān)于DApps的重要之處在于后端是如何處理數(shù)據(jù)的。
    發(fā)表于 09-05 14:37 ?3791次閱讀

    USB接口工作原理_USB接口優(yōu)點

    簡述USB接口工作原理”由電蜂優(yōu)選為您整理,采購連接器,上電蜂優(yōu)選。
    發(fā)表于 06-10 10:52 ?9349次閱讀

    存儲程序工作原理是什么

    要想搞清楚存儲程序工作原理,最好先知道它是存儲在了什么地方,或者說,應(yīng)當先搞清楚存儲工作的物質(zhì)基礎(chǔ)是什么。
    發(fā)表于 06-13 15:23 ?7635次閱讀

    應(yīng)用程序屏蔽和應(yīng)用程序內(nèi)保護哪個更安全?

    眾所周知,攻擊者往往會使用用戶移動設(shè)備上運行的應(yīng)用程序來攻擊后端的系統(tǒng),比如攻擊者利用移動操作系統(tǒng)和你的應(yīng)用程序中的漏洞來監(jiān)視你,獲取私人數(shù)據(jù)甚至竊取資金。為了應(yīng)對這種情況,許多移動應(yīng)用程序
    的頭像 發(fā)表于 08-26 16:02 ?4632次閱讀

    MMU的工作原理梳理

    本文從內(nèi)存管理的發(fā)展歷程角度層層遞進,介紹 MMU 的誕生背景,工作機制。而忽略了具體處理器的具體實現(xiàn)細節(jié),將 MMU 的工作原理從概念上比較清晰的梳理了一遍。 MMU 誕生之前:在傳統(tǒng)的批處理
    的頭像 發(fā)表于 12-17 16:13 ?1.4w次閱讀
    MMU的<b class='flag-5'>工作原理</b>梳理

    前端與后端編程有什么區(qū)別

    什么是web開發(fā)?Web開發(fā)是創(chuàng)建網(wǎng)站或Web應(yīng)用程序的過程。我們可以將其分為兩個主要層:前端開發(fā)和后端開發(fā)。 每個網(wǎng)站都有后端和前端。
    的頭像 發(fā)表于 05-05 18:19 ?2028次閱讀

    springboot前后端交互流程

    Spring Boot 是一個用于構(gòu)建 Java 企業(yè)級應(yīng)用程序的開源框架,它提供了一種簡化的開發(fā)方式,使得開發(fā)人員可以更加便捷地創(chuàng)建獨立的、可執(zhí)行的 Spring 應(yīng)用程序。在使用 Spring
    的頭像 發(fā)表于 11-22 16:00 ?3223次閱讀

    Spring MVC的工作原理

    Spring MVC是一種基于Java的Web應(yīng)用程序框架,它采用了Model-View-Controller(MVC)設(shè)計模式來分離應(yīng)用程序的不同方面。Spring MVC的工作原理涉及多個關(guān)鍵
    的頭像 發(fā)表于 12-03 11:49 ?1220次閱讀

    氣壓制動系統(tǒng)工作原理簡述

    氣壓制動系統(tǒng)的工作原理可以簡述如下: 一、系統(tǒng)概述 氣壓制動系統(tǒng)是一種通過壓縮空氣來實現(xiàn)制動的技術(shù),廣泛應(yīng)用于汽車行業(yè)中,特別是大型商用車和重型車輛。該系統(tǒng)利用發(fā)動機驅(qū)動的空氣壓縮機產(chǎn)生壓縮空氣,并
    的頭像 發(fā)表于 09-18 15:44 ?2054次閱讀