質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Echo(フレームワーク)

Echoは、Go言語で作られたフレームワーク。非常に軽量で、小~中規模のアプリ構成を想定した仕様になっています。公式ドキュメントが用意されており、初心者でも始めやすい点が特徴です。

JWT(JSON Web Token)

JWT(JSON Web Token)とは、JSONをベースとしたアクセストークンの仕様。電子署名付きのURL safeなJSONのことを指します。電子署名が付いているため、改ざんをチェックできる点がメリットです。

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Q&A

解決済

1回答

2876閲覧

Go web framework echoのJWTチェックが正常に完了しない

reud

総合スコア21

Echo(フレームワーク)

Echoは、Go言語で作られたフレームワーク。非常に軽量で、小~中規模のアプリ構成を想定した仕様になっています。公式ドキュメントが用意されており、初心者でも始めやすい点が特徴です。

JWT(JSON Web Token)

JWT(JSON Web Token)とは、JSONをベースとしたアクセストークンの仕様。電子署名付きのURL safeなJSONのことを指します。電子署名が付いているため、改ざんをチェックできる点がメリットです。

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

0グッド

1クリップ

投稿2019/10/22 09:31

編集2019/10/22 09:33

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?が出力されない

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

postmanではなくcurlでテストしたところうまくいったためコードの問題ではなさそうなためcloseさせて頂きます

投稿2019/10/22 09:58

reud

総合スコア21

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問