正在获取错误{“ error”:“ invalid_grant”,“ error_description”:“令牌已过期或吊销。” }来自Google oauth2 API

时间:2020-07-16 13:25:34

标签: google-api gmail-api google-oauth

我早在2016年就在自己的Google Developer Console帐户中创建了一个应用,并且拥有该应用的客户端ID,客户端机密,访问令牌和刷新令牌。我正在尝试使用apache骆驼应用程序中的google:mail API从Gmail帐户中读取电子邮件。到今天为止一切正常,突然出现此错误,提示:

c.g.api.client.auth.oauth2.Credential    : unable to refresh token

com.google.api.client.auth.oauth2.TokenResponseException: 400 Bad Request
{
  "error" : "invalid_grant",
  "error_description" : "Bad Request"
}
    at com.google.api.client.auth.oauth2.TokenResponseException.from(TokenResponseException.java:105)
    at com.google.api.client.auth.oauth2.TokenRequest.executeUnparsed(TokenRequest.java:287)
    at com.google.api.client.auth.oauth2.TokenRequest.execute(TokenRequest.java:307)
    at com.google.api.client.auth.oauth2.Credential.executeRefreshToken(Credential.java:570)
    at com.google.api.client.googleapis.auth.oauth2.GoogleCredential.executeRefreshToken(GoogleCredential.java:362)
    at com.google.api.client.auth.oauth2.Credential.refreshToken(Credential.java:489)
    at com.google.api.client.auth.oauth2.Credential.handleResponse(Credential.java:272)
    at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:999)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:410)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:343)
    at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:460)
    at org.apache.camel.component.google.mail.GoogleMailProducer.doInvokeMethod(GoogleMailProducer.java:49)
    at org.apache.camel.util.component.AbstractApiProducer$1.run(AbstractApiProducer.java:86)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180)
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)

2020-07-20 11:31:02.689  WARN 20885 --- [CamelGoogleMail] o.a.camel.component.timer.TimerConsumer  : Error processing exchange. Exchange[ID-FVFXN5JKHV29-51050-1595224856126-0-2]. Caused by: [org.apache.camel.RuntimeCamelException - com.google.api.client.googleapis.json.GoogleJsonResponseException: 401 Unauthorized
{
  "code" : 401,
  "errors" : [ {
    "domain" : "global",
    "location" : "Authorization",
    "locationType" : "header",
    "message" : "Invalid Credentials",
    "reason" : "authError"
  } ],
  "message" : "Request had invalid authentication credentials. Expected OAuth 2 access token, login cookie or other valid authentication credential. See https://developers.google.com/identity/sign-in/web/devconsole-project.",
  "status" : "UNAUTHENTICATED"
}]

这是因为访问令牌或刷新令牌已于2016年之后过期吗?我应该尝试从Google Developer Console重置客户端密码吗?

编辑-这是我正在使用的代码

public GoogleMailComponent googleMailComponent() {
        GoogleMailConfiguration googleMailConfiguration = new GoogleMailConfiguration();
        googleMailConfiguration.setClientId(clientId);
        googleMailConfiguration.setClientSecret(clientSecret);
        googleMailConfiguration.setAccessToken(accessToken);
        googleMailConfiguration.setRefreshToken(refreshToken);

        GoogleMailComponent googleMailComponent = new GoogleMailComponent();
        googleMailComponent.setConfiguration(googleMailConfiguration);
        return googleMailComponent;
    }

1 个答案:

答案 0 :(得分:1)

删除令牌/StoredCredential 文件让我解决了这个问题。

下次当我运行试图连接到 Google 表格的 Java 应用程序时,它提示我

  1. 转到网址
  2. 允许访问 Google API