我想编写一个将本地文件发布到Google Blogger的漫游器。我将是唯一使用此应用程序的人,所以我不需要设置用户友好的身份验证例程。我花了一个晚上试图设置一些东西,而我仍然在努力处理OAuth请求。使用Java为Blogger API验证自己的Google帐户
我创建了一个新的Google应用程序项目(键入:安装的桌面应用程序)并添加了Blogger API作为范围,然后为我自己的帐户(google-credentials.json,见下文)导出了一个客户端秘密文件。
代码:
try
{
HttpTransport httpTransport = GoogleNetHttpTransport.newTrustedTransport();
JsonFactory jsonFactory = JacksonFactory.getDefaultInstance();
List<String> scopes = Arrays.asList(BloggerScopes.BLOGGER);
GoogleClientSecrets secrets = GoogleClientSecrets.load(jsonFactory, new InputStreamReader(Main.class.getResourceAsStream("/google-credentials.json")));
GoogleCredential credential = new GoogleCredential.Builder().setJsonFactory(jsonFactory)
.setTransport(httpTransport)
.setClientSecrets(secrets)
.build();
Blogger blogger = new Blogger.Builder(httpTransport, jsonFactory, credential).setApplicationName("jd34app")
.build();
blogger.blogs().getByUrl("http://jd34blog.blogspot.com").execute();
}
catch (Exception e)
{
e.printStackTrace();
}
谷歌-credentials.json:
{
"installed": {
"client_id": "<removed>",
"project_id": "<removed>",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://accounts.google.com/o/oauth2/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_secret": "<removed>",
"redirect_uris": [
"urn:ietf:wg:oauth:2.0:oob",
"http://localhost"
]
}
}
响应:
com.google.api.client.googleapis.json.GoogleJsonResponseException: 403 Forbidden
{
"code" : 403,
"errors" : [ {
"domain" : "usageLimits",
"message" : "Daily Limit for Unauthenticated Use Exceeded. Continued use requires signup.",
"reason" : "dailyLimitExceededUnreg",
"extendedHelp" : "https://code.google.com/apis/console"
} ],
"message" : "Daily Limit for Unauthenticated Use Exceeded. Continued use requires signup."
}
我也试过GoogleAuthorizationCodeFlow + GoogleTokenResponse,但我不知道由于新的G,在哪里注册令牌响应oogleCredential()。setFromTokenResponse()似乎是不允许的。
Google发现的例子有些年了,并且导入了AuthorizationCodeInstalledApp,它不是我的依赖项com.google.apis的一个类:google-api-services-blogger:v3-rev50-1.21.0。