IBM Watson机器学习手写数字样本笔记本认证错误

在处理使用IBM Watson机器学习识别手写数字笔记本的第6.1节时,调用Watson机器学习REST API来获取已发布模型列表时使用:

GET /v3/wml_instances/{instance_id}/published_models

端点时,出现了授权(401)错误,并返回以下响应文本:

{"trace":"-1xmid60eblabs","errors":[{"code":"invalid_token_format","message":"无效的令牌格式。应使用Bearer令牌格式。","target":{"type":"header","name":"Authorization"}}]}

笔记本中之前的REST API调用,使用从/v3/identity/token端点返回的授权令牌获取实例详情时运行正常。

看起来笔记本中可能存在错误。API授权方案是否发生了变化,导致笔记本无法正常工作?


回答:

REST API中的这个端点似乎期望认证形式为Authorization: <type> <credentials>,按照W3C在HTTP 1.0中的规定

我更新了笔记本代码,在头部的Authorization字段中添加了类型:

header = {'Content-Type': 'application/json', 'Authorization': 'Bearer ' + mltoken}

笔记本中用于创建在线部署和评分新数据的其余Watson机器学习API调用使用相同的头部,并且都正确执行。

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注