重新学习web后端开发-002-hello, world
UNIX is very simple, it just needs a genius to understand its simplicity. —— Dennis M.Ritchie
作者剛開始學習編程的時候,學習的就是C語言。寫的第一個入門例子就是在控制臺上打印一句“hello, world"。后來陸續接觸了php、java、python、go等語言,發現入門第一個例子都是打印"hello, world"。這已經成為了業內的慣例。那么我們也從這里開始。
<!-- more -->
1. 第一個接口
話不多說,直接上代碼
package mainimport ("github.com/gin-gonic/gin" )func main() {r := gin.Default()r.GET("/hello", func(c *gin.Context) {c.String(200, "hello, world")})r.GET("/helloJson", func(c *gin.Context) {c.JSON(200, gin.H{"code": 0, "msg": "", "body": "hello, world"})})r.Run(":9800") // listen and serve on 0.0.0.0:9800 }這段代碼非常簡潔明了,運行后將會在機器上綁定9800端口,映射了url "/hello"和"/helloJson",當通過瀏覽器訪=問"/hello"時,將在頁面上顯示hello, world,當訪問"/helloJson"時,則會顯示一個json串
{"body":"hello, world","code":0,"msg":""}Tip:
- 這兩個接口返回的區別一個返回的是字符串,一個返回的是json串。
- 這里使用了go著名的web開源框架gin,它簡潔小巧且性能不錯。
- go版本是1.11,沒有使用任何第三方包管理。當前go版本開始內置包管理工具:go module,但還不是非常成熟,期待后續版本能較好的解決包管理問題。因此,你需要先通過go get安裝gin包。具體請參考gin文檔。
- 可以直接clone git上的代碼,點此查看,分支為feature/001-hello_world
2. 看看背后發生的事
2.1 "/hello" web交互過程
打開chrome瀏覽器,并在地址欄輸入:http://localhost:9800/hello , 頁面將會顯示hello, world。實際上,我們向服務器9800端口發起了一個http請求,同時服務器返回了一個http響應。信息就在這類似”一問一答“的方式下進行傳輸交互。我們也可以使用chrome開發者工具,看一看具體傳輸的數據內容。
2.1.1 http請求
首先我們發起了了一個http請求,采用GET請求的方式,請求http://localhost:9800/hello ,請求的數據如下:
GET /hello HTTP/1.1 Host: localhost:9800 Connection: keep-alive Pragma: no-cache Cache-Control: no-cache Upgrade-Insecure-Requests: 1 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8 Accept-Encoding: gzip, deflate, br Accept-Language: en-US,en;q=0.9,zh-CN;q=0.8,zh;q=0.7<上面一行是一個空行CRLF, 同時請忽略本行的說明文字>根據http v1.1協議規范[RFC 7230],請求消息的格式為:
- 請求行 (例如: GET /hello HTTP/1.1)
- 請求頭 (例如: Host: localhost:9800)
- 一個空行,由CRLF,即回車(CR, ASCII 13, r) 換行(LF, ASCII 10, n)組成。
- 可選body消息
Tip:
- 請求行和請求頭必須要以CRLF結尾。
- 空行必須只包含CRLF,不能包含其它字符包括空格。
- 除去可選body消息外,其余三個部分都是必須要有的。
后續將會詳細介紹http請求的具體內容。
2.1.2 http響應
服務接收到請求后返回響應,響應消息如下:
HTTP/1.1 200 OK Content-Type: text/plain; charset=utf-8 Date: Tue, 15 Jan 2019 02:56:59 GMT Content-Length: 12hello, world根據http v1.1協議規范,響應消息格式為:
- 狀態行,包括狀態碼和簡單描述 (例如:HTTP/1.1 200 OK)
- 響應頭 (例如:Content-Type: text/plain; charset=utf-8)
- 一個空行
- 可選body消息
Tip:
- 狀態行和響應頭必須要以CRLF結尾。
- 空行必須只包含CRLF,不能包含其它字符包括空格。
2.2 "/helloJson" web交互過程
該接口返回的數據和"/hello"主要區別就是返回內容的格式不一樣,一個是純文本字符串,一個是json字符串。通過分析下http數據的交互,來了解下兩者之間的區別。
2.2.1 http請求
請求的部分除了GET部分,其它都一樣
GET /helloJson HTTP/1.1 ...2.2.2 http響應
HTTP/1.1 200 OK Content-Length: 41 Content-Type: application/json; charset=utf-8 Date: Wed, 16 Jan 2019 16:48:50 GMT{"body":"hello, world","code":0,"msg":""}響應的部分主要區別在響應頭的字段Content-Type的值不一樣。這里是:application/json; charset=utf-8,意思是告訴客戶端返回的數據內容格式為json,且編碼為utf-8
Tip: 當今主流的web后端開發,隨著前后端分離,主要就是接口開發,其主要使用的數據格式是JSON。無論從可讀性,支持語言廣泛、客戶端易于解析等方面來看,JSON是現在主流的數據交換格式之一。3. 小結
本節通過簡單的接口實例,介紹了背后http傳輸的基本信息。下一節開始,我們將詳細介紹作為web后端開發人員,必須要了解掌握的http協議的內容,以及在正式項目實踐中所需要關注的細節。
本文為作者原創作品,屬于《重新學習web后端開發》專輯中的一篇,轉載時請備注作者信息及來源。本文原文地址:https://www.donnyzhang.com/20... 《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的重新学习web后端开发-002-hello, world的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: import提升导致Fundebug报错
- 下一篇: linux 更新yum源 改成阿里云源