[Go]處理請求

閱讀時間約 13 分鐘

Request內容

package main

import (
"fmt"
"log"
"net/http"
"strings"
)

func request(w http.ResponseWriter, r *http.Request) {
//這些資訊是輸出到伺服器端的列印訊息
fmt.Println("Request解析")
//HTTP方法
fmt.Println("method", r.Method)
//RequestURI是被客戶端傳送到服務端的請求的請求行中未修改的請求URI
fmt.Println("RequestURI:", r.RequestURI)
//URL類型,下方分別列出URL的各成員
fmt.Println("URL_path", r.URL.Path)
fmt.Println("URL_RawQuery", r.URL.RawQuery)
fmt.Println("URL_Fragment", r.URL.Fragment)
//協定版本
fmt.Println("proto", r.Proto)
fmt.Println("protomajor", r.ProtoMajor)
fmt.Println("protominor", r.ProtoMinor)
//HTTP請求的頭域
for k, v := range r.Header {
for _, vv := range v {
fmt.Println("header key:" + k + " value:" + vv)
}
}
//判斷是否multipart方式
isMultipart := false
for _, v := range r.Header["Content-Type"] {
if strings.Index(v, "multipart/form-data") != -1 {
isMultipart = true
}
}
//解析body
if isMultipart == true {
r.ParseMultipartForm(128)
fmt.Println("解析方式:ParseMultipartForm")
} else {
r.ParseForm()
fmt.Println("解析方式:ParseForm")
}
//body內容長度
fmt.Println("ContentLength", r.ContentLength)
//是否在回覆請求後關閉連接
fmt.Println("Close", r.Close)
//HOSt
fmt.Println("host", r.Host)
//該請求的來源位址
fmt.Println("RemoteAddr", r.RemoteAddr)

fmt.Fprintf(w, "hello, let's go!")
//這個寫入到w的是輸出到客戶端的
}
func main() {
http.HandleFunc("/hello", request)
err := http.ListenAndServe(":8081", nil)
if err != nil {
log.Fatal("ListenAndServe:", err)
}
}


URL內容

package main

import "net/url"

func main() {
path := "http://lcoalhost:8082/article?id=1"
p, _ := url.Parse(path) // 解析url
println(p.Host)//lcoalhost:8082
println(p.User)//0x0
println(p.RawQuery)//id=1
println(p.RequestURI())///article?id=1
}


請求的內容

package main

import (
"fmt"
"net/http"
)

func getBody(w http.ResponseWriter, r *http.Request) {
//取得請求訊息的內容長度
len := r.ContentLength
//新建一個位元組切片,長度與請求封包的內容長度相同
body := make([]byte, len)
//讀取r的請求主體,並將具體內容讀入body中
r.Body.Read(body)
//將位元組切片內容寫入對應報文
fmt.Fprintln(w, string(body))
}
func main() {
http.HandleFunc("/getBody", getBody)
err := http.ListenAndServe(":8082", nil)
if err != nil {
fmt.Println(err)
}
}


Form與PostForm

package main

import (
"fmt"
"html/template"
"io/ioutil"
"net/http"
)

func process(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" {
t, _ := template.ParseFiles("form.html")
t.Execute(w, nil)
} else {
r.ParseForm()//語法分析
fmt.Fprintln(w, "表單鍵值對和URL鍵值對:", r.Form)
fmt.Fprintln(w, "表單鍵值對:", r.PostForm)
}
}

func main() {
http.HandleFunc("/", process)
http.ListenAndServe(":8089", nil)
}


MultipartForm

package main

import (
"fmt"
"html/template"
"io/ioutil"
"net/http"
)

func multiProcess(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" {
t, _ := template.ParseFiles("form.html")
t.Execute(w, nil)
} else {
r.ParseMultipartForm(1024)//從表單中提取多少位元組的數據
fmt.Fprintln(w,"表单键值对:", r.MultipartForm)
}
}

func main() {
http.HandleFunc("/", multiProcess)
http.ListenAndServe(":8089", nil)
}


上傳檔案

package main

import (
"fmt"
"html/template"
"io/ioutil"
"net/http"
)

//上傳
func upload(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" {
t, _ := template.ParseFiles("upload.html")
t.Execute(w, nil)
} else {
r.ParseMultipartForm(4096)
fileHeader := r.MultipartForm.File["uploaded"][0]//取得名為"uploaded"的第一個檔案頭

file, err := fileHeader.Open()//取得文件
if err != nil {
fmt.Println("error")
return
}
data, err := ioutil.ReadAll(file)//讀取文件
if err != nil {
fmt.Println("error!")
return
}
fmt.Fprintln(w, string(data))
}
}

func main() {
http.HandleFunc("/", upload)
http.ListenAndServe(":8089", nil)
}


WriteHeader()與Header()

package main

import (
"fmt"
"net/http"
)

func Redirect(w http.ResponseWriter, r *http.Request) {
//設定一個301重定向
w.Header().Set("Location", "https://www.xxx.com")
w.WriteHeader(301)
}

func main() {
http.HandleFunc("/redirect", Redirect)
err := http.ListenAndServe(":8086", nil)
if err != nil {
fmt.Println(err)
}
}

這邊要注意w.Header().Set()與w.WriteHeader()的使用順序。


Write()

字串

package main

import (
"fmt"
"net/http"
)

func Welcome(w http.ResponseWriter, r *http.Request) {
w.Write([]byte("Go go!"))
}

func main() {
http.HandleFunc("/welcome", Welcome)
err := http.ListenAndServe(":8086", nil)
if err != nil {
fmt.Println(err)
}
}


HTML

package main

import (
"fmt"
"net/http"
)

func Home(w http.ResponseWriter, r *http.Request) {
html := `<html>
<head>
<title>Write()內容為HTML</title>
</head>
<body>
<h1>Go go go
</body>
</html>`
w.Write([]byte(html))
}

func main() {
http.HandleFunc("/", Home)
err := http.ListenAndServe(":8086", nil)
if err != nil {
fmt.Println(err)
}
}


JSON

package main

import (
"encoding/json"
"fmt"
"net/http"
)

type JsonData struct {
Message string `json:"message"`
}
func Hello(w http.ResponseWriter, r *http.Request) {
//返回JSON格式
jsonData := JsonData{
"Go go",
}
message, _ := json.Marshal(jsonData)
w.Header().Set("Content-Type", "application/json")
w.Write(message)
}

func main() {
http.HandleFunc("/", Hello)
err := http.ListenAndServe(":8086", nil)
if err != nil {
fmt.Println(err)
}
}





avatar-img
8會員
123內容數
嗨,我是一名程式設計師,會在這分享開發與學習紀錄。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
小黑與程式的邂逅 的其他內容
ServeMux ServeMux是一個包含映射的結構,映射會將URL映射到對應的伺服器。 DefaultServeMux DefaultServeMux是net/HTTP中預設的多工器,是ServeMux的實例。多工器要根據URL的請求導向到不同的伺服器。DefaultServeMux是
HTTP伺服器端 package main import ( "net/http" ) type Refer struct { handler http.Handler refer string } //實現中介軟體邏輯​ func (this *Refer) ServeHTTP(
ServeMux ServeMux是一個包含映射的結構,映射會將URL映射到對應的伺服器。 DefaultServeMux DefaultServeMux是net/HTTP中預設的多工器,是ServeMux的實例。多工器要根據URL的請求導向到不同的伺服器。DefaultServeMux是
HTTP伺服器端 package main import ( "net/http" ) type Refer struct { handler http.Handler refer string } //實現中介軟體邏輯​ func (this *Refer) ServeHTTP(
你可能也想看
Google News 追蹤
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
※ 原本狀態:伺服器渲染 這是 MVC 架構下的 request / response 示意圖,在這張圖呈現的架構裡,畫面和資料都由同一個架構處理。 伺服器渲染流程: 瀏覽器針對特定網址送出請求。 路由器解析請求後,轉接給對應的 controller。 controller 按照要求,透過
Thumbnail
利用文字紀錄,明確寫下自己的採購項目......
xhr 在下面的例子裡,我們首先建立了一個 XMLHttpRequest 物件,並使用 .open() 開啟一個 URL,最後使用 .send() 發出 request。 具體來說步驟有四個: 建立XMLHttpReque 開啟一個請求。 送出請求。 拿到回應後去處理畫面要如何呈現。
發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文
Thumbnail
先前幾篇筆記介紹了網路請求,瀏覽器儲存資料的方式,那麼實務上,前端最常需要發送網路請求的時候,就是透過呼叫 API,去向後端工程師發送/請求資料,所以今天來記錄什麼是 API吧!
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
※ 原本狀態:伺服器渲染 這是 MVC 架構下的 request / response 示意圖,在這張圖呈現的架構裡,畫面和資料都由同一個架構處理。 伺服器渲染流程: 瀏覽器針對特定網址送出請求。 路由器解析請求後,轉接給對應的 controller。 controller 按照要求,透過
Thumbnail
利用文字紀錄,明確寫下自己的採購項目......
xhr 在下面的例子裡,我們首先建立了一個 XMLHttpRequest 物件,並使用 .open() 開啟一個 URL,最後使用 .send() 發出 request。 具體來說步驟有四個: 建立XMLHttpReque 開啟一個請求。 送出請求。 拿到回應後去處理畫面要如何呈現。
發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文內容發文
Thumbnail
先前幾篇筆記介紹了網路請求,瀏覽器儲存資料的方式,那麼實務上,前端最常需要發送網路請求的時候,就是透過呼叫 API,去向後端工程師發送/請求資料,所以今天來記錄什麼是 API吧!