環境
PlayFramework 2.4
Java 1.8
FacebookAPI 2.5
認証ライブラリ pac4j 2.3
###状況・問題
まず、アプリ起動後に認証をさせるために
application.conf内に
play.modules.enabled += "modules.SecurityModule"
を記載して下記のJavaを読み込んでいます。
java
1public class SecurityModule extends AbstractModule { 2 3 private final Environment environment; 4 private final Configuration configuration; 5 6 public SecurityModule( 7 Environment environment, 8 Configuration configuration) { 9 this.environment = environment; 10 this.configuration = configuration; 11 } 12 13 @Override 14 public void configure() { 15 final String fbId = configuration.getString("fbId"); 16 final String fbSecret = configuration.getString("fbSecret"); 17 final String baseUrl = configuration.getString("baseUrl"); 18 19 // OAuth 20 final FacebookClient facebookClient = new FacebookClient(fbId, fbSecret); 21 final Clients clients = new Clients(baseUrl + "callback", facebookClient); 22 23 final Config config = new Config(clients); 24 config.setClients(clients); 25 26 config.addAuthorizer("admin", new RequireAnyRoleAuthorizer<>("ROLE_ADMIN")); 27 config.addAuthorizer("custom", new CustomAuthorizer()); 28 config.setHttpActionAdapter(new DemoHttpActionAdapter()); 29 bind(Config.class).toInstance(config); 30 31 // set profile timeout to 2h instead of the 1h default 32 PlayCacheStore store = new PlayCacheStore(); 33 store.setProfileTimeout(7200); 34 config.setSessionStore(store); 35 36 // callback 37 final CallbackController callbackController = new CallbackController(); 38 callbackController.setDefaultUrl("/"); 39 callbackController.setMultiProfile(true); 40 bind(CallbackController.class).toInstance(callbackController); 41 42 // logout 43 final ApplicationLogoutController logoutController = new ApplicationLogoutController(); 44 logoutController.setDefaultUrl("/"); 45 bind(ApplicationLogoutController.class).toInstance(logoutController); 46 } 47}
そして、アプリを起動させてから時間が経過してからFacebook認証をおこなうと
下記のエラーが出てしまいます。
[TechnicalException: com.github.scribejava.core.exceptions.OAuthConnectionException: There was a problem while creating a connection to the remote service: https://graph.facebook.com/v2.5/oauth/access_token?client_id] //長文のエラーの下の方に表示される java.net.SocketTimeoutException: connect timed out
###試したこと
エラー内容から考えて、
store.setProfileTimeout(7200);
の一文で7200秒間でcacheが切れてしまいエラーになってしまうのだと思うので、
Java
1// set profile timeout to 2h instead of the 1h default 2PlayCacheStore store = new PlayCacheStore(); 3store.setProfileTimeout(7200); 4config.setSessionStore(store);
を削除するという対処を致しました。
実際に30分以上放置した後に接続させてもエラーは出力されなくなったのですが、
ずっと認証情報をキャッシュを残している状態だと思うのですが、
問題はないのでしょうか?
是非お力添えの程宜しく御願い致します。
あなたの回答
tips
プレビュー