我已经尝试通过golang.com/x/oauth2
库成功使用OAuth进行身份验证。
// provider variable is oauth2.Config
// scope is: https://www.googleapis.com/auth/userinfo.email
url := provider.AuthCodeURL(``) // redirect URL
从客户端重定向回后,我发送auth_code
成功
auth_code := ctx.Request.URL.RawQuery // code=XXXX
if len(auth_code) > 5 {
auth_code = auth_code[5:] // XXXX
}
tok, err := provider.Exchange(oauth2.NoContext, auth_code)
if err == nil {
client := provider.Client(oauth2.NoContext, tok)
email_url := `https://www.googleapis.com/auth/userinfo.email`
//Log.Describe(client)
response, err := client.Get(email_url)
if err == nil {
ctx.Render(`login_oauth`, response)
//handled = true
}
}
//Log.Describe(err)
我发现什么都没有告诉电子邮件部分response
(Body
为空):
{
"Status": "200 OK",
"StatusCode": 200,
"Proto": "HTTP/1.1",
"ProtoMajor": 1,
"ProtoMinor": 1,
"Header": {
"Alternate-Protocol": [
"443:quic,p=0.5"
],
"Cache-Control": [
"private, max-age=0"
],
"Content-Type": [
"text/plain"
],
"Date": [
"Tue, 14 Apr 2015 05:52:17 GMT"
],
"Expires": [
"Tue, 14 Apr 2015 05:52:17 GMT"
],
"Server": [
"GSE"
],
"X-Content-Type-Options": [
"nosniff"
],
"X-Frame-Options": [
"SAMEORIGIN"
],
"X-Xss-Protection": [
"1; mode=block"
]
},
"Body": {}, // empty!!!
"ContentLength": -1,
"TransferEncoding": [
"chunked"
],
"Close": false,
"Trailer": null,
"Request": {
"Method": "GET",
"URL": {
"Scheme": "https",
"Opaque": "",
"User": null,
"Host": "www.googleapis.com",
"Path": "/auth/userinfo.email",
"RawQuery": "",
"Fragment": ""
},
"Proto": "HTTP/1.1",
"ProtoMajor": 1,
"ProtoMinor": 1,
"Header": {
"Authorization": [
"Bearer ya29.VQFRHDe21t7g2cUhN8sUwjpRRi10XldgLe0RFhMe2ZxgyRo7q90HoKES5WmcucwKqtjZdq_KvYjKiQ"
]
},
"Body": null,
"ContentLength": 0,
"TransferEncoding": null,
"Close": false,
"Host": "www.googleapis.com",
"Form": null,
"PostForm": null,
"MultipartForm": null,
"Trailer": null,
"RemoteAddr": "",
"RequestURI": "",
"TLS": null
},
"TLS": {
// really long output
}
}
第一个问题 ,如何正确获取电子邮件?无需使用Google+ API。
编辑#2 我尝试将另一个scope
用于oauth2.Config
:
https://www.googleapis.com/auth/plus.profile.emails.read
https://www.googleapis.com/auth/plus.login
https://www.googleapis.com/auth/plus.me
并尝试使用较新的API检索电子邮件:
https://www.googleapis.com/plus/v1/people/me
但它给 403 Forbidden
编辑#3 我尝试使用另一个范围:
openid
profile
email
并尝试使用以下URL检索电子邮件:
https://www.googleapis.com/oauth2/v3/userinfo
但它仍然Body
像以前一样为空。
第二个问题 ,我可以为其他用户重用oauth2.Config
(provider
)变量吗?还是应该为每个用户创建一个副本?
我不好,我应该读第response.Body
一个,例如:
response, err = client.Get(`https://accounts.google.com/.well-known/openid-configuration`)
body, err := ioutil.ReadAll(response.Body)
response.Body.Close()
根据本文档,我们应该首先从该URL获取,然后从userinfo_endpoint
以上结果获取以检索电子邮件,例如:
// json := json_to_map(body)
// get json[`userinfo_endpoint`]
// response, err = client.Get(json[`userinfo_endpoint`])
// body, err := ioutil.ReadAll(response.Body)
// response.Body.Close()
// json = json_to_map(body)
// json[`email`]
对于第二个问题,该oauth2.Config
结构是可重用的。
问题内容: 我想从IMAP4服务器获取整个邮件。在python文档中,如果发现此代码有效: 我想知道我是否总是可以相信data [0] [1]返回消息的主体。当我运行“ RFC822.SIZE”时,我只有一个字符串而不是一个元组。 我已经浏览了rfc1730,但无法弄清楚“ RFC822”的正确响应结构。也很难从imaplib文档中得知获取结果的结构。 这是我在获取时得到的: 但是当我获取时,我得
我正在尝试在Rails应用程序中使用Ruby中的谷歌Adwords API SDK实现托管账户。 用户流如下所示: 用户点击谷歌账号登录 用户授权我的应用使用谷歌账户信息 然后,用户可以检索托管Adword帐户的列表 我看过Adwords API文档,通过Stackoverflow查看,似乎无法通过Adwords API上的方法调用检索当前登录的用户名和电子邮件。所以我想知道,当我第一次授权我的应
我试图在我的进程中使用节点模块(在本例中为),如下所示: 注意:功能在我按下
我试图让我的应用程序向电子邮件发送一个新密码,但它会打开一个页面并给出消息“没有应用程序可以执行此操作”,标题为“发送电子邮件”(我知道我有),为什么?我想要一个新密码的想法,但首先我想向编辑文本中键入的电子邮件发送任何内容以进行测试。我尝试过在真实设备上运行它。 编辑:
在我的SMTP服务器代码中,我有一个mimessage实例,我想用它来提取传入的邮件正文(邮件文本)和邮件附件。为此,我在客户端和服务器端使用以下实现。但是,我只能检索邮件附件。代码以某种方式检测CustomerEngineer。ahmet thing两次,都没有包含邮件正文,即:“这是一个邮件正文”。不过我可以检索图像。 在我的java邮件客户端中,我创建了一个具有以下模式的邮件: 在服务器端,
问题内容: 我的Android应用程序中有一个Facebook登录选项,但尝试获取用户的电子邮件失败。在用户登录并添加到Parse.com用户表(具有有效的访问令牌)之后,我请求Facebook用户信息,但仅获取其ID和名称(即使电子邮件已设置为权限之一) )。 这是我的代码(在我的按钮的OnClickListener内部): 问题答案: 我想这与Graph API v2.4中的更改有关,该更改使