Java获取GoogleOAuth2.0令牌方法
最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《Java 获取 Google OAuth 2.0 令牌教程》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

本教程旨在指导 Java 应用程序如何通过 Google OAuth 2.0 授权代码流获取用户访问令牌。针对直接使用 `GoogleCredentials.Builder` 遇到的权限问题,本文将介绍正确的依赖配置、`client_secrets.json` 文件创建,并提供使用 `GoogleAuthorizationCodeFlow` 实现交互式用户认证的完整代码示例,最终安全地获取并管理访问令牌,助力开发者顺利集成 Google API。
引言:理解 Google OAuth 2.0 认证挑战
在 Java 应用程序中与 Google API 进行交互时,获取用户授权的访问令牌是关键一步。许多开发者在尝试直接使用 com.google.auth.oauth2.GoogleCredentials.Builder 配合 clientId 和 clientSecret 获取访问令牌时,可能会遇到 Builder() 方法受保护的访问权限问题。这是因为 GoogleCredentials.Builder 主要设计用于服务账户认证或在已拥有刷新令牌等凭据时构建 GoogleCredentials 对象,而非用于启动交互式的用户授权流程。
对于需要用户通过浏览器进行认证并授予应用程序访问权限的场景(例如桌面应用程序或自动化脚本),Google 推荐使用 OAuth 2.0 授权代码流(Authorization Code Flow)。本文将详细介绍如何正确配置项目、实现这一流程,并安全地获取所需的 Google 访问令牌。
项目依赖配置
为了实现 Google OAuth 2.0 授权代码流,我们需要在项目的 pom.xml 文件中添加以下 Maven 依赖。这些库提供了处理 OAuth 流程、HTTP 请求以及 JSON 解析所需的功能。
<dependencies>
<!-- Google API 客户端核心库 -->
<dependency>
<groupId>com.google.api-client</groupId>
<artifactId>google-api-client</artifactId>
<version>1.32.1</version> <!-- 推荐使用最新稳定版本 -->
</dependency>
<!-- Google OAuth 客户端库 -->
<dependency>
<groupId>com.google.oauth-client</groupId>
<artifactId>google-oauth-client</artifactId>
<version>1.32.1</version>
</dependency>
<!-- Google OAuth 客户端库,用于 Jetty 服务器(桌面应用授权回调) -->
<dependency>
<groupId>com.google.oauth-client</groupId>
<artifactId>google-oauth-client-jetty</artifactId>
<version>1.32.1</version>
</dependency>
<!-- Google HTTP 客户端库,用于 Jackson2 JSON 解析 -->
<dependency>
<groupId>com.google.http-client</groupId>
<artifactId>google-http-client-jackson2</artifactId>
<version>1.39.2</version>
</dependency>
<!-- Google OAuth 客户端库,用于 Java 6+ (包含 FileDataStoreFactory 等) -->
<dependency>
<groupId>com.google.oauth-client</groupId>
<artifactId>google-oauth-client-java6</artifactId>
<version>1.32.1</version>
</dependency>
</dependencies>请注意,版本号可能需要根据最新的稳定版本进行调整。
配置客户端密钥:client_secrets.json
出于安全性和最佳实践考虑,您的 clientId 和 clientSecret 不应硬编码在源代码中。Google 推荐将这些凭据存储在一个名为 client_secrets.json 的文件中。
1. 从 Google Cloud 控制台获取凭据
- 访问 Google Cloud 控制台 (console.cloud.google.com)。
- 选择或创建一个项目。
- 导航到 "API 和服务" -> "凭据"。
- 点击 "创建凭据",选择 "OAuth 客户端 ID"。
- 选择 "桌面应用" 作为应用程序类型,然后创建。
- 创建后,您将获得客户端 ID 和客户端密钥。点击 "下载 JSON" 按钮,下载的文件通常就是 client_secret_
.json。将其重命名为 client_secrets.json。
2. client_secrets.json 文件结构
下载的 client_secrets.json 文件通常具有以下结构:
{
"web": { // 如果您选择的是“Web 应用”类型,这里是 "web"
"client_id": "YOUR_CLIENT_ID.apps.googleusercontent.com",
"project_id": "your-project-id",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_secret": "YOUR_CLIENT_SECRET",
"redirect_uris": [
"http://localhost" // 或其他配置的重定向 URI
]
},
"installed": { // 如果您选择的是“桌面应用”类型,这里是 "installed"
"client_id": "YOUR_CLIENT_ID.apps.googleusercontent.com",
"project_id": "your-project-id",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_secret": "YOUR_CLIENT_SECRET",
"redirect_uris": [
"http://localhost"
]
}
}请确保您的 client_secrets.json 文件位于项目的类路径下(例如 src/main/resources 目录),以便程序可以加载它。
实现 Google OAuth 2.0 授权代码流
以下是使用 Java 实现 Google OAuth 2.0 授权代码流的完整代码示例。此示例将引导用户在浏览器中完成认证,然后应用程序将接收授权代码并交换为访问令牌。
package com.example.googleauth;
import com.google.api.client.auth.oauth2.Credential;
import com.google.api.client.extensions.java6.auth.oauth2.FileDataStoreFactory;
import com.google.api.client.extensions.jetty.auth.oauth2.LocalServerReceiver;
import com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow;
import com.google.api.client.googleapis.auth.oauth2.GoogleClientSecrets;
import com.google.api.client.googleapis.javanet.GoogleNetHttpTransport;
import com.google.api.client.http.HttpTransport;
import com.google.api.client.json.JsonFactory;
import com.google.api.client.json.jackson2.JacksonFactory;
import com.google.api.client.util.store.DataStoreFactory;
import com.google.api.client.extensions.java6.auth.oauth2.AuthorizationCodeInstalledApp;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.security.GeneralSecurityException;
import java.util.Collections;
import java.util.List;
public class GoogleTokenFetcher {
/** 应用程序名称,用于标识用户代理 */
private static final String APPLICATION_NAME = "Google Token Fetcher";
/** JSON 工厂,用于解析 JSON 响应 */
private static final JsonFactory JSON_FACTORY = JacksonFactory.getDefaultInstance();
/** HTTP 传输器 */
private static HttpTransport HTTP_TRANSPORT;
/** 数据存储工厂,用于持久化凭据(如刷新令牌) */
private static FileDataStoreFactory DATA_STORE_FACTORY;
/**
* 定义应用程序所需的授权范围(Scopes)。
* 这里以访问 Google 日历为例,您可以根据需要更改。
* 更多 Scope 请参考 Google API 文档。
*/
private static final List<String> SCOPES = Collections.singletonList("https://www.googleapis.com/auth/calendar.readonly");
// 如果需要访问用户个人资料,可以使用 "https://www.googleapis.com/auth/userinfo.profile"
// 或 "https://www.googleapis.com/auth/userinfo.email"
// 甚至更通用的 "https://www.googleapis.com/auth/drive.readonly" 等
static {
try {
HTTP_TRANSPORT = GoogleNetHttpTransport.newTrustedTransport();
// 凭据将存储在用户主目录下的 .store/google_token_fetcher 目录中
DATA_STORE_FACTORY = new FileDataStoreFactory(new File(System.getProperty("user.home"), ".store/google_token_fetcher"));
} catch (GeneralSecurityException | IOException e) {
e.printStackTrace();
System.exit(1);
}
}
public static void main(String[] args) throws IOException {
try {
Credential credential = authorize();
if (credential != null && credential.getAccessToken() != null) {
String accessToken = credential.getAccessToken();
System.out.println("成功获取访问令牌 (Access Token): " + accessToken);
// 您可以使用这个访问令牌调用 Google API
// 例如:
// Calendar service = new Calendar.Builder(HTTP_TRANSPORT, JSON_FACTORY, credential)
// .setApplicationName(APPLICATION_NAME)
// .build();
// Event event = service.events().get("primary", "eventId").execute();
// System.out.println("获取到的事件:" + event.getSummary());
} else {
System.out.println("未能获取访问令牌。");
}
} catch (Exception e) {
System.err.println("授权过程中发生错误: " + e.getMessage());
e.printStackTrace();
}
}
/**
* 授权安装的应用程序访问用户的受保护数据。
* @return Credential 对象,包含访问令牌和刷新令牌
* @throws Exception 如果授权过程中发生错误
*/
private static Credential authorize() throws Exception {
// 1. 加载客户端密钥 (client_secrets.json)
// 确保 client_secrets.json 文件在类路径中 (例如 src/main/resources)
GoogleClientSecrets clientSecrets = GoogleClientSecrets.load(
JSON_FACTORY,
new InputStreamReader(GoogleTokenFetcher.class.getResourceAsStream("/client_secrets.json"))
);
// 2. 设置授权代码流
GoogleAuthorizationCodeFlow flow = new GoogleAuthorizationCodeFlow.Builder(
HTTP_TRANSPORT,
JSON_FACTORY,
clientSecrets,
SCOPES // 应用程序所需的权限范围
)
.setDataStoreFactory(DATA_STORE_FACTORY) // 用于持久化凭据,例如刷新令牌
.setAccessType("offline") // 请求刷新令牌,以便在访问令牌过期后重新获取
.build();
// 3. 授权用户
// LocalServerReceiver 会在本地启动一个服务器,监听 Google 授权回调
LocalServerReceiver receiver = new LocalServerReceiver.Builder().setPort(8888).build(); // 可以指定端口
return new AuthorizationCodeInstalledApp(flow, receiver).authorize("user");
}
}代码解析:
- 静态初始化块 (static {}): 初始化 HttpTransport 和 DataStoreFactory。GoogleNetHttpTransport.newTrustedTransport() 用于创建安全的 HTTP 传输层。FileDataStoreFactory 用于将用户的凭据(包括刷新令牌)持久化存储在本地文件系统中,避免每次运行时都要求用户重新授权。
- SCOPES: 定义了应用程序需要访问用户数据的权限范围。请务必根据您的应用程序实际需求选择合适的 Scope。
- authorize() 方法:
- 加载 client_secrets.json: 使用 GoogleClientSecrets.load() 从类路径加载 client_secrets.json 文件。
- 构建 GoogleAuthorizationCodeFlow: 这是 OAuth 2.0 授权代码流的核心
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
Java类型推断详解与使用技巧
- 上一篇
- Java类型推断详解与使用技巧
- 下一篇
- 手机屏幕太暗怎么调?亮度调节方法分享
-
- 文章 · java教程 | 2小时前 |
- Java高效对比文件夹并处理同名文件方法
- 185浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- Linux挂载目录搭建静态服务与安全配置
- 104浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- Java发送HTML邮件的实用技巧分享
- 131浏览 收藏
-
- 文章 · java教程 | 3小时前 |
- Java封装优势与作用解析
- 404浏览 收藏
-
- 文章 · java教程 | 4小时前 |
- synchronized用法与同步机制详解
- 107浏览 收藏
-
- 文章 · java教程 | 4小时前 | java 类型推断
- Java类型推断详解与使用技巧
- 345浏览 收藏
-
- 文章 · java教程 | 4小时前 |
- JavaExcel数据导入导出教程详解
- 366浏览 收藏
-
- 文章 · java教程 | 5小时前 |
- Java基本类型与对象比较技巧
- 360浏览 收藏
-
- 文章 · java教程 | 5小时前 | java 在线考试
- Java题库系统开发全攻略
- 271浏览 收藏
-
- 文章 · java教程 | 5小时前 |
- AkkaActor状态与消息处理详解
- 332浏览 收藏
-
- 文章 · java教程 | 6小时前 |
- Java任务统计实现技巧与方法解析
- 281浏览 收藏
-
- 文章 · java教程 | 6小时前 |
- Java面向对象数据结构优化方法
- 308浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3363次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3572次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3605次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4731次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3977次使用
-
- 提升Java功能开发效率的有力工具:微服务架构
- 2023-10-06 501浏览
-
- 掌握Java海康SDK二次开发的必备技巧
- 2023-10-01 501浏览
-
- 如何使用java实现桶排序算法
- 2023-10-03 501浏览
-
- Java开发实战经验:如何优化开发逻辑
- 2023-10-31 501浏览
-
- 如何使用Java中的Math.max()方法比较两个数的大小?
- 2023-11-18 501浏览

