PHP的APC模块实现上传进度条


Posted in PHP onOctober 27, 2015

APC模块,它的全称是Alternative PHP Cache。APC可以将所有PHP代码会被缓存起来, 另外它可提供一定的内存缓存功能.但是这个功能并不是十分完美,有报告说如果频繁使用APC缓存的写入功能,会导致不可预料的错误.如果想使用这个功能,可以看看apc_fetch,apc_store等几个与apc缓存相关的函数。
值得高兴的是从5.2开始APC加入了APC_UPLOAD_PROGRESS,解决了困扰大家已久的进度条问题。并且它把原来的上传时把临时文件全部缓存到内存改成了当临时文件达到设定值时就自动保存到硬盘,有效地改善了内存利用状况。
它的作用原理是在上传时候赋予每个上传一个唯一的ID,当PHP 脚本收到一个上传文件时,解释程序将自动检查$_POST数组中名为APC_UPLOAD_PROGRESS 的隐藏字段,它将成为缓存变量,存储关于上传的信息,这样脚本就可以通过上传的ID来访问上传文件的状态信息。

<!?以下为上传表单?>
<form enctype="multipart/form-data" id="upload_form" action="" method="POST">
<input type="hidden" name="APC_UPLOAD_PROGRESS" id="progress_key" value="upid"/>
视频标题:<input type="text" id="subject" name="subject"/>
视频说明:<input type="text" id="content" name="content"/>
视频TAG(以逗号分割)<input type="text" id="tag" name="tags"/>
<input type="file" id="upfile" name="upfile"/>
<input type="submit" id="filesubmit" value="上传" onclick="startProgress(‘upid'); return true;"/>
<!?注意:startProgress(‘upid')中的参数是你从php中分配的唯一上传参数?>
</form>
<!?以下为上传进度条?>
<div id="upstatus" style="width: 500px; height: 30px; border: 1px solid ##ffffde; color:#796140;">
</div
<div id="progressouter" style="width: 500px; height: 20px; border: 3px solid #de7e00; display:none;">
<div id="progressinner" style="position: relative; height: 20px; color:#796140; background-color: #f6d095; width: 0%; "></div>
</div>

最主要的就是那个APC_UPLOAD_PROGRESS的隐藏域,有了它脚本才能去访问目前上传文件的状态,另外加一个显示上传状态的div就好了。
下面是处理Ajax的脚本,用了Jquery框架,json传递消息。

function getProgress(upid){
var url = "<{$siteurl}>epadmin/upprocess";
$.getJSON(
url,
{ progress_key: upid },
function(json){
$("#progressinner").width(json.per+"%");
$("#upstatus").html(‘文件大小:'+json.total+‘KB'+‘ 已上传:'+json.current+‘KB');
if (json.per < 100){
setTimeout(function(){
getProgress(upid);
}, 10);
}else{
$("#upstatus").html("视频上传完成,正在处理数据,请稍后……");
}
}
)
}
function startProgress(upid){
$("#progressouter").css({ display:"block" });
setTimeout(function(){
getProgress(upid);
}, 100);
}

再下来就是读取上传状态的PHP代码了,至于上传文件的处理可以按照平常自己的来写。
//上传文件操作函数,可按照自己的需要编写

function upflvAction()
 {
 if($_SERVER['REQUEST_METHOD']==‘POST'){
 $subject = trim($this->f->filter($this->_request->getPost(‘subject')));
 $content = trim($this->f->filter($this->_request->getPost(‘content')));
 Zend_Loader::loadClass(‘Custom_FlvOp');
 $flv = new Custom_FlvOp;
 $flv->uploadFlv(‘upfile',$subject,$content);
 }
 }
 //这就是读取上传状态的函数了~~
 function upprocessAction()
 {
 if(isset($_GET['progress_key'])) {
 $status = apc_fetch(‘upload_'.$_GET['progress_key']);
 $json = array(
 ‘per'=>$status['current']/$status['total']*100,
 ‘total'=>round($status['total']/1024),
 ‘current'=>round($status['current']/1024),
 );
 require_once("Zend/Json.php");
 echo Zend_Json::encode($json);
 }
 }

好了,现在就可以将其部署自己的站点中了,自己看看效果是不是很酷?

PHP的APC模块实现上传进度条

以上就是PHP的APC模块制作上传进度条的关键点介绍,希望对大家的学习有所启发,对大家有所帮助。

PHP 相关文章推荐
PHP 截取字符串 分别适合GB2312和UTF8编码情况
Feb 12 PHP
整理的9个实用的PHP库简介和下载
Nov 09 PHP
php抓取页面的几种方法详解
Jun 17 PHP
php json与xml序列化/反序列化
Oct 28 PHP
PHP的变量类型和作用域详解
Mar 12 PHP
WordPress中重置文章循环的rewind_posts()函数讲解
Jan 11 PHP
PHP数组函数array_multisort()用法实例分析
Apr 02 PHP
php大小写转换函数(strtolower、strtoupper)用法介绍
Nov 17 PHP
PHP读取并输出XML文件数据的简单实现方法
Dec 22 PHP
PHP笛卡尔积实现算法示例
Jul 30 PHP
Laravel关系模型指定条件查询方法
Oct 10 PHP
PHP中国际化的字符串排序和比较对象详解
Aug 23 PHP
php+ajax制作无刷新留言板
Oct 27 #PHP
一个完整的php文件上传类实例讲解
Oct 27 #PHP
php邮件发送的两种方式
Apr 28 #PHP
php语言中使用json的技巧及json的实现代码详解
Oct 27 #PHP
php+ajax实现无刷新的新闻留言系统
Dec 21 #PHP
PHP测试成功的邮件发送案例
Oct 26 #PHP
php使用APC实现实时上传进度条功能
Oct 26 #PHP
You might like
JAVA/JSP学习系列之六
2006/10/09 PHP
php事务处理实例详解
2014/07/11 PHP
PHP 实现类似js中alert() 提示框
2015/03/18 PHP
Mootools 1.2教程 滑动效果(Slide)
2009/09/15 Javascript
Javascript学习笔记 delete运算符
2011/09/13 Javascript
原生javascript兼容性测试实例
2013/07/01 Javascript
Asp.Net alert弹出提示信息的几种方法总结
2014/01/29 Javascript
javascript中Date对象的getDay方法使用指南
2014/12/22 Javascript
纯javascript实现四方向文本无缝滚动效果
2015/06/16 Javascript
如何实现移动端浏览器不显示 pc 端的广告
2015/10/15 Javascript
TinyMCE汉化及本地上传图片功能实例详解
2016/05/31 Javascript
jquery点击切换背景色的简单实例
2016/08/25 Javascript
require、backbone等重构手机图片查看器
2016/11/17 Javascript
微信小程序 引用其他js文件实现代码
2017/02/22 Javascript
js+canvas实现动态吃豆人效果
2017/03/22 Javascript
怎样在vue项目下添加ESLint的方法
2019/05/16 Javascript
vue集成kindeditor富文本的实现示例代码
2019/06/07 Javascript
JavaScript学习教程之cookie与webstorage
2019/06/23 Javascript
Weex开发之地图篇的具体使用
2019/10/16 Javascript
微信jssdk踩坑之签名错误invalid signature
2020/05/19 Javascript
修改Vue打包后的默认文件名操作
2020/08/12 Javascript
详细介绍Python函数中的默认参数
2015/03/30 Python
python中sleep函数用法实例分析
2015/04/29 Python
利用python求解物理学中的双弹簧质能系统详解
2017/09/29 Python
Python使用Socket实现简单聊天程序
2020/02/28 Python
如何使用repr调试python程序
2020/02/28 Python
python元组拆包实现方法
2021/02/28 Python
html5 css3 动态气泡按钮实例演示
2012/12/02 HTML / CSS
override和overload的区别
2016/03/09 面试题
英文自荐信
2013/12/15 职场文书
教师一帮一活动总结
2014/07/08 职场文书
党员教师群众路线对照检查材料思想汇报
2014/09/29 职场文书
升学宴学生答谢词
2015/01/05 职场文书
学年个人总结范文
2015/03/05 职场文书
建立共青团委员会的请示
2019/04/02 职场文书
Python中OpenCV实现查找轮廓的实例
2021/06/08 Python