版权声明:转载请注明出处。 https://blog.csdn.net/asing1elife/article/details/82788154
Java + jQuery 实现阿里云点播
阿里云播放器直接在线点播视频以及直播技术,此处记录点播实现过程
更多精彩
- 更多技术博客,请移步 asing1elife’s blog
官网
准备步骤
后端相关操作
在项目 pom 中引入所需 jar 包
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>3.2.2</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-vod</artifactId>
<version>2.7.0</version>
</dependency>
获取对接需要的数据
- 将 AccessKeyId 、AccessKeySecret 进行相应存储
新建 VideoController 用于接收前端获取视频播放凭证的请求
@Controller
@RequestMapping("/api/video")
public class VideoController extends AbstractBaseController {
@Autowired
private VideoServiceImpl videoServiceImpl;
/**
* 获取播放凭证
*
* @param videoId
* @return
*/
@RequestMapping(value = "/auth", method = RequestMethod.POST)
@ResponseBody
public ResponseData playAuth(@RequestParam final String videoId) {
return new SimpleActionHandler(request) {
@Override
protected void doHandle(ResponseData responseData) throws Exception {
responseData.setData(videoServiceImpl.getVideoPlayAuth(videoId));
}
}.handle();
}
}
新建 VideoServiceImpl 用于和阿里云播放器接口对接
@Service
public class VideoServiceImpl extends AbstractBaseService {
...
}
在 VideoServiceImpl 中添加获取客户端的 getClient() 方法
-
Constants.ALI_ACCESS_KEY_ID
和Constants.ALI_ACCESS_SECRET
是密钥,成对生成和使用 - 其他参数信息按照阿里云开发手册说明,均不需要改变
private DefaultAcsClient getClient() {
// 初始化配置
DefaultProfile profile = DefaultProfile.getProfile("cn-shanghai", Constants.ALI_ACCESS_KEY_ID, Constants.ALI_ACCESS_SECRET);
// 获取客户端
return new DefaultAcsClient(profile);
}
通过外部传入的视频 id 从客户端获取视频播放凭证
public String getVideoPlayAuth(String videoId) {
GetVideoPlayAuthRequest request = new GetVideoPlayAuthRequest();
GetVideoPlayAuthResponse response = null;
// 播放id
request.setVideoId(videoId);
try {
response = getClient().getAcsResponse(request);
} catch (ClientException e) {
logger.error("视频客户端获取失败!", e);
}
if (response != null) {
return response.getPlayAuth();
}
return null;
}
前端相关操作
引入播放器所需要的 css/js 文件
- 以下引入的 js 文件为通用版本,包括了 flash 和 h5 的播放器
- 如果只想单独引入 flash 或 h5 ,只需要将名称中间加上对应标识即可,例如
aliplayer-h5-min.js
- css 文件为公有版本,无需区分类型
<link rel="stylesheet" href="//g.alicdn.com/de/prismplayer/2.5.1/skins/default/aliplayer-min.css"/>
<script charset="utf-8" type="text/javascript" src="//g.alicdn.com/de/prismplayer/2.5.1/aliplayer-min.js"></script>
准备待转化为播放器的标签内容
- 标签中的
data-id
是将视频传入到阿里云播放器后端之后返回的一个 vid - 该 vid 可以通过 接口上传 也可以通过阿里云后端上传,此处不做介绍
<div class="prism-player" id="prismPlayer" data-id="281fc1687cb245658dc5e7462e54bc66"></div>
初始化视频播放器
-
$.ts.doAction
是经过封装后的 ajax 操作 -
Aliplayer({...})
则是具体的播放器初始化操作
var playerTag = target.find("#prismPlayer");
var videoId = playerTag.data("id");
// 移除文字标识
playerTag.empty();
// 非空验证
if (videoId === undefined) {
return;
}
$.ts.doAction("/api/video/auth", {
videoId: videoId
}, function () {
Aliplayer({
id: "prismPlayer",
autoplay: true,
width: "100%",
vid: videoId,
playauth: this.data
});
}, '', '', '');