通过开放的Web服务对视频进行转码视频

使用eyevinn开源云在5分钟内完成媒体供应链视频转码

Eyevinn开源云旨在降低开源项目的启动门槛,并通过将部分收入回馈给贡献者。本指南将引导您完成使用Eyevinn开源云的开放式Web服务进行视频转码的步骤。

1. 获取API访问令牌和项目设置

访问Eyevinn开源云网络控制台的“设置/API”页面。复制API访问令牌,并将其存储在名为OSC_ACCESS_TOKEN的环境变量中。 如下图所示:

通过开放的Web服务对视频进行转码视频

export OSC_ACCESS_TOKEN=

创建一个Node.js项目:

mkdir transcodecd transcodenpm init

安装JavaScript客户端SDK:

npm install --save @osaas/client-core @osaas/client-services @osaas/client-transcode

创建一个名为transcode.js的文件,并添加以下代码:

const { context } = require('@osaas/client-core');const ctx = new context();

测试运行脚本:

node transcode.js

2. 设置用于存储转码视频文件的存储空间

(如果您已拥有S3兼容存储,可跳过此步骤)安装Minio客户端库:

npm install --save minio

添加名为setup()的新函数,该函数将上下文作为参数:

const { context, waitForInstanceReady } = require('@osaas/client-core');const { getMinioMinioInstance, createMinioMinioInstance } = require('@osaas/client-services');const minio = require('minio');const delay = (ms) => new Promise((res) => setTimeout(res, ms));async function setup(context) {  console.log('setting up storage');  let storage = await getMinioMinioInstance(context, 'devguide');  if (!storage) {    storage = await createMinioMinioInstance(context, {      name: 'devguide',      rootuser: 'admin',      rootpassword: 'abc12345678'    });    await waitForInstanceReady('minio-minio', 'devguide', context);    await delay(2000);  }  const client = new minio.Client({    endpoint: new URL(storage.url).hostname,    accessKey: 'admin',    secretKey: 'abc12345678',  });  const buckets = await client.listBuckets();  if (!buckets.find((bucket) => bucket.name === 'output')) {    await client.makeBucket('output');  }}async function main() {  const ctx = new context();  await setup(ctx);}main();

运行脚本将创建一个存储服务和存储桶。

3. 设置视频转码器

将以下代码添加到setup()函数中,创建视频转码实例。(如果已拥有S3存储桶,请替换以下S3凭据为您的存储桶凭据)

通义视频 通义视频

通义万相AI视频生成工具

通义视频 70 查看详情 通义视频

const { getEncoreInstance, createEncoreInstance } = require('@osaas/client-services');...async function setup(context) {  ...  let transcoder = await getEncoreInstance(context, 'devguide');  if (!transcoder) {    transcoder = await createEncoreInstance(context, {      name: 'devguide',      s3AccessKeyId: 'admin',      s3SecretAccessKey: 'abc12345678',      s3Endpoint: storage.url    });  }}

4. 转码视频文件

使用以下示例视频进行转码:https://testcontent.eyevinn.technology/mp4/vinn.mp4

将以下代码添加到main()函数中:

const { transcode } = require('@osaas/client-transcode');...async function main() {  const ctx = new context();  await setup(ctx);  await transcode(ctx, {    encoreInstanceName: 'devguide',    inputUrl: new URL('https://testcontent.eyevinn.technology/mp4/vinn.mp4'),    externalId: 'vinn',    outputUrl: new URL('s3://output/')  });}

为了接收转码进度通知,可以使用callbackUrl参数:

await transcode(ctx, {    encoreInstanceName: 'devguide',    inputUrl: new URL('https://testcontent.eyevinn.technology/mp4/vinn.mp4'),    externalId: 'vinn',    outputUrl: new URL('s3://output/'),    callbackUrl: 'https://example.com/webhook'  });

您可以使用S3客户端验证输出存储桶中的转码文件。

本指南简化了原文,并对代码块进行了格式调整,使其更易于阅读和理解。 同时,对部分语句进行了同义词替换,避免了直接照搬原文。

以上就是通过开放的Web服务对视频进行转码视频的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/371051.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 07:37:50
下一篇 2025年11月6日 07:38:27

相关推荐

  • JavaScript单元测试与Mocking

    单元测试通过隔离函数验证行为,Mocking可替换依赖如API或数据库,避免不稳定和慢速问题。Jest提供jest.fn()、jest.mock()等工具模拟返回值与调用,支持异步请求和错误场景,结合mockResolvedValue、toHaveBeenCalledWith等方法精准控制测试逻辑,…

    好文分享 2025年12月20日
    000
  • 异步编程进阶:Promise与async/await深度剖析

    Promise是状态机,通过then链式调用返回新Promise,async/await以同步语法处理异步,基于Promise并依赖事件循环的微任务队列,合理使用可避免回调地狱并提升代码可读性与健壮性。 JavaScript 是单线程语言,异步编程是其核心能力之一。随着应用复杂度提升,回调地狱(Ca…

    2025年12月20日
    000
  • 使用自定义Hooks抽象React中重复的加载和错误处理模式

    本文旨在探讨并解决react应用中常见的重复性代码模式,特别是针对异步操作的加载状态和错误处理逻辑。通过引入自定义hooks,我们可以有效地抽象这些通用逻辑,显著减少代码冗余,提升组件的可读性、可维护性及复用性,从而构建更清晰、更专业的react应用架构。 在构建复杂的React应用程序时,开发者经…

    好文分享 2025年12月20日
    000
  • JavaScript Service Worker高级应用

    Service Worker通过拦截请求、管理缓存、后台同步与消息推送,实现PWA的高级功能。1. 可采用Cache-First、Stale-While-Revalidate等策略精细化控制资源缓存;2. 通过fetch事件实现路由拦截与代理转发,支持微前端与灰度发布;3. 利用Background…

    2025年12月20日
    000
  • 如何利用JavaScript的Web Locks API管理资源锁?

    Web Locks API通过命名锁协调同源多上下文对共享资源的访问,防止竞态条件。使用navigator.locks.request(‘name’, callback)获取独占或共享锁,确保操作原子性;支持超时和ifAvailable配置避免阻塞;通过navigator.l…

    2025年12月20日
    000
  • 在React/Next.js中实现持久化与更新数据过滤器的策略

    在React/Next.js应用中,高效管理URL查询参数是实现持久化数据过滤的关键。本文将深入探讨如何构建一个健壮的系统,确保用户在应用新过滤器时,旧的过滤器状态得以保留,并实现查询参数的添加、更新与删除。通过利用Next.js App Router的`useRouter`、`usePathnam…

    2025年12月20日
    000
  • React组件状态与useEffect的响应式更新策略

    本文深入探讨了React组件在使用`useEffect`钩子时,如何响应`localStorage`中用户登录状态的变化。我们将分析常见的`useEffect`依赖项陷阱,揭示为何直接依赖`localStorage.getItem()`无法触发组件更新。文章将提出并批判一种非理想的轮询方案,最终倡导…

    2025年12月20日
    000
  • JavaScript计时器秒数处理异常:parseInt解析限制的解决方案

    本文探讨并解决了javascript计时器在处理秒数时出现的常见问题。当尝试从`mm:ss`格式的字符串中解析时间限制时,`parseint`函数由于其解析行为导致秒数部分被忽略,从而使计时器立即停止。文章提供了通过字符串分割和分别解析分钟与秒数来正确设置计时器上限的解决方案,确保计时器功能正常运行…

    2025年12月20日
    000
  • 在Ionic Capacitor应用中实现PDF文件打开功能

    本教程详细介绍了在Ionic Capacitor应用中正确打开PDF文件的方法。针对传统@ionic-native插件在Capacitor环境中可能遇到的兼容性问题,我们推荐使用专为Capacitor设计的第三方文件打开插件。文章将指导读者完成插件的安装、配置,并提供将应用内PDF资产复制到设备文件…

    2025年12月20日
    000
  • 解决Discord.js V14机器人无法检测私聊消息的问题

    在discord.js v14中,机器人无法检测私聊(dm)消息是一个常见问题,即使启用了`directmessages`意图。本文将深入探讨此问题的原因,并提供一个完整的解决方案。核心在于理解并正确配置`partials.channel`和`partials.message`,以确保机器人能够处理…

    2025年12月20日
    000
  • 优化Web组件焦点管理:实现“焦点进入”事件与焦点陷阱

    本文探讨了 `focusin` 事件的重复触发问题,并提供了模拟“焦点进入”事件的策略。在此基础上,文章详细阐述了如何构建一个健壮的焦点陷阱(focus trap),包括处理焦点首次进入、在容器内部循环以及在边界处重定向焦点,以提升复杂ui组件的键盘可访问性。 在构建复杂的Web界面时,尤其是在涉及…

    2025年12月20日
    000
  • Quill.js富文本编辑器中实现页面目录(TOC)的自动生成

    本文详细介绍了如何在quill.js富文本编辑器中实现自动生成页面目录(toc)的功能。通过定制quill的链接和标题模块,解决了默认链接行为不适用于内部跳转以及标题缺少唯一id的问题。文章提供了具体的javascript代码示例,指导用户如何修改链接和标题的行为,从而允许在编辑器内创建可导航的目录…

    2025年12月20日
    000
  • 避免重复请求和更新:React Native日期选择器优化

    本文旨在解决React Native应用中使用日期选择器时,`getOpenHours`函数被频繁调用以及`openHours`数组被重复更新的问题。通过引入`useEffect`钩子,监听日期变化,并优化数据更新逻辑,有效避免不必要的网络请求和状态更新,提升应用性能和用户体验。 在React Na…

    2025年12月20日
    000
  • Mongoose Schema中数组类型字段的正确定义与高效更新实践

    本教程旨在指导开发者如何在mongoose schema中正确定义和管理存储引用类型id的数组字段,如点赞列表或关注者列表。文章将详细阐述使用`mongoose.schema.types.objectid`和`ref`建立数据关联的重要性,并结合实际api路由更新操作,演示如何利用`$push`和`…

    2025年12月20日
    000
  • React组件中外部链接安全实践:解决“Script error”

    在react应用中,当组件渲染的外部链接被点击时,可能会出现“script error”运行时错误。这通常是由于未正确处理新标签页打开时的安全上下文所致。通过在“标签中同时使用`target=”_blank”`和`rel=”noopener noref…

    2025年12月20日
    000
  • JavaScript实现复选框动态增减数值:优化计算逻辑与避免常见错误

    本文探讨了如何使用javascript和html复选框实现数值的动态增减功能。针对常见的首次点击计算错误问题,文章详细分析了错误原因,并提出了一种更高效、准确的解决方案。通过利用事件监听和直接操作当前状态变量,我们能够避免不必要的循环和重复计算,确保数值更新的实时性和准确性,从而提升用户交互体验。 …

    2025年12月20日
    000
  • JavaScript GraphQL API开发

    使用Node.js和Apollo Server搭建GraphQL API,相比REST更高效精准。2. 初始化项目并安装apollo-server-express等依赖。3. 创建服务器实例,定义typeDefs和resolvers。4. 通过gql定义Schema,包括Query和Mutation…

    2025年12月20日
    000
  • JavaScript 的迭代器与生成器是如何协同工作以处理数据流的?

    JavaScript的迭代器与生成器通过惰性求值实现高效数据流处理。迭代器遵循协议提供next()方法,返回value和done属性;生成器函数用function定义,内部使用yield暂停执行,返回可迭代的生成器对象。例如numberStream()生成无限数字序列,每次调用next()才计算下一…

    2025年12月20日
    000
  • 使用Vue 组件实现平滑的模态框弹出动画

    本教程将详细介绍如何利用vue内置的“组件,为模态框(modal)实现平滑的淡入淡出动画效果。通过封装需要动画的元素并定义相应的css过渡类,我们可以轻松控制模态框的出现与消失,提升用户体验,避免直接使用`v-if`带来的动画限制。 在现代Web应用中,模态框(Modal)是常见的交互元…

    2025年12月20日
    000
  • 解决React useEffect Hook首次渲染时状态未更新的问题

    本文旨在帮助开发者解决在使用React的useEffect Hook获取数据并更新状态时,组件首次渲染时状态未能正确更新的问题。我们将分析常见的错误原因,并提供相应的解决方案,确保组件在首次加载时就能正确显示数据。 问题分析 在使用useEffect Hook从API获取数据并更新组件状态时,可能会…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信