找回密码
 立即注册

扫一扫,访问微社区

查看: 10776|回复: 4

微信小程序视频应用场景开发教程

  [复制链接]

910

主题

1190

回帖

3万

金钱

管理员

论坛管理员

积分
0

突出贡献优秀版主荣誉管理论坛元老

QQ
发表于 2016-10-28 16:06:29 | 显示全部楼层 |阅读模式
视频应用场景

微信小程序框架具备丰富的wxml/wxss/js api以及配套的文档帮助开发者快速地搭建时下热门的视频类应用,微信小程序框架主要提供了客户端的解决方案,但构建完整的视频类应用必须要有配套的云端支持,其中最为重要的是流媒体转码集群和流媒体播放服务集群。腾讯云作为专业的云服务提供商,汇聚腾讯强大的视频处理能力,具备一站式的视频点播/直播能力,可以为视频类小程序提供专业可靠的云端视频解决方案,使得开发者可以节省实现基础视频服务能力的成本,只专注于业务需求的开发。

部署和运行
整体架构
1. 准备域名和证书
2. Nginx 和 Node 代码部署
3. 配置 HTTPS
4. 域名解析
5. 开通 点播服务
6. 准备 云数据库MySQL
7. 启动新片预告示例 Node 服务
8. 启动新片预告 Demo
主要功能实现
获取视频列表、展示评论、提交评论
播放视频




新片预告是结合腾讯云点播 VOD云数据库 MySQL制作的一个微信小程序示例。在代码结构上包含如下两部分:

  • app: 新片预告应用包代码,可直接在微信开发者工具中作为项目打开
  • server: 搭建的Node服务端代码,作为服务器和app通信,提供 CGI 接口示例用于拉取云数据库上的视频列表、评论列表,将评论数据提交到云数据库


新片预告主要功能如下:

  • 支持分页滚动加载视频列表
  • 点击海报跳转至详情页播放视频
  • 对视频进行评论
  • 展示视频的评论列表



部署和运行

拿到了本小程序源码的朋友可以尝试自己运行起来。

整体架构


1. 准备域名和证书

在微信小程序中,所有的网路请求受到严格限制,不满足条件的域名和协议无法请求,具体包括:

只允许和在 MP 中配置好的域名进行通信,如果还没有域名,需要注册一个。
网络请求必须走 HTTPS 协议,所以你还需要为你的域名申请一个 SSL 证书。
腾讯云提供域名注册证书申请服务,还没有域名或者证书的可以去使用
域名注册好之后,可以登录微信公众平台配置通信域名了。


注意:需要将 www.qcloud.la 设置为上面申请的域名

2. Nginx 和 Node 代码部署

小程序服务要运行,需要进行以下几步:

  • 部署 Nginx,Nginx 的安装和部署请大家自行搜索(注意需要把 SSL 模块也编译进去)
  • 配置 Nginx 反向代理到 http://127.0.0.1:9994
  • Node 运行环境,可以安装 Node V6.6.0
  • 部署 server 目录的代码到服务器上,如 /data/release/qcloud-applet-video
  • 使用 npm install 安装依赖模块
  • 使用 npm install pm2 -g 安装 pm2


上述环境配置比较麻烦,新片预告的服务器运行代码和配置已经打包成腾讯云 CVM 镜像,推荐大家直接使用。

  • 镜像部署完成之后,云主机上就有运行 WebSocket 服务的基本环境、代码和配置了。
  • 腾讯云用户可以免费领取礼包,体验腾讯云小程序解决方案。
  • 镜像已包含所有小程序的服务器环境与代码,需要体验小程序的朋友无需重复部署


3. 配置 HTTPS

镜像中已经部署了 nginx,需要在 /etc/nginx/conf.d 下修改配置中的域名、证书、私钥。


配置完成后,即可启动 nginx。
  1. nginx
复制代码

4. 域名解析

我们还需要添加域名记录解析到我们的云服务器上,这样才可以使用域名进行 HTTPS 服务。

在腾讯云注册的域名,可以直接使用云解析控制台来添加主机记录,直接选择上面购买的 CVM。


解析生效后,我们在浏览器使用域名就可以进行 HTTPS 访问。


5. 开通 点播服务

新片预告示例的播放资源是存储在 腾讯云点播 上的mp4文件,要使用 点播 服务,需要登录点播 管理控制台,然后在其中完成以下操作:

  • 上传视频资源,点播几乎支持所有主流的视频格式上传
  • 转码成功后获取mp4或m3u8源地址




目前微信小程序video组件经测试支持mp4和m3u8格式,其中 m3u8 格式只能在手机上使用,开发者可以使用腾讯云点播控制台将视频源转码成 mp4 或 m3u8 格式,并且腾讯云点播会对播放的资源进行CDN加速。



6. 准备 云数据库MySQL

示例中拉取的视频和评论列表都是存储在 云数据库 上,要使用 云数据库 服务需要完成以下操作

购买,注意购买的云数据库需要与云服务器同在一个地域分区
初始化流程,本示例选用的是utf8编码
点击云数据库 控制台操作栏的登录按钮,登录到phpMyAdmin创建数据库并在当前数据库中导入本示例中的SQL文件

注意:导入SQL文件中包含了 点播 上传的视频列表,开发者可以基于云数据库自行开发维护一个视频发布管理系统,因为此内容跟本示例暂不相关,所以不再详述。




7. 启动新片预告示例 Node 服务

在镜像中,新片预告示例的 Node 服务代码已部署在目录/data/release/qcloud-applet-video下:

进入该目录:
  1. cd /data/release/qcloud-applet-video
复制代码

在该目录下有个名为config.js的配置文件(如下所示),按注释修改对应的 MySQL 配置:

  1. module.exports = {
  2.     // Node 监听的端口号
  3.     port: '9994',
  4.     ROUTE_BASE_PATH: '/applet',

  5.     host: '填写开通 MySQL 时分配的内网IP',
  6.     user: '填写MySQL用户名',
  7.     password: '填写MySQL密码',
  8.     database: '填写上一步中创建的MySQL数据名',
  9. };
复制代码
示例使用pm2管理 Node 进程,执行以下命令启动 node 服务:
  1. pm2 start process.json
复制代码

8. 启动新片预告 Demo

在微信开发者工具将新片预告应用包源码添加为项目,并把源文件config.js中的通讯域名修改成上面申请的域名。


然后点击调试即可打开新片预告Demo开始体验。


主要功能实现

获取视频列表、展示评论、提交评论

通过node的mysql模块连接mysql,进行查询,插入操作
以下是查询评论列表的示例代码
  1. const mysql = require('mysql');
  2. const config = require('../../../config');

  3. let vid = this.req.query.vid;
  4. if (!vid) {
  5.     this.res.json({ code: -1, msg: 'failed', data: {} });
  6.     return;
  7. }

  8. //CDB Mysql配置
  9. let connection = mysql.createConnection({
  10.     host: config.host,
  11.     password: config.password,
  12.     user: config.user,
  13.     database: config.database
  14. });

  15. //开启数据库连接
  16. connection.connect((err) => {
  17.     if (err) {
  18.         this.res.json({ code: -1, msg: 'failed', data: {} });
  19.     }
  20. });

  21. //查询列表
  22. connection.query('SELECT * from comment where vid = ? order by id desc', [vid], (err, result) => {
  23.     if (err) {
  24.         this.res.json({ code: -1, msg: 'failed', data: {} });
  25.         return;
  26.     }

  27.     this.res.json({
  28.         code: 0,
  29.         msg: 'ok',
  30.         data: result,
  31.     });
  32. });
  33. //查询完后关闭连接
  34. connection.end();
复制代码

播放视频
  1. <video src="{{videoUrl}}" binderror="videoErrorCallback"></video>
复制代码



属性名类型说明
srcString要播放视频的资源地址
binderrorEventHandle当发生错误时触发error事件,event.detail = {errMsg: 'something wrong'}

播放视频使用的是video标签,目前官方文档上只给出了两个参数说明,笔者测试了src支持加载mp4和m3u8格式视频,
video标签的控制条暂时没办法自定义样式以及隐藏

游客,如果您要查看本帖隐藏内容请回复

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

0

主题

4

回帖

54

金钱

新人求带

积分
0
发表于 2016-12-14 11:46:44 | 显示全部楼层
学习啥也不说了,感谢楼主分享哇!

0

主题

9

回帖

85

金钱

新人求带

积分
0
发表于 2017-1-9 18:51:36 | 显示全部楼层
啥也不说了,感谢楼主分享哇!

0

主题

24

回帖

250

金钱

新人求带

积分
0
发表于 2017-2-11 10:48:48 | 显示全部楼层
正需要,支持楼主大人了!

0

主题

408

回帖

600

金钱

新人求带

积分
0
发表于 2020-4-24 14:31:36 | 显示全部楼层
我有流量,你有产品,我们就可以合作,有意的个人开发者朋友可以联系微,信,号j i m 2 0 1 8 0 6 8 8,详聊
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|微信小程序开发|教程|文档|资源汇总_即速论坛 ( 粤ICP备14097199号-1  

GMT+8, 2024-11-22 09:34 , Processed in 0.131622 second(s), 38 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表