我正在尝试获取 Google Apps 域上用户的管理员状态。
因此,我将从 Google Marketplace 的应用程序列表中获得的 CONSUMER_KEY 和 CONSUMER_SECRET 放入我的代码中。
String CONSUMER_KEY = "748096634522.apps.googleusercontent.com";
String CONSUMER_SECRET = "PK/Wx/9sbLkz5hhj6rq6LKCZ";
我已经授权应用程序访问范围
https://apps-apis.google.com/a/feeds/user/
但是当我尝试访问 URL
https://apps-apis.google.com/a/feeds/user/2.0/domain.com/username%40domain.com
我收到以下错误:
javax.servlet.ServletContext log: Exception while dispatching incoming RPC call
com.google.gwt.user.server.rpc.UnexpectedException: Service method 'public abstract com.icada.idea.client.LoginInfo com.icada.idea.client.LoginService.login(java.lang.String,java.lang.String)' threw an unexpected exception: java.lang.RuntimeException: com.google.gdata.client.authn.oauth.OAuthException: oauth_token does not exist.
然而,根据上面提供的数据,在Google 的 OAuth 操场上尝试效果很好。
这是我的代码:
private boolean isAdmin (String userEmail, String domain) {
boolean ret= false;
String CONSUMER_KEY = "748096634522.apps.googleusercontent.com";
String CONSUMER_SECRET = "PK/Wx/9sbLkz5hhj6rq6LKCZ";
GoogleOAuthParameters oauthParameters = new GoogleOAuthParameters();
oauthParameters.setOAuthConsumerKey(CONSUMER_KEY);
oauthParameters.setOAuthConsumerSecret(CONSUMER_SECRET);
oauthParameters.setScope ("https://apps-apis.google.com/a/feeds/user/");
com.google.gdata.client.appsforyourdomain.UserService client
= new com.google.gdata.client.appsforyourdomain.UserService ("Idea");
try {
client.setOAuthCredentials(oauthParameters, new OAuthHmacSha1Signer());
URL feedUrl = new URL("https://apps-apis.google.com/a/feeds/user/2.0/"
+ domain +"/"+ java.net.URLEncoder.encode (userEmail));
UserFeed resultFeed = client.getFeed(feedUrl, UserFeed.class);
for (UserEntry entry : resultFeed.getEntries()) {
if (entry.getLogin ().getAdmin ().equals (Boolean.TRUE)) ret= true;
else ret= false;
}
}
catch (OAuthException ex) {
log.severe (ex.getMessage () + ex.toString () + ex.getCause ()
+ ex.getStackTrace ().toString ());
ex.printStackTrace();
}
[more catch-blocks...]
return ret;
}
任何想法,为什么它说“oauth_token 不存在”?