成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

用Go模擬實(shí)現(xiàn)單點(diǎn)登錄Token生成和驗(yàn)證解析

開(kāi)發(fā) 前端
資源服務(wù)端監(jiān)聽(tīng)本地的8081端口, 當(dāng)接收到用戶請(qǐng)求之后, 首先從請(qǐng)求頭中的Authorization字段獲取Token令牌, 并對(duì)令牌進(jìn)行解析, 如果正確解析出用戶ID, 返回該用戶的資源信息。

1.單點(diǎn)登錄(SSO)原理

單點(diǎn)登錄(Single Sign-On,簡(jiǎn)稱SSO)是一種身份驗(yàn)證和授權(quán)機(jī)制,允許用戶在訪問(wèn)多個(gè)相關(guān)獨(dú)立的系統(tǒng)或應(yīng)用程序時(shí)只需一次登錄, 而不需要為每個(gè)系統(tǒng)都提供單獨(dú)的身份驗(yàn)證憑證。SSO的目的是簡(jiǎn)化用戶體驗(yàn)、提高安全性, 并減少用戶因頻繁登錄而可能面臨密碼疲勞問(wèn)題。

SSO的工作原理涉及以下關(guān)鍵概念:

  • 身份提供者(Identity Provider, IdP): 負(fù)責(zé)驗(yàn)證用戶的身份并生成令牌(Token)。IdP通常是一個(gè)中心化的認(rèn)證系統(tǒng), 負(fù)責(zé)向其他相關(guān)系統(tǒng)提供認(rèn)證服務(wù)。
  • 服務(wù)提供者(Service Provider, SP): 各個(gè)系統(tǒng)或應(yīng)用程序, 它們依賴于IdP來(lái)驗(yàn)證用戶身份。SP接收到IdP頒發(fā)的令牌后, 可以通過(guò)驗(yàn)證令牌的有效性來(lái)信任用戶身份。
  • 令牌(Token): 由IdP頒發(fā), 包含有關(guān)用戶身份的信息, 以及可能的授權(quán)信息。
  • 單一登錄會(huì)話(Single Sign-On Session): 用戶只需一次登錄到IdP,然后就可以訪問(wèn)所有與IdP集成的SP, 而無(wú)需再次提供用戶名和密碼。

原理圖如下:

圖片圖片

2.JWT原理

JWT 是一種基于 JSON 格式的輕量級(jí)令牌,其主要原理是通過(guò)在服務(wù)端生成一個(gè)包含用戶信息的 JSON 對(duì)象,然后使用密鑰對(duì)該對(duì)象進(jìn)行簽名,生成一個(gè)令牌。這個(gè)令牌可以被發(fā)送到客戶端,客戶端可以在之后的請(qǐng)求中攜帶該令牌,服務(wù)端使用密鑰驗(yàn)證令牌的簽名,并解析其中的信息, 從而完成身份驗(yàn)證。

JWT 由三部分組成:Header(頭部)、Payload(負(fù)載)和 Signature(簽名)。

  • Header(頭部):包含了兩部分信息,token 的類型(JWT)和使用的簽名算法,通常是 Base64 編碼的 JSON 字符串。
  • Payload(負(fù)載):包含了一些聲明(Claim),其中包括標(biāo)準(zhǔn)聲明、私有聲明等。這部分也是 Base64 編碼的 JSON 字符串,用于攜帶一些關(guān)鍵的信息。
  • Signature(簽名):由前兩部分使用指定的算法簽名而成,用于驗(yàn)證消息的完整性。

JWT原理圖如下:

圖片圖片

3.使用Golang模擬實(shí)現(xiàn)過(guò)程

為了模擬單點(diǎn)登錄(SSO), 將創(chuàng)建兩個(gè)簡(jiǎn)單的Golang服務(wù): 一個(gè)用于認(rèn)證用戶(認(rèn)證中心), 另一個(gè)用于資源提供。用戶如果要獲取資源,必須先登錄認(rèn)證中心獲取令牌, 然后再通過(guò)令牌訪問(wèn)資源服務(wù)器, 下面是認(rèn)證中心的服務(wù)端實(shí)現(xiàn)代碼:

package main

import (
  "fmt"
  "net/http"
  "time"

  "github.com/dgrijalva/jwt-go"
)

var secretKey = []byte("btk.gqv7jtu7VZD1dar")

func main() {
  http.HandleFunc("/login", handleLogin)
  http.ListenAndServe(":8080", nil)
}

func handleLogin(w http.ResponseWriter, r *http.Request) {
  // 在實(shí)際應(yīng)用中,這里應(yīng)該有用戶認(rèn)證的邏輯,為了簡(jiǎn)化,這里直接使用一個(gè)固定用戶
  userID := "9527"
  tokenString, err := createToken(userID)
  if err != nil {
    http.Error(w, "創(chuàng)建令牌失敗", http.StatusInternalServerError)
    return
  }

  // 將 JWT 令牌附加到響應(yīng)中
  w.Header().Set("Authorization", "Bearer "+tokenString)
  w.WriteHeader(http.StatusOK)
  fmt.Fprintf(w, "登錄成功. Token: %s", tokenString)
}

func createToken(userID string) (string, error) {
  // 創(chuàng)建負(fù)載
  payload := jwt.MapClaims{
    "user": userID,
    "exptime": time.Now().Add(time.Minute * 15).Unix(), // 令牌過(guò)期時(shí)間為15分鐘
  }

  // 創(chuàng)建 Token
  token := jwt.NewWithClaims(jwt.SigningMethodHS256, payload)

  // 簽名并獲取完整的 Token 字符串
  tokenString, err := token.SignedString(secretKey)
  if err != nil {
    return "", err
  }

  return tokenString, nil
}

在上面的代碼中, 認(rèn)證中心服務(wù)端在本地監(jiān)聽(tīng)8080端口, 用來(lái)模擬處理用戶的登錄請(qǐng)求, 在收到用戶請(qǐng)求之后, 服務(wù)端根據(jù)用戶ID調(diào)用JWT的方法生成Token, 并將Token設(shè)置到HTTP頭的Authorization字段中返回給客戶端。

接下來(lái)實(shí)現(xiàn)資源提供的服務(wù)端,參考代碼如下:

package main

import (
  "fmt"
  "net/http"

  "github.com/dgrijalva/jwt-go"
)

var secretKey = []byte("btk.gqv7jtu7VZD1dar")

func main() {
  http.HandleFunc("/resource", handleResource)
  http.ListenAndServe(":8081", nil)
}

func handleResource(w http.ResponseWriter, r *http.Request) {
  // 從請(qǐng)求中獲取 Authorization 頭
  authHeader := r.Header.Get("Authorization")
  if authHeader == "" {
    http.Error(w, "未找到Authorization字段", http.StatusUnauthorized)
    return
  }

  // 解析JWT令牌
  tokenString := authHeader[len("Bearer "):]
  token, err := parseToken(tokenString)
  if err != nil || !token.Valid {
    http.Error(w, "令牌不合法", http.StatusUnauthorized)
    return
  }

  // 獲取負(fù)載信息
  claims, ok := token.Claims.(jwt.MapClaims)
  if !ok {
    http.Error(w, "令牌不合法", http.StatusUnauthorized)
    return
  }

  userID, ok := claims["user"].(string)
  if !ok {
    http.Error(w, "訪問(wèn)令牌中的用戶不存在", http.StatusUnauthorized)
    return
  }

  // 在實(shí)際應(yīng)用中,這里可以根據(jù) userID 獲取用戶信息或提供資源
  // 這里只是一個(gè)簡(jiǎn)單的示例
  response := fmt.Sprintf("用戶ID%s獲取資源成功!", userID)
  w.WriteHeader(http.StatusOK)
  fmt.Fprintf(w, response)
}

func parseToken(tokenString string) (*jwt.Token, error) {
  // 解析 Token 字符串
  token, err := jwt.Parse(tokenString, func(token *jwt.Token) (interface{}, error) {
    return secretKey, nil
  })

  if err != nil {
    return nil, err
  }

  return token, nil
}

在上面的代碼中, 資源服務(wù)端監(jiān)聽(tīng)本地的8081端口, 當(dāng)接收到用戶請(qǐng)求之后, 首先從請(qǐng)求頭中的Authorization字段獲取Token令牌, 并對(duì)令牌進(jìn)行解析, 如果正確解析出用戶ID, 返回該用戶的資源信息。

4.驗(yàn)證實(shí)現(xiàn)結(jié)果

將上面兩段代碼分別編譯成兩個(gè)獨(dú)立Server端,并開(kāi)啟兩個(gè)窗口分別運(yùn)行。首先請(qǐng)求SSO服務(wù)端, 返回結(jié)果如下:

圖片圖片

從上圖可知,SSO服務(wù)端成功返回了一個(gè)Token令牌, 下面先不用Token訪問(wèn)一下資源服務(wù)器試試:

圖片圖片

從上圖可以看到,沒(méi)有令牌無(wú)法正常請(qǐng)求到所需資源, 下面使用Apifox新建一個(gè)請(qǐng)求, 在里面加上Token, 如圖:

圖片圖片

保存之后, 帶著Token請(qǐng)求一下資源服務(wù)端, 如圖:

圖片圖片

可以看到, 成功返回了資源, 整個(gè)流程測(cè)試成功。



責(zé)任編輯:武曉燕 來(lái)源: 二進(jìn)制空間安全
相關(guān)推薦

2024-09-27 12:13:26

GoGTokenSSO

2016-12-26 18:05:00

單點(diǎn)登錄原理簡(jiǎn)單實(shí)現(xiàn)

2020-12-28 05:52:27

SSO登錄單點(diǎn)

2023-03-09 08:12:08

免登錄實(shí)Python腳本

2022-07-20 09:52:44

Go語(yǔ)言短信驗(yàn)證碼

2024-06-21 09:28:43

2023-12-31 16:44:30

2018-06-25 12:35:31

2023-08-29 08:00:38

2012-02-14 14:17:35

ibmdw

2021-06-24 08:52:19

單點(diǎn)登錄代碼前端

2022-01-26 07:01:00

開(kāi)源社區(qū)項(xiàng)目

2020-05-15 08:07:33

JWT登錄單點(diǎn)

2024-08-12 08:12:38

2024-12-06 07:00:00

2021-10-29 13:26:54

單點(diǎn)登錄SSO

2021-08-02 12:29:15

Python爬蟲(chóng)網(wǎng)站

2023-05-19 07:43:11

2024-03-01 11:33:31

2025-06-05 02:22:00

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 蜜桃传媒一区二区 | 欧美日韩手机在线观看 | 九九热这里只有精品6 | 精品自拍视频 | 国产观看 | 国产欧美日韩 | 国产激情在线播放 | 国产日韩欧美中文字幕 | 国产精品自拍一区 | 天天干天天爽 | 国产激情免费视频 | 亚洲免费一区二区 | 在线观看日本网站 | 免费在线观看一区二区 | 亚洲激情av| 99久久久99久久国产片鸭王 | 欧美在线观看一区二区 | 精品伦精品一区二区三区视频 | 亚洲精品久久区二区三区蜜桃臀 | 韩日在线视频 | 日韩在线观看精品 | 一区二区三区国产好 | 亚洲第一在线视频 | 国产精品爱久久久久久久 | 亚洲一区二区日韩 | 国产草草视频 | 91亚洲精品在线 | 午夜影晥| 国内精品久久久久 | 日韩精品久久一区二区三区 | 国产美女在线看 | 日本激情一区二区 | 九九看片 | 亚洲成人精品在线观看 | 国产91久久久久蜜臀青青天草二 | 国产aaaaav久久久一区二区 | 久久精品色视频 | 国产精品夜间视频香蕉 | 久久国产精品视频 | 免费精品国产 | 一区二区三区韩国 |