相关文章推荐
从容的生姜  ·  使用 Java 列出 Blob - ...·  1 月前    · 
深沉的电脑桌  ·  职业球员的脚有多“丑陋”?这才是足球真实的样 ...·  3 月前    · 
另类的蚂蚁  ·  国务院关于印发“十三五”节能减排综合工作方案的通知·  4 月前    · 
非常酷的皮蛋  ·  注册kaggle帐号及kaggle绑定手机收 ...·  5 月前    · 
任性的弓箭  ·  夸克·  6 月前    · 
曾经爱过的西装  ·  Vue拖拽组件列表实现动态页面配置功能_vu ...·  1 年前    · 
Code  ›  Java 使用blob对H5视频播放进行加密开发者社区
blob
https://cloud.tencent.com/developer/article/1335832
乐观的签字笔
2 年前
用户1518699
0 篇文章

Java 使用blob对H5视频播放进行加密

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
最新优惠活动
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP 最新优惠活动
返回腾讯云官网
用户1518699
首页
学习
活动
专区
工具
TVP 最新优惠活动
返回腾讯云官网
社区首页 > 专栏 > nice_每一天 > Java 使用blob对H5视频播放进行加密

Java 使用blob对H5视频播放进行加密

作者头像
用户1518699
发布 于 2018-09-12 15:33:35
4.3K 0
发布 于 2018-09-12 15:33:35
举报

1.创建一个H5 <video>标签

<video id="sound" type="video/mp4" controls="controls" autoplay="autoplay"
       webkit-playsinline="true"    playsinline="true"   heigth="100%"></video>

2.创建请求获取视频源,并将视频源转为blob对象

    //创建XMLHttpRequest对象
    var xhr = new XMLHttpRequest();
    //配置请求方式、请求地址以及是否同步
    xhr.open('POST', '/armystudy/blob/getVideoSrc', true);
    //设置请求结果类型为blob
    xhr.responseType = 'blob';
    //请求成功回调函数
    xhr.onload = function(e) {
        if (this.status == 200) {//请求成功
            //获取blob对象
            var blob = this.response;
            //获取blob对象地址,并把值赋给容器
            $("#sound").attr("src", URL.createObjectURL(blob));
    xhr.send();

3.Java后台将视频转为视频源

   @ResponseBody
    @RequestMapping("/getVideoSrc")
    public OutputStream getVideoSrc(HttpServletRequest httpServletRequest,
                                    HttpServletResponse httpServletResponse){
        //1.创建文件对象
        File f = new File("E:/test/1.mp4");
        //2.获取文件名称
        String fileName = f.getName();
        //3.导出文件
        String agent = httpServletRequest.getHeader("User-Agent").toUpperCase();
        InputStream fis = null;
        OutputStream os = null;
        try {
            //4.获取输入流
            fis = new BufferedInputStream(new FileInputStream(f.getPath()));
            byte[] buffer;
            buffer = new byte[fis.available()];
            fis.read(buffer);
            httpServletResponse.reset();
            //5.由于火狐和其他浏览器显示名称的方式不相同,需要进行不同的编码处理
            if(agent.indexOf("FIREFOX") != -1){//火狐浏览器
                httpServletResponse.addHeader("Content-Disposition", "attachment;filename="+ new String(fileName.getBytes("GB2312"),"ISO-8859-1"));
            }else{//其他浏览器
                httpServletResponse.addHeader("Content-Disposition", "attachment;filename="+ URLEncoder.encode(fileName, "UTF-8"));
            //6.设置response编码
            httpServletResponse.setCharacterEncoding("UTF-8");
            httpServletResponse.addHeader("Content-Length", "" + f.length());
            //设置输出文件类型
            httpServletResponse.setContentType("video/mpeg4");
            //7.获取response输出流
            os = httpServletResponse.getOutputStream();
            os.flush();
            //8.输出文件
            os.write(buffer);
        }catch(Exception e){
            System.out.println(e.getMessage());
        } finally{
            //关闭流
            try {
                if(fis != null){ fis.close(); }
                if(os != null){ os.flush(); }
                if(os != null){os.close(); }
            } catch (IOException e) {
 
推荐文章
从容的生姜  ·  使用 Java 列出 Blob - Azure Storage | Microsoft Learn
1 月前
深沉的电脑桌  ·  职业球员的脚有多“丑陋”?这才是足球真实的样子_运动家_澎湃新闻-The Paper
3 月前
另类的蚂蚁  ·  国务院关于印发“十三五”节能减排综合工作方案的通知
4 月前
非常酷的皮蛋  ·  注册kaggle帐号及kaggle绑定手机收不到验证码的问题_kaggle怎么绑定手机号-CSDN博客
5 月前
任性的弓箭  ·  夸克
6 月前
曾经爱过的西装  ·  Vue拖拽组件列表实现动态页面配置功能_vue.js_脚本之家
1 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号