ecshop二次开发--视频上传
1.前台展示效果:
2.后台展示效果:
3.代码实现:
后台实现过程:
1.在languages/zh_cn/admin/goods.php中插入
$_LANG['tab_video'] = '视频上传';
2显示标签在admin/templates/goods_info.htm中
将<span class="tab-back" id="video-table">{$lang.tab_video}</span>
写入到<div id="tabbar-div">里
然后,在form标签中将下面代码粘贴在下图之上
<table width="90%" id="video-table" align="center" style="display:none;"><tr><td><div id="drop_area" style="border:3px solid red;width:200px; height:150px">将将你所需上传视频拖拽到此即可</div><input type="hidden" id="video_val" name="goods_video"><progress value="0" max="10" id="prouploadfile"></progress><span id="persent">0%</span><br /><!--<button οnclick="xhr2()">ajax上传</button>--><input type="button" οnclick="stopup()" id="stop" value="上传"><script>//拖拽上传开始//-1.禁止浏览器打开文件行为document.addEventListener("drop",function(e){ //拖离e.preventDefault();})document.addEventListener("dragleave",function(e){ //拖后放e.preventDefault();})document.addEventListener("dragenter",function(e){ //拖进e.preventDefault();})document.addEventListener("dragover",function(e){ //拖来拖去e.preventDefault();})//上传进度var pro = document.getElementById('prouploadfile');var persent = document.getElementById('persent');function clearpro(){pro.value=0;persent.innerHTML="0%";}//2.拖拽var stopbutton = document.getElementById('stop');var resultfile="";var box = document.getElementById('drop_area'); //拖拽区域box.addEventListener("drop",function(e){var fileList = e.dataTransfer.files; //获取文件对象console.log(fileList)//检测是否是拖拽文件到页面的操作if(fileList.length == 0){return false;}//判断文件大小var num=1048576;var cha=Math.ceil(fileList[0].size)/num;if(cha>200){alert(Math.ceil(fileList[0].size/num));var str="<font color='red'>请选取文件在200M以下的视频</font>";document.getElementById('drop_area').innerHTML=str;return false;}//拖拉图片到浏览器,可以实现预览功能//规定视频格式//in_arrayArray.prototype.S=String.fromCharCode(2);Array.prototype.in_array=function(e){var r=new RegExp(this.S+e+this.S);return (r.test(this.S+this.join(this.S)+this.S));};var video_type=["video/mp4","video/ogg"];//创建一个url连接,供src属性引用var fileurl = window.URL.createObjectURL(fileList[0]);if(fileList[0].type.indexOf('image') === 0){ //如果是图片var str="<img width='200px' height='200px' src='"+fileurl+"'>";document.getElementById('drop_area').innerHTML=str;}else if(video_type.in_array(fileList[0].type)){ //如果是规定格式内的视频var str="<video width='200px' height='200px' controls='controls' src='"+fileurl+"'></video>";document.getElementById('drop_area').innerHTML=str;}else{ //其他格式,输出文件名//alert("不预览");var str="文件名字:"+fileList[0].name;document.getElementById('drop_area').innerHTML=str;}resultfile = fileList[0];console.log(resultfile);//切片计算filesize= resultfile.size;setsize=500*1024;filecount = filesize/setsize;//console.log(filecount)//定义进度条pro.max=parseInt(Math.ceil(filecount));i =getCookie(resultfile.name);i = (i!=null && i!="")?parseInt(i):0;if(Math.floor(filecount)<i){alert("已经完成");pro.value=i+1;persent.innerHTML="100%";}else{alert('可以上传');pro.value=i;p=parseInt(i)*100/Math.ceil(filecount)persent.innerHTML=parseInt(p)+"%";}},false);//3.ajax上传var stop=1;function xhr2(){if(stop==1){return false;}if(resultfile==""){alert("请选择文件")return false;}i=getCookie(resultfile.name);console.log(i)i = (i!=null && i!="")?parseInt(i):0 if(Math.floor(filecount)<parseInt(i)){alert("已经完成");return false;}else{//alert(i)}var xhr = new XMLHttpRequest();//第一步//新建一个FormData对象var formData = new FormData(); //++++++++++//追加文件数据//改变进度条pro.value=i+1;p=parseInt(i+1)*100/Math.ceil(filecount)persent.innerHTML=parseInt(p)+"%";//进度条if((filesize-i*setsize)>setsize){blobfile= resultfile.slice(i*setsize,(i+1)*setsize);}else{blobfile= resultfile.slice(i*setsize,filesize);formData.append('lastone', Math.floor(filecount));}formData.append('file', blobfile);formData.append('goods_id', "{$goods.goods_id}");//return false;formData.append('blobname', i); //++++++++++ formData.append('filename', resultfile.name); //++++++++++//post方式xhr.open('POST', 'goods.php?act=upload'); //第二步骤//发送请求xhr.send(formData); //第三步骤stopbutton.innerHTML = "暂停" //ajax返回xhr.onreadystatechange = function(){ //第四步 if ( xhr.readyState == 4 && xhr.status == 200 ) { console.log( xhr.responseText );if(xhr.responseText=="none"){alert("视频格式不支持");persent.innerHTML="0%";document.getElementById("drop_area").innerHTML="支持视频格式为'.flv' ,'.rmvb' , '.mp4'";pro.value=0;return false;}else if(i<filecount){xhr2();}else{alert(xhr.responseText);clearCookie(resultfile.name);document.getElementById("video_val").value=xhr.responseText;//location.href="文件";} } };//设置超时时间xhr.timeout = 20000;xhr.ontimeout = function(event){ alert('请求超时,网络拥堵!低于25K/s'); }i=i+1;setCookie(resultfile.name,i,365)}//设置cookiefunction setCookie(c_name,value,expiredays){var exdate=new Date()exdate.setDate(exdate.getDate()+expiredays)document.cookie=c_name+ "=" +escape(value)+((expiredays==null) ? "" : ";expires="+exdate.toGMTString()+";path=/")}//清除cookiefunction clearCookie(name) {setCookie(name, "", -1);}//获取cookiefunction getCookie(c_name){if (document.cookie.length>0){c_start=document.cookie.indexOf(c_name + "=")if (c_start!=-1){c_start=c_start + c_name.length+1 c_end=document.cookie.indexOf(";",c_start)if (c_end==-1) c_end=document.cookie.lengthreturn unescape(document.cookie.substring(c_start,c_end))}}return "" }function stopup(){if(stop==1){stop = 0 xhr2();}else{stop = 1 stopbutton.innerHTML = "继续" }}</script></td></tr></table>
然后,在admin/goods.php中创建一个上传视频的方法
代码如下:
//商品视频文件 上传方法elseif ($_REQUEST['act'] == 'upload'){$goods_id=isset($_REQUEST['goods_id'])?$_REQUEST['goods_id']:"";$sql="SELECT goods_video FROM ".$ecs->table("goods")." WHERE goods_id=".$goods_id;$sql1="SELECT goods_name FROM ".$ecs->table("goods")." WHERE goods_id=".$goods_id;$yuan=iconv('UTF-8','gb2312//IGNORE',$db->getOne($sql));//通过商品id 查询该商品的视频$goods_name=$db->getOne($sql1);//$yuan_dir="uploads/";//获得文件断点续传储存路径$dir1=iconv('UTF-8','gb2312//IGNORE',$_POST['filename']);//用于中文转码//ignore的意思是忽略转换时的错误,如果没有ignore参数,所有该字符后面的字符串都无法被保存//允许上传的文件扩展名$file_type = array( '.flv' ,'.rmvb' , '.mp4' );$filetype='.'.substr(strrchr($dir1, "."),1);//截取获得文件后缀名if(!in_array($filetype,$file_type)){echo "none";return false;die;}if($goods_name==""){$name="video/".md5($_POST['filename'].date("Y-m-dH:i")).'/';}else{$name="video/".md5($goods_name).'/';//目录名}if(!is_dir($name)){mkdir($name);}$dir2='admin/'.$name.$_POST['filename'];$dir="uploads/".md5($dir1);//还原文件原名file_exists($dir) or mkdir($dir,0777,true);$path=$dir."/".$_POST['blobname'];//$sql="UPDATE ".$ecs->table('goods')." SET goods_video='".$dir2."' WHERE goods_id=".$goods_id;//echo $sql;die;move_uploaded_file($_FILES["file"]["tmp_name"],iconv('UTF-8','gb2312//IGNORE',$path));if(isset($_POST['lastone'])){//echo $_POST['lastone'];$count=$_POST['lastone'];$fp = fopen("$name".$dir1,"abw");for($i=0;$i<=$count;$i++){$handle = fopen($dir."/".$i,"rb");fwrite($fp,fread($handle,filesize($dir."/".$i)));fclose($handle);}fclose($fp);//通过文件是否存在 判断是否上传完成if(file_exists($name.$dir1)){//$db->query($sql);echo $dir2; //'上传完成';}}}
然后,查找 /* 处理商品数据 */
找到 接值赋值的区域
接收传过来的 视频名称路径
代码:
$goods_video=isset($_POST['goods_video'])?$_POST['goods_video']:'';//视频
并在下方$sql语句中,添加字段和值
总共有三条$sql语句,都需要添加字段和值
2.
在admin文件夹中创建video文件夹
修改ecshop数据库的ecs_goods表,添加一个goods_video字段varchar类型
添加完,就可以上传视频了
后台完成。
前台实现过程
1.在Language/common.php中写入
$_LANG['goods_video'] = '商品视频:';
在goods.dwt中显示
2.在goods.php中(189行)写入以下代码
if($goods['goods_video']!=""){$goods_url="http://www.seven.com/ECShop/upload/".$goods['goods_video'];$goods['goods_video']='<video width="300" height="200" src="'.$goods_url.'" preload="none" controls="controls" ></video>';}else{$goods['goods_video']="该商品视频正在更新中,敬请期待!";}
3首先,复制goods.dwt第434行代码
粘贴,改为 视频或商品视频
最后在goods.dwt的489行后,回车,在其下,写入以下代码
<blockquote>
<!-- 视频 字段名-->
{$goods.goods_video}
</blockquote>
如图
这样,如果后台商品添加了视频,前台就可通过查看商品,查看视频了
文章转载:http://www.gehut.cn/
赞 (0)