- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试使用“twitter”npm 包将视频媒体上传并发布到 Twitter。
在此期间我遇到一个错误:
error Error: HTTP Error: 400 Bad Request
at Request._callback (/Volumes/Office/Work/Pack3/developer/tweet-it/node_modules/twitter/lib/twitter.js:221:9)
at Request.self.callback (/Volumes/Office/Work/Pack3/developer/tweet-it/node_modules/request/request.js:185:22)
at Request.emit (events.js:180:13)
at Request.<anonymous> (/Volumes/Office/Work/Pack3/developer/tweet-it/node_modules/request/request.js:1157:10)
at Request.emit (events.js:180:13)
at IncomingMessage.<anonymous> (/Volumes/Office/Work/Pack3/developer/tweet-it/node_modules/request/request.js:1079:12)
at Object.onceWrapper (events.js:272:13)
at IncomingMessage.emit (events.js:185:15)
at endReadableNT (_stream_readable.js:1101:12)
at process._tickCallback (internal/process/next_tick.js:114:19)
代码库初始化库
var Twitter = require('twitter');
所有详细信息均通过 Twitter 应用控制台生成。
var twitterClient = new Twitter({
consumer_key: process.env.TWITTER_CONSUMER_KEY,
consumer_secret: process.env.TWITTER_CONSUMER_SECRET,
access_token_key: process.env.TWITTER_ACCESS_TOKEN_KEY,
access_token_secret: process.env.TWITTER_ACCESS_TOKEN_SECRET
});
function makePost(endpoint, params) {
return new Promise(function (resolve, reject) {
twitterClient.post(endpoint, params, function (error, data, response) {
if (error) {
reject(error);
} else {
resolve(data);
}
});
});
}
exports.postVideo = async function (req, res, next) {
var params = req.body;
const pathToMovie = './medias/video_3_640x360_1mb.mp4';
const mediaType = 'video/mp4'; // `'video/mp4'` is also supported
const mediaData = require('fs').readFileSync(pathToMovie);
const mediaSize = require('fs').statSync(pathToMovie).size;
console.log('mediaData ', mediaData);
try {
var options = {
command: 'INIT',
total_bytes: mediaSize,
media_type: mediaType,
};
//该请求即将完成
var mediaInit = await makePost('media/upload', options);
console.log('options ', options);
console.log('mediaInit ', mediaInit);
console.log('mediaInit.media_id_string ', mediaInit.media_id_string);
//此请求无效。
await makePost('media/upload', {
command: 'APPEND',
media_id: mediaInit.media_id_string,
media: mediaData,
segment_index: 0
});
var mediaFinalize = await makePost('media/upload', {
command: 'FINALIZE',
media_id: mediaInit.media_id_string,
});
console.log('mediaFinalize ', mediaFinalize);
var status = {
status: params.status,
media_ids: mediaFinalize.media_id_string
};
twitterClient.post('statuses/update', status, function (error, tweet, response) {
if (error) {
return next(error);
}
req.twitterStore = tweet;
return next();
});
} catch (error) {
console.log('error ', error);
return next(error);
}
};
使用的视频: https://www.sample-videos.com/video/mp4/360/big_buck_bunny_360p_1mb.mp4
引用:https://github.com/desmondmorris/node-twitter/tree/master/examples#chunked-media
最佳答案
示例中包含三个上传媒体的命令:
INIT 和 APPEND 命令在您的代码中似乎是正确的,但在 FINALIZE 命令中具有 media_id 作为输入。如果我没有误解代码,您应该使用“mediaInit”对象而不是“media_id_string”设置此参数。
/**
* Step 2 of 3: Append file chunk
* @param String mediaId Reference to media object being uploaded
* @return Promise resolving to String mediaId (for chaining)
*/
function appendUpload (mediaId) {
return makePost('media/upload', {
command : 'APPEND',
media_id : mediaId,
media : mediaData,
segment_index: 0
}).then(data => mediaId);
}
第二步返回 mediaId,该对象在第三步中使用:
/**
* Step 3 of 3: Finalize upload
* @param String mediaId Reference to media
* @return Promise resolving to mediaId (for chaining)
*/
function finalizeUpload (mediaId) {
return makePost('media/upload', {
command : 'FINALIZE',
media_id: mediaId <-------------
}).then(data => mediaId);
}
但是在您的代码中,您将“mediaInit.media_id_string”作为参数 media_id 的值传递:
var mediaFinalize = await makePost('media/upload', {
command: 'FINALIZE',
media_id: mediaInit.media_id_string, <-------------
});
这可能是您的代码中的错误。
关于node.js - Twitter 视频媒体上传无法正常工作 : Error: HTTP Error: 400 Bad Request,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50713748/
似乎最近我看到越来越多的人开始在他们的样式表中使用 media="all" 而不是 media="screen"。 我的问题是什么时候应该使用 media="all" 而不是 media="scree
我正在尝试使用 https://www.instagram.com/developer/endpoints/media/ ,但对于我使用的每个媒体 ID,我总是得到相同的结果: { "meta
哟,我正在为服务器制作一个 MOTD 供最终用户阅读。但是,对于使用较小显示器的用户来说,它看起来非常压缩,例如,当分辨率为 1280x1040 时,它会被拉低。我不熟悉 CSS 中的 @media
我在我的 CSS 文件中使用了 @media screen 而不是 (-webkit-min-device-pixel-ratio:0)。我的问题是关于指定的值,即在这种情况下为“0”。值的变化将如何
我正在播放 Activity 中的视频,我需要显示/隐藏顶部栏 View 以及媒体 Controller 。所以当媒体 Controller 在屏幕上时,我的顶部 View 应该是可见的,当媒体 Co
我在我的 WordPress 主题中创建了一个小部件来显示图像。到目前为止,小部件可以工作,我可以输入值并在前端显示这些值。 当我选择一个小部件并将其放入小部件区域时,媒体上传按钮不起作用。在 Wor
我正在使用MWFeedParser从此处读取Youtube原子供稿:here xml代码: 我如何获取媒体的网址:缩略图? 我试图更改MWFeedParser.m 由此: else if ([cu
当使用 Python 向 Instagram API 发出 GET 请求时,传递所需的变量,如下所示 photos = api.media_search(lat=latitude, lng=longi
我正在使用与媒体播放器关联的媒体 Controller 来播放声音。问题是媒体 Controller 一旦失去焦点就会隐藏起来。我有一个按钮,按下时会播放声音,媒体 Controller 会出现在屏幕
我有一个媒体播放器并与它关联了一个媒体 Controller 。控件工作正常。 我遇到了两个问题: 当媒体 Controller 获得焦点时,即用户触摸它然后触摸屏幕的另一部分时,媒体 Control
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
我在对话框中显示一个 VideoView 并向其附加一个媒体控件。 但是当我尝试点击媒体控件(播放、搜索栏等)时,对话框会消失。 媒体控制按钮不会被点击,而是将点击注册为 Dialog 的 Outsi
我目前正在使用 HTML 编写可打印文档,它将显示从数据库中提取的数据。我的想法是我将使用 HTML/CSS 使文档看起来不错,但它将专门用于打印。 文档的布局使用表格来控制数据库中数据的显示方式。
我需要在网络应用程序中打印我的报告。 我有在我的代码中。但它不应用任何样式。另一方面,如果我使用 在文档中编写 print.css 代码一切正常。 怎么了? 最佳答案 也许你在主样式之前插入打印样式
CSS html{ overflow-y:scroll; } js function showW(){ var a=($(window).width()); $('#
我编写了一个 Chrome 扩展程序,其中一个功能是您可以在您所在的页面中调出一个帮助面板,其中包含其使用指南。这个帮助面板是通过JS插入到页面中的,它的CSS都是通过$('#selector_for
我需要为 WORM 媒体开发归档软件。 这种类型的媒体允许通常的访问操作:读取、写入,但文件一旦写入,就无法修改或删除。 因为这样的媒体可能很昂贵,我想知道如何在开发阶段为测试创建一个假的 WORM
下面的这个 Activity 工作正常,但 mediaController 仅在我单击屏幕时显示。第二个问题是媒体 Controller 只显示 3 秒。我应该怎么做才能消除这个问题? public
我正在使用 VideoView 播放本地 mp4,我也在使用 MediaController。媒体控制栏未显示在我的视频剪辑下方,而是显示在屏幕中间。我使用 setAnchorView 将其附加到我的
我的布局包含 videoView 还有java代码中的Medicontrolleri: final MediaController mediaCont
我是一名优秀的程序员,十分优秀!