我正在开发一个需要访问帐户中所有用户的应用程序。
所有操作都是使用管理帐户在Google Apps for Business帐户上完成的。
一般的想法是在没有任何登录屏幕/仪表板的URL的情况下访问我的应用程序,并检索必要的数据(在这种情况下为用户)。那可能吗?
我不知道是否必须设置OAuth(我的应用程序已部署在appspot上并添加到GApps帐户中)-就像我之前说的,我只想启动我的应用程序,它应该从当前登录的GApps用户那里获取登录凭据。
但是,获取当前用户将返回null。这是我的servlet,具有获取当前用户的方法:
public class ExperimentalServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
UserService userService = UserServiceFactory.getUserService();
User user = userService.getCurrentUser();
resp.setContentType("text/plain");
resp.getWriter().println("User: " + (user == null ? "<null>" : user.getNickname()));
}
}
appengine-web.xml
<?xml version="1.0" encoding="utf-8"?>
<appengine-web-app xmlns="http://appengine.google.com/ns/1.0">
<application>name-of-my-application</application>
<threadsafe>true</threadsafe>
<version>1</version>
</appengine-web-app>
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
<servlet>
<servlet-name>experimental</servlet-name>
<servlet-class>my.app.domain.ExperimentalServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>experimental</servlet-name>
<url-pattern>/experimental</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
最佳答案
如果getCurrentUser返回null,则没有用户登录。
在这种情况下,您可以自己编写代码以重定向到登录页面
或者您将自己的应用配置为所有/某些网址都需要登录。
然后,appengine将自动将用户重定向到登录屏幕,并在成功登录后返回。
在您的Appengine应用信息中心中,您可以配置允许哪些用户(全部或全部)登录,或者仅允许Gapps域中的一个用户登录。
如果您将其设置为您的Gapps域,并且您配置了应用中的所有网址都需要身份验证,那么如果Gapps用户输入了您的应用,则他将自动登录;如果他未登录其Gapps帐户,则登录屏幕将显示给用户。
这是如何配置安全URL的链接
https://developers.google.com/appengine/docs/java/configyaml/appconfig_yaml#Secure_URLs