我已经编写了一个云函数,该函数接收一个Base64字符串并将其传递到Google Cloud Vision API中,我还在客户端上编写了一个函数,该函数通过HTTP调用Firebase云函数。
虽然数据可以很好地从客户端传递到云功能,但服务器对Google Vision API的请求不起作用。我得到一个状态码500
错误。
我很确定这与授权承载令牌有关,因为在shell中使用环境变量GOOGLE_APPLICATION_CREDENTIALS
运行它就可以了。顺便说一句,运行Cloud函数时会出现相同的环境变量。
curl -X POST \
-H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \
-H "Content-Type: application/json; charset=utf-8" \
-d @request.json \
https://vision.googleapis.com/v1/images:annotate
我是否使用了正确的承载令牌(请参见下面的代码)?我怎样才能通过这个请求呢?
auth.currentUser.getIdToken()
.then((idToken) => {
axios({
method: 'post',
url: 'http://localhost:5001/project/my-endpoint',
data: qs.stringify({
imageData: image,
token: idToken
}),
maxContentLength: 100000,
maxBodyLength: 100000
}) // .then, .catch follows...
})
axios({
method: 'post',
url: 'https://vision.googleapis.com/v1/images:annotate',
headers: {
"Authorization": `Bearer ${request.body.token}`,
"Content-Type": "application/json; charset=utf-8"
},
data: {
"requests": [
{
"image": {
"content": request.body.imageData
},
"features": [
{
"type": "DOCUMENT_TEXT_DETECTION"
}
]
}
]
},
maxContentLength: 100000,
maxBodyLength: 100000
}) // .then, .catch follows...
最好的解决方案是使用客户端库。谷歌页面上的文档不是很好,但是这些文档要好得多。
代码应该如下所示:
const vision = require('@google-cloud/vision')
const client = new vision.ImageAnnotatorClient()
const fileName = request.body.imageData // base64 image data
const req = {
image: {
content: fileName
}
}
client.documentTextDetection(req)
.then(result => response.send(result))
.catch(error => response.send(error))
})
当一个人试图使用azure AD承载令牌访问我们的系统时,这个获取和缓存资源令牌的工作流程是不存在的。 所以我的问题是,我如何使用承载令牌来启用它?如何才能像使用OpenIDConnect一样请求额外的资源令牌?是否可以使用ADAL从承载令牌获取授权代码?
那是ID还是访问令牌?
是否可以使用来自Google API客户端Javascript库的承载令牌来授权Google云存储桶,而无需向用户请求https://www.googleapis.com/auth/devstorage范围。该桶具有对所有Google帐户的读写访问权限。
我正在尝试Google Cloud Vision API(测试版),它返回“权限被拒绝”消息。但该项目启用了“云视觉API”。感谢您的帮助。 谷歌API浏览器中的错误详细信息
嘿,我想弄清楚如何为REST API POST调用使用OAuth授权令牌。 文件规定: 如果发生此错误,您的应用程序可以通过重新运行相应的流来请求新的访问令牌。 目前我的VB. net代码是这样的: 我不断收到一个错误:远程服务器返回一个错误:(401)未经授权。 我在下面的帖子中发现了这一点: Yammer API要求OAuth数据位于标头中。如果您查看他们获取数据的示例,您将看到请求如下所示。