> 백엔드 개발 > Golang > golang JWT 프런트엔드를 확인하는 방법

golang JWT 프런트엔드를 확인하는 방법

풀어 주다: 2019-12-24 10:59:28
원래의
2307명이 탐색했습니다.

golang JWT 프런트엔드를 확인하는 방법

golang jwt 프론트엔드 검증 방법:

클라이언트가 요청 객체 헤더에 토큰 매개변수를 추가하여 서버로 보내면, 서버는 비교를 위해 토큰을 꺼냅니다.

계정이 존재하고 올바른지 확인하기 위해 로그인한 후 첫 번째 토큰 생성이 발생합니다. 사용자에게 토큰(암호화된 문자열)이 제공되고 토큰은 클라이언트가 성공적으로 로그인한 후 응답 헤더에 배치됩니다. , 응답에서 토큰을 꺼내고 후속 작업 요청에서 헤더에 토큰을 계속 추가합니다. 토큰 유효 기간이 만료된 후에는 다시 로그인해야만 새 토큰을 얻을 수 있습니다.

구현:

server_token이 생성되어 응답 헤더에 저장됩니다.
프런트 엔드에서 다음을 수락하고 가져옵니다. response.headers['x-auth-token']

import "github.com/fwhezfwhez/jwt"
func Login(c *gin.Context){
	...(验证身份正确)
	//获取token管理对象
	token := jwt.GetToken()
	//添加令牌关键信息
	token.AddPayLoad("userName", user.UserName).AddPayLoad("role", "admin").AddHeader("typ", "JWT").AddHeader("alg", "HS256")
	//添加令牌期限
	exp:=time.Now().Add(1*time.Hour)
	token.AddPayLoad("exp", strconv.FormatInt(exp.Unix(), 10))
	//获取令牌,并添加进reponse的header里
	jwts, _, erre := token.JwtGenerator(consts.Secret)
	if erre != nil {
		fmt.Println("token生成出错")
		return
	}
	fmt.Println("生成的jwt是:", jwts)
	c.Writer.Header().Add("x-auth-token", jwts)
	...
	}
로그인 후 복사

Client_로그인 요청 보내기

var Token string
func main(){
		...
		var content = fmt.Sprintf("userName=admin&password=123456")
		t1 := time.Now()
		resp, err := http.Post(host+"v1/POST/user/login", "application/x-www-form-urlencoded", strings.NewReader(content))
		Token =resp.Header.Get("x-auth-token")
		t2 := time.Now()
		fmt.Println(t2.Sub(t1))
		if err != nil {
			panic(err)
		}
		helpRead(resp)
		...
		}
로그인 후 복사

Client_Request 가져오기 기타 기능 목록

		...
		t1 := time.Now()

		//resp, err := http.Get(host + "v1/GET/mediums/list")
		client := &http.Client{}
		req, err := http.NewRequest("GET", "http://localhost:8087/v1/GET/mediums/list",nil)
		req.Header.Add("x-auth-token", Token)
		resp, err := client.Do(req)
		t2 := time.Now()
		fmt.Println(t2.Sub(t1))
		if err != nil {
			panic(err)
		}
		helpRead(resp)
		...
로그인 후 복사

Server_Token Verification

func main(){
	...
	router := gin.Default()
	//Login不需要令牌验证,所以写中间件前面
	router.POST(consts.LoginURL, userControl.Login)

	router.Use(Validate())
	//后续的监听都需要通过Validate()的验证
	router.GET(consts.GetMediumsURL, mediumControl.GetMediums)
	router.....
	...
	}
func Validate()gin.HandleFunc{
return func(c *gin.Context) {
		if JWTToken := c.Request.Header.Get("x-auth-token");JWTToken!=""{
			token :=jwt.GetToken()
			legal,err:=token.IsLegal(JWTToken,consts.Secret)
			if err!=nil{
				fmt.Println(err)
				c.Abort()
				c.JSON(200,consts.ResponseTokenValidateError)
				return
			}
			if !legal{
				c.Abort()
				c.JSON(200,consts.ResponseTokenValidateWrong)
				return
			}
			c.Next()
		}else{
			c.JSON(200, consts.ResponseTokenNotFound)
			c.Abort()
			return
		}
	}
}
로그인 후 복사

더 많은 golang 지식을 알고 싶다면 PHP 중국어 웹사이트 golang tutorial 칼럼을 주목해주세요.

위 내용은 golang JWT 프런트엔드를 확인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿