java - Android 应用的 Google 访问 token 服务器端验证

标签 java android spring-mvc oauth-2.0 google-plus

我正在开发基于与服务器通信的 android 应用程序,我想使用 Google(g+) 身份验证机制。

基本上,我认为它应该像这样工作:

  1. 在我的 android 应用程序中,用户使用他的电子邮件和密码登录 Google。
  2. 用户允许访问其相关 Google 应用程序的数据。
  3. 我的 android 应用程序在成功登录后收到访问 token 。
  4. 在与我的服务器进一步通信时,我的 Android 应用程序应该使用接收到的 Google 访问 token (例如:在查询中)。
  5. 当我的服务器收到来自 Android 应用的一些带有访问 token 的查询时,它应该向 Google 询问此 token 是否有效(以及对谁有效),如果是,服务器应该假定用户已通过 Google 的身份验证。

我的问题是:服务器应该如何询问 Google 给定的访问 token 是否有效?我想我应该以某种方式检查 token 是否对我的 Android 应用程序有效。

我已尝试对 Google API 进行许多 Google 查询,但我发现没有任何结果如我所料。你能给我举个例子吗?

最佳答案

您可以验证 access_token 是否有效。

您需要向 api 端点发送 GET 请求:https://www.googleapis.com/oauth2/v1/tokeninfo 并在请求中包含您的 access_token。

你可以这样试试:

 String connection = new ConnectionService().connectionGoogle("https://www.googleapis.com/oauth2/v1/tokeninfo", "access_token=" + "YOUR_EXISTING_ACCESS_TOKEN");
        System.out.println(connection);

上面代码中使用的方法是:

public static String connectionGoogle(String url, String parameter) throws MalformedURLException, ProtocolException, IOException {

        URL url1 = new URL(url);
        HttpURLConnection request1 = (HttpURLConnection) url1.openConnection();
        request1.setRequestMethod("GET");
        request1.setDoOutput(true);
        request1.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
        OutputStreamWriter wr = new OutputStreamWriter(request1.getOutputStream());
        wr.write(parameter);
        wr.flush();
        request1.connect();
        String responseBody = convertStreamToString(request1.getInputStream());
        wr.close();
        return responseBody;
    }

    private static String convertStreamToString(InputStream is) {
        BufferedReader reader = new BufferedReader(new InputStreamReader(is));
        StringBuilder sb = new StringBuilder();
        String line = null;
        try {
            while ((line = reader.readLine()) != null) {
                sb.append(line).append("\n");
            }
        } catch (IOException e) {
        } finally {
            try {
                is.close();
            } catch (IOException e) {
            }
        }

        return sb.toString();
    }

关于java - Android 应用的 Google 访问 token 服务器端验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19477969/

相关文章:

java - 以最小的努力从 Java 代码使用 Windows 静态库(最好使用 JNA)

java - Delphi 使用 Android Jni 包装器中的过程

java - 在 Ibatis 中迭代对象列表

java - onClickListener 无法在 Fragment 中工作

java - Spring MVC 中 Devise (Ruby on Rails) 的等价物?

java - Controller 排除不起作用

java - 验证 Mongo DB 时出现异常

android - 将任何 mp3 文件保存到我的应用程序中

android - 为什么 60dp 的文本会在 60dp TextView 中被剪裁?

java - 如何将一个spring项目包含到另一个spring项目中