我尝试使用api:https://api.foursquare.com/v2/photos/add并在node.js代码后面的foursquare页面添加照片:
var accessToken = "myAccessToken";
var platformProfileId = "4squarePageId";
var b64content = "somebase64stringrepresentationofimage";
var url = "https://api.foursquare.com/v2/photos/add";
var formObj = {'oauth_token': accessToken, v: '20151009', 'pageId': platformProfileId, 'photo': b64content};
request({
url: url, //URL to hit
form: formObj, //form data
method: 'POST',
headers: { 'Content-Type': 'image/jpeg' }
}, function(error, response, body){
if(error) {
console.log(error);
return cb(error);
} else {
if(typeof body != 'object') {
body = JSON.parse(body);
}
console.log(body);
if(('meta' in body) && ('code' in body['meta']) && (body['meta']['code'] != 200)) {
return callback_inner("error");
}
var mediaIdStr = body['response']['id'];
return callback_inner(null, mediaIdStr);
}
});
我得到了以下回复:
{ meta: { code: 400, errorType: 'other', errorDetail: 'Missing file upload', requestId: '561fe6c1498e097824456e38' }, notifications: [ { type: 'notificationTray', item: [Object] } ], response: {} }
有谁能告诉我我哪里做错了?
更新
var queryObj = {'oauth_token': accessToken, v: '20151009', 'pageId': platformProfileId};
request({
url: url, //URL to hit
qs: queryObj, //query obj
method: 'POST',
headers: { 'Content-Type': 'image/jpeg' },
body: b64content
}, function(error, response, body){
if(error) {
console.log(error);
return cb(error);
} else {
if(typeof body != 'object') {
body = JSON.parse(body);
}
console.log(body);
if(('meta' in body) && ('code' in body['meta']) && (body['meta']['code'] != 200)) {
return callback_inner("error");
}
var mediaIdStr = body['response']['id'];
return callback_inner(null, mediaIdStr);
}
});
尝试将图片作为帖子邮件正文发送,但即使这样它也无法正常工作。
更新2:
var b64mediaFilesArr = results.C;
async.map(b64mediaFilesArr, function(b64content, callback_inner){
var imagename = new Date() + '.jpg';
var url = "https://api.foursquare.com/v2/photos/add";
var formObj = {
'oauth_token': accessToken,
'v': '20151009',
'pageId': platformProfileId,
'photo': {
value: b64content,
options: {
filename: imagename,
contentType: 'image/jpeg'
}
}
};
request({
url: url, //URL to hit
formData: formObj, //form data
method: 'POST',
headers: { 'Content-Type': 'image/jpeg' }
}, function(error, response, body){
if(error) {
console.log(error);
return cb(error);
} else {
if(typeof body != 'object') {
body = JSON.parse(body);
}
console.log(body);
if(('meta' in body) && ('code' in body['meta']) && (body['meta']['code'] != 200)) {
return callback_inner("error");
}
var mediaIdStr = body['response']['id'];
return callback_inner(null, mediaIdStr);
}
});
如果我使用上面的代码,那么响应会发生变化:
{ meta: { code: 400, errorType: 'param_error', errorDetail: 'InvalidPhotoFormat: Unable to determine photo type', requestId: '56207798498ee45703ab6059' }, notifications: [ { type: 'notificationTray', item: [Object] } ], response: {} }
此后我疯了。有人可以帮帮我吗?
解决方案
除了下面接受的答案,我解决了base64编码的问题。对于那些在您的Web应用程序中使用base64编码图像数据的人,您需要将原始二进制代码发送到Foursquare。这个SO答案帮助我做到了这一点。 Convert Binary.toString('encode64') back to Binary
答案 0 :(得分:3)
这些是对我有用的请求选项:
var options = {
'url': 'https://api.foursquare.com/v2/photos/add',
'qs': {
'v': '20161001',
'oauth_token': ACCESS_TOKEN,
'venueId': VENUE_ID
},
'formData': {
'file': {
'value': RAW_IMAGE_BUFFER,
'options': {
'filename': 'topsecret.jpg',
'contentType': 'image/jpg'
}
}
},
'json': true
};
然后打电话:
request.post(options, function(error, response, body){})
答案 1 :(得分:1)
photo
参数不存在。 photo
是响应字段。
图像数据作为HTTP请求的POST消息正文发送。
修改强>
您使用request
?请参阅https://github.com/request/request#multipartform-data-multipart-form-uploads
您不需要编码到base64。