go - googleapi:错误 403:请求的身份验证范围不足。更多细节:原因:权限不足,消息:权限不足
问题描述
我正在尝试使用 Gmail API 发送电子邮件。但我得到这个错误
googleapi:错误 403:请求的身份验证范围不足。更多细节:原因:权限不足,消息:权限不足
我认为它可能与配置有关,我也关注了谷歌的 Go 快速入门,这里是 getClient 函数:
func getClient(config *oauth2.Config) *http.Client {
// The file token.json stores the user's access and refresh tokens, and is
// created automatically when the authorization flow completes for the first
// time.
tokFile := "token.json"
tok, err := tokenFromFile(tokFile)
if err != nil {
tok = getTokenFromWeb(config)
saveToken(tokFile, tok)
}
return config.Client(context.Background(), tok)
}
这是发送的代码:
case "pass":
templateData := struct {
VerPass string
}{
VerPass: cont1,
}
emailBody, err := parseTemplate("ver.html", templateData)
if err != nil {
fmt.Println("Parse Err")
return false, err
}
var message gmail.Message
emailTo := "To: " + to + "\r\n"
subject := "Subject: " + sub + "\n"
mime := "MIME-version: 1.0;\nContent-Type: text/html; charset=\"UTF-8\";\n\n"
msg := []byte(emailTo + subject + mime + "\n" + emailBody)
message.Raw = base64.URLEncoding.EncodeToString(msg)
// Send the message
fmt.Println("OOOOOYYYYY")
//here is the problem
b, err := ioutil.ReadFile("credentials.json")
if err != nil {
log.Fatalf("Unable to read client secret file: %v", err)
}
// If modifying these scopes, delete your previously saved token.json.
config, err := google.ConfigFromJSON(b, gmail.MailGoogleComScope)
if err != nil {
log.Fatalf("Unable to parse client secret file to config: %v", err)
}
client := getClient(config)
srv, err := gmail.New(client)
if err != nil {
log.Fatalf("Unable to retrieve Gmail client: %v", err)
}
//GmailService
res, err := srv.Users.Messages.Send("me", &message).Do() // change me
if err != nil {
fmt.Println("Res Err")
fmt.Println(err)
return false, err
}
fmt.Println(res)
我试过了for config, err := google.ConfigFromJSON(b, gmail.MailGoogleComScope)
,我试过使用GmailReadonlyScope
and gmail.GmailSendScope
,但我得到了同样的错误。
解决方案
请求的身份验证范围不足。
意味着授权您的应用程序访问其数据的用户没有授予您的应用程序足够的权限来执行您正在尝试执行的操作。
您似乎正在使用user.message.send方法。如果您检查文档,您会发现该方法要求用户获得以下范围之一的授权。
如果您确实按照Google 的快速入门进行操作,那么您将gmail.GmailReadonlyScope
其用作仅授予您只读访问权限的范围。但是,您的代码现在似乎包含mail.MailGoogleComScope
应该工作的范围,但是我猜您忽略了重新授权应用程序。并没有看到教程中的评论
// 如果修改这些范围,请删除您之前保存的 token.json。
我建议您删除 token.json ,然后应用程序将要求您再次授权,并且您的代码应该使用提升的权限。
推荐阅读
- c++ - 在 vs2019 中创建服务
- android - 如何在Android Kotlin中以特定间隔播放声音
- c++ - 我的代码在 Visual 代码中遇到嵌套 for 循环的错误,但在其他在线 C++ 编译器中运行良好,为什么?
- constants - 如何在 puppeteer Node.js 中将 const 添加到 await page.$eval?
- python - 对frozensets列表进行排序?
- c# - FluentValidation 比较来自不同类的 2 个值
- javascript - 为什么这个返回的 promise 的值没有更新?
- vba - 在字符串文本 Access 中插入超链接
- ios - Xamarin.Forms iOS 15 导致应用程序冻结/崩溃
- css - TailwindCSS 中类似 Webflow 的布局