トラビスはウィンドウを開く方法に答えました。第三者からの認証で新しいポップアップブラウザウィンドウを開く必要があります。オープンIDを使用している場合は、dyuprojectを使用して全体のフローを助けることもお勧めします。サーバー側のハンドシェイクが完了したら、クライアントにメッセージを送り返す必要があります。ポップアップウィンドウはhttp要求/応答を制御します。そのため、成功または失敗の情報をクライアントアプリケーションにポップアップウィンドウから戻す必要があります。私は最初にjsniでクライアントにコールバックする場所を登録することでこれを行いました。どこかの認証コードでは、おそらくポップアップブラウザウィンドウを起動し、コードの近くに、私はこの
private native void exposeAuthorizedHandler(OpenIdPanelPresenter pres) /*-{
$wnd.handleOpenIDResponse = function() {
[email protected]::Authorized()();
};
}-*/;
private native void exposeFailedHandler(OpenIdPanelPresenter pres) /*-{
$wnd.handleOpenIDFailed = function() {
[email protected]::Failed()();
};
}-*/;
ようなコードを持っているそして、私は、サーバー側のコードを持っているブラウザウィンドウに2つのJSPページのいずれかにリダイレクトし、認証された1は、ザ・一つは、この
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<body>
<h1>Authentication failed.</h1>
</br>
<div style="color:red;font-size:1.4em">${openid_fail_message}</div>
<button onclick="window.opener.handleOpenIDFailed();window.close();">Close</button>
</body>
</html>
のように見えなかったこの
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<body onload="window.opener.handleOpenIDResponse();window.close();">
<h1>You have been authenticated.</h1>
</body>
</html>
のように見えます