2012-04-11 37 views
0

我正在嘗試爲Web應用程序設置oauth身份驗證。在此,我想在應用程序頁面中顯示oauth提供程序列表...現在,當用戶單擊其中一個提供程序的按鈕時,將打開一個新窗口,該窗口將用戶直接帶到用戶嘗試進行身份驗證的提供程序的網站。gwt初學者 - 如何在另一個窗口中打開url,並在此窗口中控制流程

成功認證後,流程應返回到我的應用程序的主頁面,其中內容被修改(因爲登錄已成功)。

如何創建一個新窗口並將其設置爲轉到第三方url?我可以在用戶登錄成功後從該窗口獲得所需的信條,並關閉附加窗口?我能以這種方式從外部窗口獲取憑證嗎?

任何指針/教程將是一個很大的幫助....我已經看到一些實現上述流程,但想知道如何使用GWT可以完成此類實現。

回答

0

特拉維斯回答瞭如何打開窗戶。您確實需要使用第三方的身份驗證來打開新的彈出式瀏覽器窗口。如果您使用的是開放標識,我還會建議使用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()(); 
}; 
}-*/; 

然後在瀏覽器窗口中我有服務器端代碼重定向到兩個JSP頁面中的一個,經過身份驗證的一個看起來像這樣

<%@ 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> 

失敗的一個看起來像這樣

<%@ 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> 
相關問題