首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Window.close()不关闭Google Oauth弹出窗口[Java Servlet]

Window.close()不关闭Google Oauth弹出窗口[Java Servlet]
EN

Stack Overflow用户
提问于 2018-05-22 02:08:44
回答 1查看 1.7K关注 0票数 9

我正在尝试实现Google Oauth功能。这就是我的程序的运行方式。首先,index.jsp文件运行并打开一个页面,如下所示:

我的index.jsp代码是:

代码语言:javascript
复制
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Website</title>
</head>
<style>
h1 {
	font-family: Bookman;
	font-size: 150px;
	font-style: normal;
	font-variant: normal;
	font-weight: 800;
	line-height: 26.4px;
	text-color: white;
	text-align: center;
}
p {
	font-family: Bookman;
	font-size: 50px;
	font-style: normal;
	font-variant: normal;
	font-weight: 800;
	line-height: 26.4px;
	text-color: white;
	text-align: center;
}
.main_background{
    background-image: url("img/main_page_background.jpg");
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}
</style>
<body class=main_background>
<h1 style="color:white">Title</h1>
<p style="color:white">Subtitle</p>
<form action="google_oauth" method="post">
<input type="submit" value="Sign In With Google"/>
</form>

</body>
</html>

发生的情况是用户单击“使用Google Button登录”,该按钮将重定向到servlet。在servlet中,使用以下代码打开另一个html文件:

代码语言:javascript
复制
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		File htmlFile = new File("C:\\Users\\neel-\\OneDrive\\Eclipse Workspace\\Website\\Website\\WebContent\\google_oauth.html");
		Desktop.getDesktop().browse(htmlFile.toURI());
	}

}

我知道我可以在.jsp文件中实现这一点,但是以后我需要重定向。打开html文件后会发生什么,我们会看到一个这样的窗口。

打开的html文件是google_ouath.html文件,代码是:

代码语言:javascript
复制
<!DOCTYPE html>
<html>
<head>
    <script src="jquery.js"></script>
    <script>
        var OAUTHURL    =   'https://accounts.google.com/o/oauth2/auth?';
        var VALIDURL    =   'https://www.googleapis.com/oauth2/v1/tokeninfo?access_token=';
        var SCOPE       =   'https://www.googleapis.com/auth/userinfo.profile https://www.googleapis.com/auth/userinfo.email';
        var CLIENTID    =   '778647136201-d9trubpsuokohuj9a0c9bgufpo1qvqtf.apps.googleusercontent.com';
        var REDIRECT    =   'http://localhost:8080/Website/main_page'
        var LOGOUT      =   'http://accounts.google.com/Logout';
        var TYPE        =   'token';
        var _url        =   OAUTHURL + 'scope=' + SCOPE + '&client_id=' + CLIENTID + '&redirect_uri=' + REDIRECT + '&response_type=' + TYPE;
        var acToken;
        var tokenType;
        var expiresIn;
        var user;
        var loggedIn    =   false;

        function login() {
            var win         =   window.open(_url, "windowname1", 'width=800, height=600'); 

            var pollTimer   =   window.setInterval(function() { 
                try {
                    console.log(win.document.URL);
                    if (win.document.URL.indexOf(REDIRECT) != -1) {
                        window.clearInterval(pollTimer);
                        var url =   win.document.URL;
                        acToken =   gup(url, 'access_token');
                        tokenType = gup(url, 'token_type');
                        expiresIn = gup(url, 'expires_in');
                        win.close();
                        validateToken(acToken);
                    }
                } catch(e) {
                }
            }, 500);
        }

        function validateToken(token) {
            $.ajax({
                url: VALIDURL + token,
                data: null,
                success: function(responseText){  
                    getUserInfo();
                    loggedIn = true;
                    $('#loginText').hide();
                    $('#logoutText').show();
                },  
                dataType: "jsonp"  
            });
        }

        function getUserInfo() {
            $.ajax({
                url: 'https://www.googleapis.com/oauth2/v1/userinfo?access_token=' + acToken,
                data: null,
                success: function(resp) {
                    user    =   resp;
                    console.log(user);
                    $('#uName').text('Welcome ' + user.name);
                    $('#imgHolder').attr('src', user.picture);
                },
                dataType: "jsonp"
            });
        }

        function gup(url, name) {
            name = name.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]");
            var regexS = "[\\#&]"+name+"=([^&#]*)";
            var regex = new RegExp( regexS );
            var results = regex.exec( url );
            if( results == null )
                return "";
            else
                return results[1];
        }

        function startLogoutPolling() {
            $('#loginText').show();
            $('#logoutText').hide();
            loggedIn = false;
            $('#uName').text('Welcome ');
            $('#imgHolder').attr('src', 'none.jpg');
        }

    </script>
</head>

<body>
    <a href='#' onClick='login();' id="loginText"> Click here to login </a>
    <a href="#" style="display:none" id="logoutText" target='myIFrame' onclick="myIFrame.location='https://www.google.com/accounts/Logout'; startLogoutPolling();return false;"> Click here to logout</a>
    <iframe name='myIFrame' id="myIFrame" style='display:none'></iframe>
    <div id='uName'></div>
    <img src='' id='imgHolder'/>
</body>
</html>

然而,这个问题的相关代码片段是:

代码语言:javascript
复制
        function login() {
            var win         =   window.open(_url, "windowname1", 'width=800, height=600'); 

            var pollTimer   =   window.setInterval(function() { 
                try {
                    console.log(win.document.URL);
                    if (win.document.URL.indexOf(REDIRECT) != -1) {
                        window.clearInterval(pollTimer);
                        var url =   win.document.URL;
                        acToken =   gup(url, 'access_token');
                        tokenType = gup(url, 'token_type');
                        expiresIn = gup(url, 'expires_in');
                        win.close();
                        validateToken(acToken);
                    }
                } catch(e) {
                }
            }, 500);
        }

在这里,弹出窗口打开客户端登录,然后关闭弹出窗口。就像这样。

在上面,我们可以看到google登录已经完成,url已经重定向。但是返回到login()函数,win.close()实际上并没有关闭弹出窗口。我在网上搜索,我发现了几个解决方案都不起作用。例如,here表示要使用变通方法

代码语言:javascript
复制
open(location, '_self').close();

但这也不起作用。

另一件事是,在Brock Adams Solution中,它声明:

除了一个小例外,不能允许javascript关闭不是由同一javascript打开的窗口。

然而,我不认为这是一个问题。

问题:如何在win.close()不工作时关闭此弹出窗口。

更新:在尝试了b4ch的anser之后。我得到了以下信息:

EN

回答 1

Stack Overflow用户

发布于 2018-06-13 21:54:31

不能允许javascript关闭不是由同一Javascript打开的窗口。这是出于安全原因。

可能只是您必须调用self location对象,该对象用于配置打开窗口必须由相同的java脚本打开。因此,如果你尝试open(location, '_self').close();而不是win.close(),它应该可以工作,我的情况就是这样。如果它仍然不起作用,就用Ping命令通知我。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50454406

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档