IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> php分片上传视频 -> 正文阅读

[PHP知识库]php分片上传视频

页面内容

#uploadVideo {
?? ? ?text-align: center;
?? ? ?line-height: 30px;
?? ? ?font-size: 12px;
?? ? ?overflow: hidden;
?? ? ?display: inline-block;
?? ? ?/*position: absolute;*/
?? ? ?width: 100px;
?? ? ?height: 30px;
?? ? ?background-color: #ccc;
?? ? ?border: 1px solid #000;
?? ? ?border-radius: 4px;
?? ? ?margin-top: 100px;
?? ? ?margin-left: -303px;
?? ? ?margin-bottom: -40px;
?? ?}

#progress{
?? ? ?? ?display: inline-block;
? ? ? width: 300px;
? ? ? height: 20px;
? ? ? background-color:#f7f7f7;
? ? ? box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);
? ? ? border-radius:4px;
? ? ? background-image:linear-gradient(to bottom,#f5f5f5,#f9f9f9);
? ? ? margin-bottom: 160px;
?? ? ?margin-left: 51px;
? ? }
?
? ? #finish{
? ? ? background-color: #149bdf;
? ? ? background-image:linear-gradient(45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);
? ? ? background-size:40px 40px;
? ? ? height: 100%;
? ? }
?

<div>
?? ??? ??? ??? ? ?? ?<video controls="controls" id="thumbnail-preview-video" src="http://oss.zhhmgj.com/test/2.mp4" type="video/mp4" style="cursor: pointer;width: 280px;height: 210px;"></video>
?? ??? ??? ??? ? ?? <div id="progress">
?? ??? ??? ??? ??? ??? ?<div id="finish" style="width: 0%;" progress="0"></div>
?? ??? ??? ??? ??? ?</div>
?? ? ?? ??? ??? ??? ?<span id="uploadVideo">
?? ??? ??? ??? ??? ? ? ? ?<input type="file" id="video_url" name="file" size="1" class='file' />
?? ??? ??? ??? ??? ? ? ? ?<a href="#" class="upVideo">上传视频</a >
?? ??? ??? ??? ??? ?</span>
? ? ? ? ? ? ? ? ? ? <a href="#" class="fileMerge" id="fileMerges">合并压缩</a>

</div>

??? ?//视频分片上传开始
??? ??var fileForm = document.getElementById("video_url");
? ? ? ?var upload = new Upload();
? ? ? ?fileForm.onchange = function(){
? ? ? ? ? ?var fileVIdeo = ?document.getElementById("video_url").files[0];
? ? ? ? ? ?var video_name=fileVIdeo['name'];
?? ??? ?// //获取视频时长开始
? ? ? ? ?var url = URL.createObjectURL(fileVIdeo);
? ? ? ? ?var audioElement = new Audio(url);
? ? ? ? ?audioElement.addEventListener("loadedmetadata", function (_event) {
? ? ? ? ? ? ?var duration = audioElement.duration;
? ? ? ? ? ? ?var video_time=Math.ceil(duration);
? ? ? ? ? ? ?$('#video_time').val(video_time);
? ? ? ? ?});
? ? ? ? ?$('#video_name').val(video_name);
? ? ? ? ?upload.addFileAndSend(this);
? ? ? ?}
?? ?//上传类
?? ??function Upload(){
?? ? var xhr = new XMLHttpRequest();
?? ? var form_data = new FormData();
?? ? const LENGTH = 1024 * 1024*10;
?? ? var start = 0;
?? ? var end = start + LENGTH;
?? ? var blob;
?? ? var blob_num = 1;
?? ? var is_stop = 0
?? ? //对外方法,传入文件对象
?? ? this.addFileAndSend = function(that){
?? ? ? var file = that.files[0];
?? ? ? blob = cutFile(file);
?? ? ? sendFile(blob,file);
?? ? ? blob_num += 1;
?? ? }
?? ? //停止文件上传
?? ? this.stop = function(){
?? ? ? xhr.abort();
?? ? ? is_stop = 1;
?? ? }
?? ? //切割文件
?? ? function cutFile(file){
?? ? ? var file_blob = file.slice(start,end);
?? ? ? start = end;
?? ? ? end = start + LENGTH;
?? ? ? return file_blob;
?? ? };
?? ? //发送文件
?? ? function sendFile(blob,file){
?? ? ? var total_blob_num = Math.ceil(file.size / LENGTH);
?? ? ? form_data.append('file',blob);
?? ? ? form_data.append('blob_num',blob_num);
?? ? ? form_data.append('total_blob_num',total_blob_num);
?? ? ? form_data.append('file_name',file.name);
?? ? ? ?$('#total_blob_num').val(total_blob_num);
?? ? ? xhr.open('POST','/admin/Alioss/handleaudio',false);
?? ? ? xhr.onreadystatechange = function () {
?? ? ? ? var progress;
?? ? ? ? var progressObj = document.getElementById('finish');
?? ? ? ? if(total_blob_num == 1){
?? ? ? ? ? progress = '100%';
?? ? ? ? }else{
?? ? ? ? ? ? progress = Math.min(100,(blob_num/total_blob_num)* 100 ) +'%';
?? ? ? ? }
?? ? ? ? progressObj.style.width = progress;
?? ? ? ? if(progress=='100%'){
?? ? ? ? ? ? is_stop=1;
?? ? ? ? }
? ? ? ? ?var t = setTimeout(function(){
?? ? ? ? ? if(start < file.size && is_stop === 0){
?? ? ? ? ? ?blob = cutFile(file);
?? ? ? ? ? ? sendFile(blob,file);
?? ? ? ? ? ? blob_num += 1;
?? ? ? ? ? }else{
?? ? ? ? ? ? setTimeout(t);
?? ? ? ? ? }
?? ? ? ? },1000);
?? ? ? }
?? ? ? xhr.send(form_data);

?? ? }
??}

? //视频分片上传结束

?//视频合成压缩开始
??$('.fileMerge').click(function(){
?? ? ? var formData = new FormData();
?? ? ? var totalBlobNum=$('#total_blob_num').val();
?? ? ? var fileName=$('#video_name').val();
?? ??formData.append('totalBlobNum', totalBlobNum);
?? ??formData.append('fileName', fileName);
?? ??formData.append('formerly_name', fileName);
?? ? ? //提交后台处理
?? ?? ? ? $.ajax({
?? ?? ? ? ?url: '/admin/Alioss/fileMerge',
?? ?? ? ? ?type: 'POST',
?? ?? ? ? ?cache: false,
?? ?? ? ? ?data:formData,
?? ?? ? ? ?dataType: "JSON",
?? ?? ? ? ?processData: false,
?? ?? ? ? ?contentType: false
?? ?? ? ? }).done(function(res) {
?? ?? ? ? ?if(res.code == 1){
?? ?? ? ? ? ? ?//视频压缩
?? ?? ? ? ? ? ?$.ajax({
?? ?? ? ? ? ? ?url: '/admin/Alioss/compress',
?? ?? ? ? ? ? type: 'POST',
?? ?? ? ? ? ? ?cache: false,
?? ?? ? ? ? ? ?data:formData,
?? ?? ? ? ? ? ?dataType: "JSON",
?? ?? ? ? ? ? ?processData: false,
?? ?? ? ? ? ? ?contentType: false
?? ?? ? ? ? ? }).done(function(res) {
?? ?? ? ? ? ? ?if(res.code == 1){
?? ?? ? ? ? ? ? ? ?$('#video_data').val(res.url);
?? ?? ? ? ? ? ? ? ?document.getElementById("thumbnail-preview-video").src = res.url;
?? ?? ? ? ? ? ? ? ?alert(res.msg);
?? ?? ? ? ? ? ?}else{
?? ?? ? ? ? ? ? ? alert(res.msg);
?? ?? ? ? ? ? ?}
?? ?? ? ? ? ? }).fail(function(res) {

?? ?? ? ? ? ? });
?? ?? ? ? ?}else{
?? ?? ? ? ? ? ?alert(res.msg);
?? ?? ? ? ?}
?? ?? ? ? }).fail(function(res) {

?? ?? ? ? });
?? })
? //视频合成压缩结束

分片上传接口

function handleaudio(Request $request){
? ? ? ? //第一步 分片上传
? ? ? ? //接收参数
? ? ? ? $file_url=$request->file('file');
? ? ? ? $tmpPath=$file_url->getInfo()['tmp_name'];
? ? ? ? $blobNum=$request->param('blob_num');
? ? ? ? $totalBlobNum=$request->param('total_blob_num');
? ? ? ? $fileName=$request->param('file_name');
? ? ? ? $blob_num=$blobNum+1; ? ? ? ?
? ? ? ? //继续分片上传
? ? ? ? $this->touchDir(self::video_path);
? ? ? ? $filename = self::video_path.'/'.$blobNum.$fileName;
? ? ? ? move_uploaded_file($tmpPath,$filename);

? ? }

//建立上传文件夹
? ? function touchDir($filepath=''){
? ? ? ? if(!file_exists($filepath)){
? ? ? ? ? ? return mkdir($filepath);
? ? ? ? }else{
? ? ? ? ? ? return true;
? ? ? ? }
? ? }

//视频文件合成
? ? function fileMerge(Request $request){//$blobNum='',$totalBlobNum='',$filepath='',$fileName=''
? ? ? ? $data=$request->param();
? ? ? ? if(empty($data['totalBlobNum']) || empty($data['fileName'])){
? ? ? ? ? ? $rs['code']=0;
? ? ? ? ? ? $rs['msg']='参数缺失';
? ? ? ? ? ? $rs['data']=[];
? ? ? ? ? ? echo json_encode($rs);exit();
? ? ? ? }
? ? ? ? $totalBlobNum=$data['totalBlobNum'];
? ? ? ? $filepath=self::video_path;
? ? ? ? $fileName=$data['fileName'];
? ? ? ? //分片视频进行合并处理
? ? ? ? $blob = '';
? ? ? ? for($i=1; $i<= $totalBlobNum; $i++){
? ? ? ? ? ? $blob .= file_get_contents($filepath.'/'.$i.$fileName);
? ? ? ? }
? ? ? ? file_put_contents($filepath.'/'. $fileName,$blob);
? ? ? ? //合并完后分片的视频删除
? ? ? ? for($i=1; $i<= $totalBlobNum; $i++){
? ? ? ? ? ? @unlink($filepath.'/'.$i.$fileName);
? ? ? ? }
? ? ? ? $rs['code']=1;
? ? ? ? $rs['msg']='文件合成成功';
? ? ? ? $rs['data']=[];
? ? ? ? echo json_encode($rs);exit();
? ? }

//视频文件压缩 上传oss
? ? function compress(Request $request){
? ? ? ? $data=$request->param();
? ? ? ? if(empty($data['formerly_name'])){
? ? ? ? ? ? $rs['code']=0;
? ? ? ? ? ? $rs['msg']='参数缺失';
? ? ? ? ? ? $rs['data']=[];
? ? ? ? ? ? echo json_encode($rs);exit();
? ? ? ? }
? ? ? ? $catalogue=self::video_path.'/';//要压缩的视频目录
? ? ? ? $formerly_name=$data['formerly_name'];//要压缩的视频原文件名
? ? ? ? $after_name='新'.$formerly_name;//压缩之后的视频文件名
? ? ? ? $cmd="ffmpeg -i $catalogue$formerly_name -s 360x640 -b:v 862k $catalogue$after_name";//2>&1
? ? ? ? $commandOutput =exec($cmd,$output,$status);
? ? ? ? if($status==0){
? ? ? ? ? ? @unlink($catalogue.$formerly_name);
? ? ? ? ? ? //上传oss
? ? ? ? ? ? $file_url=$catalogue.$after_name;
? ? ? ? ? ? $content=file_get_contents($file_url);
? ? ? ? ? ? $object=self::catalogue.'/'.$after_name;
? ? ? ? ? ? $OssClient=new OssClient(self::accessKeyId,self::accessKeySecret,self::endpoint);
? ? ? ? ? ? $result=$OssClient->putObject(self::bucket,$object,$content);
? ? ? ? ? ? if(!empty($result)){
? ? ? ? ? ? ? ? if(!empty($result['info'])){
? ? ? ? ? ? ? ? ? ? if($result['info']['http_code']==200){
? ? ? ? ? ? ? ? ? ? ? ? @unlink($catalogue.$after_name);
? ? ? ? ? ? ? ? ? ? ? ? $rs['code'] = 1;
? ? ? ? ? ? ? ? ? ? ? ? $rs['msg'] = '上传成功';
? ? ? ? ? ? ? ? ? ? ? ? $rs['url'] = 'http://oss.zhhmgj.com/'.self::catalogue.'/'.$after_name;
? ? ? ? ? ? ? ? ? ? ? ? echo json_encode($rs);exit();
? ? ? ? ? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? ? ? ? ? $rs['code'] = 0;
? ? ? ? ? ? ? ? ? ? ? ? $rs['msg'] = '阿里云返回上传状态码不正确';
? ? ? ? ? ? ? ? ? ? ? ? $rs['url'] = "";
? ? ? ? ? ? ? ? ? ? ? ? echo json_encode($rs);exit();
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? ? ? ? ? $rs['code'] = 0;
? ? ? ? ? ? ? ? ? ? ? ? $rs['msg'] = '返回上传详细信息失败';
? ? ? ? ? ? ? ? ? ? ? ? $rs['url'] = "";
? ? ? ? ? ? ? ? ? ? ? ? echo json_encode($rs);exit();
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? ? ? ? ? $rs['code'] = 0;
? ? ? ? ? ? ? ? ? ? ? ? $rs['msg'] = '上传失败';
? ? ? ? ? ? ? ? ? ? ? ? $rs['url'] = "";
? ? ? ? ? ? ? ? ? ? ? ? echo json_encode($rs);exit();

? ? ? ? ? ? }
? ? ? ? }
? ? }

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2022-04-13 22:06:44  更:2022-04-13 22:12:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/18 21:11:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码