婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解Golang實現http重定向https的方式

詳解Golang實現http重定向https的方式

熱門標簽:江西轉化率高的羿智云外呼系統 南通如皋申請開通400電話 廣州呼叫中心外呼系統 浙江高速公路地圖標注 西部云谷一期地圖標注 高德地圖標注口訣 地圖標注的汽車標 學海導航地圖標注 中國地圖標注省會高清

以前寫代碼時,都是直接將程序綁定到唯一端口提供http/https服務,在外層通過反向代理(nginx/caddy)來實現http和https的切換。隨著上線后的服務越來越多,有一些服務無法直接通過反向代理來提供這種重定向,只能依靠代碼自己實現。所以簡要記錄一下如何在代碼中實現http到https的重定向。

分析

無論是反向代理還是代碼自己實現,問題的本質都是判斷請求是否是https請求。 如果是則直接處理,如果不是,則修改請求中的url地址,同時返回客戶端一個重定向狀態碼(301/302/303/307)。但如果仔細分析的話,會衍生出另外的問題,返回哪個重定向碼是合理的?

這個問題展開討論,估計要寫滿滿一大頁,可能還得不出結論。 因此這里就不糾結到底返回哪個了,我使用的是307.

實現

如何我們從問題出現的場景開始分析,基本可以得出一個結論: 在需要轉換的場景中,都是用戶習慣性的首先發出了http請求,然后服務器才需要返回一個https的重定向。 因此實現的第一步就是創建一個監聽http請求的端口:

go http.ListenAndServe(":8000", http.HandlerFunc(redirect))

8000端口專門用來監聽http請求,不能阻塞https主流程,因此單獨扔給一個協程來處理。 redirect用來實現重定向:

func redirect(w http.ResponseWriter, req *http.Request) { 
  _host := strings.Split(req.Host, ":")
  _host[1] = "8443"

  target := "https://" + strings.Join(_host, ":") + req.URL.Path
  if len(req.URL.RawQuery) > 0 {
    target += "?" + req.URL.RawQuery
  }

  http.Redirect(w, req, target, http.StatusTemporaryRedirect)
}

8443是https監聽的端口。 如果監聽默認端口443,那么就可加可不加。 最后調用sdk中的Redirect函數封裝Response。

處理完重定向之后,再處理https就變得很容易了:

router := mux.NewRouter() 
  router.Path("/").HandlerFunc(handleHttps)
  c := cors.New(cors.Options{
    AllowedOrigins:  []string{"*.devexp.cn"},
    AllowedMethods:  []string{"HEAD", "GET", "POST", "PUT", "PATCH", "DELETE", "OPTIONS"},
    AllowedHeaders:  []string{"*"},
    AllowCredentials: true,
    Debug:      false,
    AllowOriginFunc: func(origin string) bool {
      return true
    },
  })

  handler := c.Handler(router)
  logrus.Fatal(http.ListenAndServeTLS(":8443", "cert.crt", "cert.key", handler))

完整代碼如下:

package main

import ( 
  "github.com/gorilla/mux"
  "github.com/rs/cors"
  "github.com/sirupsen/logrus"
  "net/http"
  "encoding/json"
  "log"
  "strings"
)

func main() { 
  go http.ListenAndServe(":8000", http.HandlerFunc(redirect))

  router := mux.NewRouter()
  router.Path("/").HandlerFunc(handleHttps)
  c := cors.New(cors.Options{
    AllowedOrigins:  []string{"*.devexp.cn"},
    AllowedMethods:  []string{"HEAD", "GET", "POST", "PUT", "PATCH", "DELETE", "OPTIONS"},
    AllowedHeaders:  []string{"*"},
    AllowCredentials: true,
    Debug:      false,
    AllowOriginFunc: func(origin string) bool {
      return true
    },
  })

  handler := c.Handler(router)
  logrus.Fatal(http.ListenAndServeTLS(":8443", "cert.crt", "cert.key", handler))
}

func redirect(w http.ResponseWriter, req *http.Request) { 
  _host := strings.Split(req.Host, ":")
  _host[1] = "8443"

  // remove/add not default ports from req.Host
  target := "https://" + strings.Join(_host, ":") + req.URL.Path
  if len(req.URL.RawQuery) > 0 {
    target += "?" + req.URL.RawQuery
  }
  log.Printf("redirect to: %s", target)
  http.Redirect(w, req, target,
    // see @andreiavrammsd comment: often 307 > 301
    http.StatusTemporaryRedirect)
}

func handleHttps(w http.ResponseWriter, r *http.Request) { 
  json.NewEncoder(w).Encode(struct {
    Name string
    Age  int
    Https bool
  }{
    "lala",
    11,
    true,
  })
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • golang flag簡單用法
  • Golang中定時器的陷阱詳解
  • 在golang中操作mysql數據庫的實現代碼
  • golang設置http response響應頭與填坑記錄
  • Golang學習之平滑重啟
  • Golang編譯器介紹

標簽:保定 常州 東營 德宏 曲靖 貴州 吐魯番 許昌

巨人網絡通訊聲明:本文標題《詳解Golang實現http重定向https的方式》,本文關鍵詞  詳解,Golang,實現,http,重定向,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Golang實現http重定向https的方式》相關的同類信息!
  • 本頁收集關于詳解Golang實現http重定向https的方式的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 固安县| 衡阳市| 宣威市| 武夷山市| 池州市| 墨玉县| 右玉县| 东莞市| 黑水县| 昌乐县| 新和县| 宁波市| 东丽区| 永登县| 鄂温| 鞍山市| 修水县| 英德市| 塔城市| 元朗区| 江源县| 遵义县| 辽阳市| 常宁市| 香河县| 邹城市| 三江| 内乡县| 金堂县| 垦利县| 壶关县| 日土县| 新干县| 油尖旺区| 双牌县| 美姑县| 永济市| 正宁县| 麟游县| 陇南市| 县级市|