JWTの検証を行いたいのですが、正しいTokenを入れてPostmanでリクエストを送ると、
Could not get any response
が出力されます。
具体的にはGET http://localhost:1323/jwt
に
Authorization: Bear ...
で不適切なトークンを入れたい場合。
json
1{ 2 "message": "invalid or expired jwt" 3}
と返されますが、先ほどの通り、正しいTokenを入れると、Could not get any response
と返されてしまいます。
理想はDemoWithJwtが呼ばれるのですが、実際に呼ばれず。
原因をご教授願いたいです。<(_ _)>
go
1package main 2 3import ( 4 "pretinder/server" 5) 6 7func main() { 8 server.RunSever() 9}
go
1package server 2 3import ( 4 "fmt" 5 "github.com/labstack/echo" 6 echoMiddle "github.com/labstack/echo/middleware" 7 "pretinder/server/handler" 8 "pretinder/server/middleware" 9) 10 11func bodyDumpHandler(c echo.Context, reqBody, resBody []byte) { 12 fmt.Printf("Request Body: %v\n", string(reqBody)) 13 fmt.Printf("Response Body: %v\n", string(resBody)) 14} 15 16func RunSever() { 17 e := echo.New() 18 e.Use(echoMiddle.Logger()) 19 e.Use(echoMiddle.BodyDump(bodyDumpHandler)) 20 e.GET("/demo", handler.Demo, middleware.Demo) 21 e.GET("/jwt", handler.DemoWithJwt, middleware.CheckJwt) 22 e.Logger.Fatal(e.Start(":1323")) 23}
go
1 2package middleware 3 4import ( 5 "fmt" 6 "github.com/SermoDigital/jose/crypto" 7 "github.com/labstack/echo" 8 "github.com/labstack/echo/middleware" 9) 10 11func CheckJwt(next echo.HandlerFunc) echo.HandlerFunc { 12 fmt.Println("Start function:CheckJwt") 13 publicPemKey := `-----BEGIN PUBLIC KEY----- 14MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAo+uA1EOMbOaHEb3H3RdL 154+9RYN1Q6+yXr/iSx5Fr/Y1//0VG4HxvYb6KcG5km/rMkB5xD+m2NFXW3aA+wHVu 16G8Uv8dAHuZ4bGVaCtVk7NqtKibAJoPXURHoQqCm6EqbHy+xNkprNdnMKMvDQ7M8Z 17WTL2en9t0Z6uHNaA6d7BnnewfUV3SUOayi5iNlbJrB21hyeBHnGzKeJqMM2L+BxQ 18vNZcyMoLBs9gSAcWVtgm6Ysuzs43KN3w8rn2Su/lYUKuzrbW7mNMj3JuRdQqP++x 19vJcx5rxAhAS0OrOd3kNmHWFK45cMpLNLsk1Tm7jIPTC5+OuGiDuF0fOxTonGOdxQ 20MwIDAQAB 21-----END PUBLIC KEY-----` 22 publicKey, _ := crypto.ParseRSAPublicKeyFromPEM([]byte(publicPemKey)) 23 24 config := middleware.JWTConfig{ 25 Skipper: func(c echo.Context) bool { 26 print("Skipper") 27 return false 28 }, 29 ContextKey: "user", 30 SigningKey: publicKey, 31 SigningMethod: "RS256", 32 TokenLookup: "header:" + echo.HeaderAuthorization, 33 } 34 35 fmt.Println("CheckJwt return") 36 return middleware.JWTWithConfig(config)(next) 37} 38
go
1package handler 2 3import ( 4 "fmt" 5 "github.com/dgrijalva/jwt-go" 6 "github.com/labstack/echo" 7 "net/http" 8) 9 10func DemoWithJwt(c echo.Context) error { 11 fmt.Println("run?") 12 user := c.Get("user").(*jwt.Token) 13 claims := user.Claims.(jwt.MapClaims) 14 s := "" 15 for k, v := range claims { 16 s += fmt.Sprintf("%+v: %+v \n", k, v) 17 } 18 return c.String(http.StatusOK, s) 19} 20
分かっていること
run?
が出力されない
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。