2012-04-11 4 views
0

ウェブアプリケーションのoauth認証を設定しようとしています。ここでは、アプリケーションのページ内にoauthプロバイダのリストを表示したいと思います...ユーザーがプロバイダのボタンの1つをクリックすると、新しいウィンドウが開き、プロバイダのWebサイトに直接アクセスして認証しようとします。gwt初心者 - 別のウィンドウでURLを開き、このウィンドウでフローを制御する方法

彼が正常に認証されたら、アプリケーションのメインページに戻り、コンテンツが変更されます(ログインが成功したため)。

新しいウィンドウを作成してサードパーティのURLに移動するにはどうすればよいですか?そして、ユーザーが正常にログインした後、そのウィンドウから希望のcreedntialsを取得して、追加のウィンドウを閉じることはできますか?この方法で外部ウィンドウから資格情報を取得できますか?

任意のポインタ/チュートリアルは素晴らしい助けになるでしょう。私は上記の流れでいくつかの実装を見ましたが、そのような実装をGWTでどのように行うことができるか知りたいと思います。

答えて

0

トラビスはウィンドウを開く方法に答えました。第三者からの認証で新しいポップアップブラウザウィンドウを開く必要があります。オープン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> 

のように見えます

関連する問題