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

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

新規登録して質問してみよう
ただいま回答率
85.48%
OAuth 2.0

OAuth 2.0(Open Authorization 2.0)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Play Framework 2

Play Framework 2はPlayのメジャーバージョンです。現代の web アプリケーション開発に必要なコンポーネント及び API を統合した生産性の高い Java と Scala の web アプリケーションフレームワークです。

Facebook

Facebookは、実名登録制のSNS(ソーシャル・ネットワーキング・サービス)です。開発者用のデベロッパーサイトが存在し、一般ユーザーによるFacebook向けアプリケーション開発が可能です。

Q&A

0回答

1736閲覧

PlayFrameworkでFacebookのOAuth認証ができなくて困っています

sequence

総合スコア29

OAuth 2.0

OAuth 2.0(Open Authorization 2.0)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Play Framework 2

Play Framework 2はPlayのメジャーバージョンです。現代の web アプリケーション開発に必要なコンポーネント及び API を統合した生産性の高い Java と Scala の web アプリケーションフレームワークです。

Facebook

Facebookは、実名登録制のSNS(ソーシャル・ネットワーキング・サービス)です。開発者用のデベロッパーサイトが存在し、一般ユーザーによるFacebook向けアプリケーション開発が可能です。

0グッド

0クリップ

投稿2016/10/07 09:28

編集2016/10/14 16:05

Java1.8でPlayFramework2.4でWebアプリを開発しています。

その中でpac4jというライブラリを用いてFacebookのOAuth認証をしているのですが、
下記のエラーが出て来てしまい、対象方法がわからず困り果てています。

[TechnicalException: com.github.scribejava.core.exceptions.OAuthConnectionException: There was a problem while creating a connection to the remote service: https://graph.facebook.com/v2.4/me?fields=...]

その他には原因は不明なのですが、

TechnicalException: com.github.scribejava.core.exceptions.OAuthConnectionException

Execution exception[[OAuthCredentialsException: State parameter mismatch: session expired or possible threat of cross-site request forger]]

のエラーも出力されています。

これらのエラーが出力される前に一度接続は成功しており、
OAuthから情報の取得はできています。

しかし、その状態で放置して再度認証をかけると上記のエラーを吐き出します。
実際にどのような状態で2つのエラーが出力されて、どのように対処すべきかが検討が付かない状態です。

上記のエラーの時はこのような処理をしなければいけない、というようなことがございましたらご指摘していただきたいです。

下記にOAuthにConnectしているコードを記載致します。

Java

1 @Override 2 public void configure() { 3 4 final String fbId = configuration.getString("fbId"); 5 final String fbSecret = configuration.getString("fbSecret"); 6 final String baseUrl = configuration.getString("baseUrl"); 7 8 // OAuth 9 final FacebookClient facebookClient = new FacebookClient(fbId, fbSecret); 10 final Clients clients = new Clients(baseUrl + "callback", facebookClient); 11 12 final Config config = new Config(clients); 13 config.setClients(clients); 14 15 config.addAuthorizer("admin", new RequireAnyRoleAuthorizer<>("ROLE_ADMIN")); 16 config.addAuthorizer("custom", new CustomAuthorizer()); 17 config.setHttpActionAdapter(new DemoHttpActionAdapter()); 18 bind(Config.class).toInstance(config); 19 20 // set profile timeout to 2h instead of the 1h default 21 PlayCacheStore store = new PlayCacheStore(); 22 store.setProfileTimeout(7200); 23 config.setSessionStore(store); 24 25 // callback 26 final CallbackController callbackController = new CallbackController(); 27 callbackController.setDefaultUrl("/"); 28 callbackController.setMultiProfile(true); 29 bind(CallbackController.class).toInstance(callbackController); 30 31 // logout 32 final ApplicationLogoutController logoutController = new ApplicationLogoutController(); 33 logoutController.setDefaultUrl("/"); 34 bind(ApplicationLogoutController.class).toInstance(logoutController); 35 }

丸投げのような形となってしまいますが、何卒宜しく御願い致します。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問