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中的字符串函数
Oct 09 PHP
图片存储与浏览一例(Linux+Apache+PHP+MySQL)
Oct 09 PHP
第十节--抽象方法和抽象类
Nov 16 PHP
PHP获取MSN好友列表类的实现代码
Jun 23 PHP
codeigniter教程之上传视频并使用ffmpeg转flv示例
Feb 13 PHP
浅谈Eclipse PDT调试PHP程序
Jun 09 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十二)
Jun 25 PHP
PHP批量查询WordPress留言者E-mail地址实现方法
Feb 15 PHP
php 防止表单重复提交两种实现方法
Nov 03 PHP
PHP使用Redis长连接的方法详解
Feb 12 PHP
php 提交表单 关闭layer弹窗iframe的实例讲解
Aug 20 PHP
phpinfo无法显示的原因及解决办法
Feb 15 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
php产生随机数的两种方法实例代码 输出随机IP
2011/04/08 PHP
PHP基于单例模式实现的数据库操作基类
2016/01/15 PHP
PHP数据库操作四:mongodb用法分析
2017/08/16 PHP
IE不出现Flash激活框的小发现的js实现方法
2007/09/07 Javascript
jQuery 选择器理解
2010/03/16 Javascript
jQuery的实现原理的模拟代码 -4 重要的扩展函数 extend
2010/08/03 Javascript
jQuery中parentsUntil()方法用法实例
2015/01/07 Javascript
JavaScript调用浏览器打印功能实例分析
2015/07/17 Javascript
angular ng-click防止重复提交实例
2017/06/16 Javascript
vuex学习之Actions的用法详解
2017/08/29 Javascript
vue iview组件表格 render函数的使用方法详解
2018/03/15 Javascript
Webpack4 使用Babel处理ES6语法的方法示例
2019/03/07 Javascript
说说如何利用 Node.js 代理解决跨域问题
2019/04/22 Javascript
TypeScript类型声明书写详解
2019/08/28 Javascript
javascript设计模式 ? 桥接模式原理与应用实例分析
2020/04/13 Javascript
react实现复选框全选和反选组件效果
2020/08/25 Javascript
用JavaScript实现贪吃蛇游戏
2020/10/23 Javascript
使用setup.py安装python包和卸载python包的方法
2013/11/27 Python
在Python中使用next()方法操作文件的教程
2015/05/24 Python
python脚本设置超时机制系统时间的方法
2016/02/21 Python
Python 自动刷博客浏览量实例代码
2017/06/14 Python
python实现二叉树的遍历
2017/12/11 Python
Python continue继续循环用法总结
2018/06/10 Python
Linux下Pycharm、Anaconda环境配置及使用踩坑
2018/12/19 Python
Python使用while循环花式打印乘法表
2019/01/28 Python
Python使用ctypes调用C/C++的方法
2019/01/29 Python
Python实现的登录验证系统完整案例【基于搭建的MVC框架】
2019/04/12 Python
Pandas实现DataFrame按行求百分数(比例数)
2019/12/27 Python
基于Tensorflow批量数据的输入实现方式
2020/02/05 Python
HTML5实现动画效果的方式汇总
2016/02/29 HTML / CSS
顶岗实习计划书
2014/01/10 职场文书
国际经济与贸易专业大学生职业规划书
2014/03/01 职场文书
素质教育标语
2014/06/27 职场文书
大学优秀学生主要事迹材料
2015/11/04 职场文书
python开发实时可视化仪表盘的示例
2021/05/07 Python
Win11远程连接不上怎么办?Win11远程桌面用不了的解决方法
2022/08/05 数码科技