## 一、web工作流程
* Web服務器的工作原理可以簡單地歸納為
客戶機通過TCP/IP協議建立到服務器的TCP連接
客戶端向服務器發送HTTP協議請求包,請求服務器里的資源文檔
服務器向客戶機發送HTTP協議應答包,如果請求的資源包含有動態語言的內容,那么服務器會調用動態語言的解釋引擎負責處理“動態內容”,并將處理得到的數據返回給客戶端
客戶機與服務器斷開。由客戶端解釋HTML文檔,在客戶端屏幕上渲染圖形結果
## 二、HTTP協議
* 超文本傳輸協議(HTTP,HyperText Transfer Protocol)是互聯網上應用最為廣泛的一種網絡協議,它詳細規定了瀏覽器和萬維網服務器之間互相通信的規則,通過因特網傳送萬維網文檔的數據傳送協議
* HTTP協議通常承載于TCP協議之上
## 三、HTTP服務端
~~~
package main
import (
"net/http"
"fmt"
)
func main() {
//第一個參數是匹配路徑
//第二個參數是響應事件
http.HandleFunc("/go", myHandler)
//監聽
http.ListenAndServe("127.0.0.1:8000", nil)
}
//ResponseWriter, *Request
//handle函數
func myHandler(w http.ResponseWriter, r *http.Request) {
fmt.Println(r.RemoteAddr, "連接成功")
fmt.Println("method=", r.Method)
//url /go
fmt.Println("url=", r.URL.Path)
fmt.Println("header=", r.Header)
fmt.Println("body =", r.Body)
w.Write([]byte("夠浪"))
}
~~~
## 四、HTTP服務端
~~~
package main
import (
"net/http"
"fmt"
"io"
)
func main() {
resp, err := http.Get("http://127.0.0.1:8000/go")
if err != nil {
fmt.Println(err)
return
}
fmt.Println(resp.Status)
defer resp.Body.Close()
fmt.Println("header=", resp.Header)
//緩沖
buf := make([]byte, 1024)
var tmp string
for {
//讀取服務端數據
n, err := resp.Body.Read(buf)
if err != nil && err != io.EOF {
fmt.Println(err)
return
}
if n == 0 {
fmt.Println("讀取內容完畢")
break
}
//累加讀取的內容
tmp += string(buf[:n])
}
fmt.Println("buf=", string(tmp))
}
~~~
測試服務器和測試端的時候,先啟動服務端
- 一、數組
- 二、切片
- 三、copy
- 四、MAP
- 五、結構體
- 六、結構體參數
- 七、面向”對象“
- 1、匿名字段
- 2、方法
- 3、包和封裝
- 4、接口
- 5、異常處理
- 八、Json
- 九、文件操作
- 1、寫文件
- 2、讀取文件內容
- 3、拷貝文件
- 十、反射
- 1、查看類型,字段和方法
- 2、查看匿名字段
- 3、修改基本類型的值
- 4、修改結構體的值
- 5、調用方法
- 十一、并發編程
- 1、并行和并發
- 2、協程
- 3、runtime包
- 5、channel的使用
- 6、close
- 7、定時器
- 8、select
- 9、協程同步鎖
- 十二、socket編程
- 十三、Http編程
- 十四、并發爬蟲和數據處理
- 1、簡易爬蟲實例
- 2、并發爬取圖片
- 3、讀文件中的數據
- 4、數據清洗
- 其他
- 1、推薦文章