- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
所以我是 OAuth 和 Node.JS 的新手,但我必须创建一个 Flickr 机器人来上传大学项目的照片。据我了解,Node 本身不支持 multipart/formdata
请求,因此我手动构建了 POST 请求。
我知道以下代码不一定是干净的或最佳实践,但它意味着一次性黑客:服务器由一台计算机请求并且仅运行几个小时。
this.post = function(text, image) {
var me = this;
if (me.authenticated) {
fs.readFile(image, 'utf8', function(err,data) {
if (err) throw new Error(err);
var bound = (crypto.createHash('md5').update((Math.random()*9999999).toString()).digest('hex'));
var req = http.request({host:'api.flickr.com',port:80,path:'/services/upload/',method:'POST',
headers:{
'Content-Type':'multipart/form-data; boundary='+bound,
'Content-Length':data.length,
'Connection':'keep-alive'
}
}, function(res) {
res.setEncoding('utf8');
res.on('data', function(chunk) {
console.log(chunk);
});
console.log(me);
});
bound = "--"+bound;
req.on('error', function(msg) {console.log('FLICKR UPLOAD ERROR: '+msg.message);});
req.write(bound+"\r\n");
req.write('Content-Disposition: form-data; name="api_key"\r\n\r\n'+flickroptions.key);
req.write("\r\n"+bound+"\r\n");
console.log("sending token "+me.token);
req.write('Content-Disposition: form-data; name="auth_token"\r\n\r\n'+me.token);
req.write("\r\n"+bound+"\r\n");
req.write('Content-Disposition: form-data; name="api_sig"\r\n\r\n'+function() {
var str = 'api_key'+flickroptions.key;
str += 'api_token'+me.token;
return crypto.createHash('md5').update(str).digest('hex');
}());
req.write("\r\n"+bound+"\r\n");
req.write('Content-Disposition: form-data; name="photo"; filename="'+image+'"\r\n');
req.write('Content-Type: image/jpeg\r\n\r\n');
req.write(data);
req.write('\r\n'+bound+"--"); req.end();
});
}
}
上述函数生成的 POST 请求或多或少与 documentation 中的建议相同。 。但由于某种原因,请求响应说 auth_token
无效。
我正在使用以下两个函数设置身份验证:
this.init = function(text,image) {
var me = this;
fauth.getOAuthRequestToken({'oauth_callback':'http://192.168.0.19:7001/flickr'}, function(err, token, secret, results) {
if (err) console.log(err);
if (token && secret) {
me.secret = secret; me.token = token;
me.location = 'http://flicker.com/services/oauth/authorize?perms=write&oauth_token='+token;
}
});
}
//?oauth_token&oauth_verifier
this.auth = function(token, verifier) {
var me = this;
this.token = token; this.verifier = verifier;
fauth.getOAuthAccessToken(this.token, this.secret, this.verifier, function(err,token,secret,results) {
if (err) {console.log(err); return;}
me.results = results; me.authenticated = true;
me.token = token;
me.secret = secret;
me.post('hello world', '../eyes/memory/eyes000001.jpg');
});
}
其中 this.init
获取 Flickr 身份验证页面,this.auth
处理重定向的回调,然后调用 this.post
。 fauth
是 node-oauth 的一个实例。我是在这个过程中错过了一个步骤还是我一路上搞砸了?谢谢。
最佳答案
使用 OAuth 时,您不再使用 api_key
、api_sig
和 auth_token
参数,即使是上传也是如此。您应该改用 oauth_consumer_key
、oauth_signature
和 oauth_token
。
OAuth token 不是有效的旧式 auth_token,反之亦然。
查看我关于 Flickr 和 OAuth 的博客系列以了解更多详细信息:http://www.wackylabs.net/2011/12/oauth-and-flickr-part-1/
关于node.js - 使用 Node.JS 上传到 Flickr : Invalid auth_token,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7700960/
如何验证返回的 auth_token token = bundle.getString(AccountManager.KEY_AUTHTOKEN); ? 在 Android 上获得新用户后,我需要将它
我一直在尝试使用以下代码测试我的登录系统 from django.test import TestCase, Client from rest_framework.test import force_
我是 jQuery Mobile 和 Backbone.js 的新手,正在尝试在客户端创建移动应用程序 - 使用基于 django rest 框架的 API。 当我将我的用户名和密码发布到我的 api
我想使用 Terraform 在 GCP 中使用 slack 设置警报。 我的代码是: resource "google_monitoring_notification_channel" "slack
我正在构建移动网站,我想将 facebook connect 集成到我的常规网站中。 我正在使用使用 cookie 获取 session key 的 facebook 连接,我认为在移动设备上不推荐使
我正在使用 Mongodb 来存储用户数据,包括用户状态(在线|离线|忙碌)。到期时间只有几秒钟。如果几秒钟后用户没有出现(发送保活请求),我想将状态设置为离线。 我正在为此寻找可扩展的解决方案。我正
我正在尝试使用 API 通过外部应用程序进行身份验证。不幸的是,我们的企业帐户配置为通过 SAML 将身份验证重定向回我们的内部 AD 以使用 SSO。有什么方法可以配置“服务帐户”或至少让我的企业帐
我正在使用安装文档在 Ubuntu 16.04 上手动安装 Openstack Newton: https://docs.openstack.org/newton/install-guide-ubun
好的,所以我知道如何获取帐户列表,以便我可以让用户验证我的应用程序以使用他们的 Google 数据,但是,我对我的AUTH_TOKEN_TYPE 使用什么感到困惑>. 这是我目前的代码: Accoun
我有一个 Rails 应用程序,我们使用 user_id 并写入 session 变量(作为 cookie)。我将为浏览器和移动平台使用相同的 token 。 生成授权 token 的首选方法是什么?
第一次使用pyFacebook。我从字面上复制了 example application并将它放到我的服务器上。我已经创建了一个 FB 应用程序,现在当我尝试加载该应用程序时,基本上会发生浏览器不断刷
为 Django 编写的两个 JWT 包都给我带来了文档质量差的问题,所以我尝试了 DRF-auth_token 包。这是我遵循的一个很好的例子,Django Rest Framework Token
我有自定义 JSON 身份验证 API(没有设计等)。如何将 @user.authentication_token 渲染到响应 header 而不是正文? 在 sessions_controller.
我希望从 gcloud -> slack 设置一些警报,到目前为止已按照以下说明进行了测试并运行: https://cloud.google.com/monitoring/support/notifi
所以我是 OAuth 和 Node.JS 的新手,但我必须创建一个 Flickr 机器人来上传大学项目的照片。据我了解,Node 本身不支持 multipart/formdata 请求,因此我手动构建
我已经按照 this 安装了 OpenStack . 我正在尝试按照 here 中的教程安装 Savanna 当我运行这个命令时 savanna-venv/bin/python savanna-ven
我有一个 Android 应用程序,它允许用户向我的服务器添加内容。每个用户都应在此服务器上拥有一个帐户。 应用程序通过简单的 API 与服务器通信。 我想使用用户的 gmail 地址作为用户名,并使
我需要在 Rails 3.1 API 中使用基于 token 的身份验证以及最新版本的设计。到目前为止没有问题。 现在我不想将我的 :auth_token 附加到客户端的 POST/PUT 参数,而是
我是一名优秀的程序员,十分优秀!