php使用APC实现实时上传进度条功能


Posted in PHP onOctober 26, 2015

php不具备实时上传进度条功能,如果想有这种功能我们一般会使用ajax来实现,但是php提供了一个apc,它就可以与php配置实现上传进度条功能。
主要针对的是window上的应用。
1.服务器要支持apc扩展,没有此扩展的话,下载一个扩展扩展要求php.5.2以上。
2.配置apc相关配置,重启apache
代码如下

extension=php_apc.dll  
apc.rfc1867 = on  
apc.max_file_size = 1000M  
upload_max_filesize = 1000M  
post_max_size = 1000M   
说明一下:至于参数要配多大,得看项目需要apc.max_file_size,  设置apc所支持上传文件的大小,要求apc.max_file_size<=upload_max_filesize  并且apc.max_file_size <=post_max_size.重新启动apache即可实现apc的支持.
3.在代码里面利用phpinfo();查看apc扩展安装了没有。
4.下面是实现代码:
getprogress.php
代码如下 

<?php 
session_start(); 
if(isset($_GET['progress_key'])) { 
 $status = apc_fetch('upload_'.$_GET['progress_key']); 
 echo ($status['current']/$status['total'])*100; 
} 
?> 
upload.php
PHP Code
<?php 
 $id = $_GET['id']; 
?> 
<form enctype="multipart/form-data" id="upload_form" action="target.php" method="POST"> 
<input type="hidden" name="APC_UPLOAD_PROGRESS" 
 id="progress_key" value="<?php echo $id?>"/> 
<input type="file" id="test_file" name="test_file"/><br/> 
<input onclick="window.parent.startProgress(); return true;" 
 type="submit" value="上传"/> 
</form>

target.php
代码如下

<?php 
set_time_limit(600); 
if($_SERVER['REQUEST_METHOD']=='POST') { 
 move_uploaded_file($_FILES["test_file"]["tmp_name"], 
 dirname($_SERVER['SCRIPT_FILENAME'])."/UploadTemp/" . $_FILES["test_file"]["name"]);//UploadTemp文件夹位于此脚本相同目录下 
 echo "<p>上传成功</p>"; 
} 
?>

index.php
代码如下 

<?php 
 $id = md5(uniqid(rand(), true)); 
?> 
<html> 
<head><title>上传进度</title></head> 
<body> 
<script src="js/jquery-1.4.4.min.js" language="javascript"></script> 
 
 
<script language="javascript"> 
var proNum=0; 
var loop=0; 
var progressResult; 
function sendURL() { 
  $.ajax({ 
   type : 'GET', 
   url : "getprogress.php?progress_key=<?php echo $id;?>", 
   async : true, 
   cache : false, 
   dataType : 'json', 
   data: "progress_key=<?php echo $id;?>", 
   success : function(e) { 
     progressResult = e; 
     proNum=parseInt(progressResult); 
     document.getElementById("progressinner").style.width = proNum+"%"; 
     document.getElementById("showNum").innerHTML = proNum+"%"; 
     if ( proNum < 100){ 
     setTimeout("getProgress()", 100); 
     } 
     
   } 
  }); 
 
} 
 
function getProgress(){ 
 loop++; 
 
 sendURL(); 
} 
var interval; 
function startProgress(){ 
 document.getElementById("progressouter").style.display="block"; 
 setTimeout("getProgress()", 100); 
} 
</script> 
<iframe id="theframe" name="theframe" 
 src="upload.php?id=<?php echo $id; ?>" 
 style="border: none; height: 100px; width: 400px;" > 
</iframe> 
<br/><br/> 
<div id="progressouter" style="width: 500px; height: 20px; border: 6px solid red; display:none;"> 
 <div id="progressinner" style="position: relative; height: 20px; background-color: purple; width: 0%; "></div> 
</div> 
<div id='showNum'></div><br> 
<div id='showNum2'></div> 
</body> 
</html>

以上就是跟大家分享的php使用APC实现实时上传进度条功能的方法,希望对大家的学习有所帮助。

PHP 相关文章推荐
PHP脚本数据库功能详解(上)
Oct 09 PHP
模仿OSO的论坛(五)
Oct 09 PHP
抓取YAHOO股票报价的类
May 15 PHP
简单的PHP多图上传小程序代码
Jul 17 PHP
php DOS攻击实现代码(附如何防范)
May 29 PHP
通过缓存数据库结果提高PHP性能的原理介绍
Sep 05 PHP
php启动时候提示PHP startup的解决方法
May 07 PHP
PHP获取php,mysql,apche的版本信息示例代码
Jan 16 PHP
php数组保存文本与文本反编成数组实例
Nov 13 PHP
PHP5.3以上版本安装ZendOptimizer扩展
Mar 27 PHP
php基于单例模式封装mysql类完整实例
Oct 18 PHP
php 删除一维数组中某一个值元素的操作方法
Feb 01 PHP
php需登录的文件上传管理系统
Mar 21 #PHP
PHP文件缓存类实现代码
Oct 26 #PHP
php多线程实现方法及用法实例详解
Oct 26 #PHP
浅析ThinkPHP缓存之快速缓存(F方法)和动态缓存(S方法)(日常整理)
Oct 26 #PHP
PHP和C#可共用的可逆加密算法详解
Oct 26 #PHP
日常整理PHP中简单的图形处理(经典)
Oct 26 #PHP
php 参数过滤、数据过滤详解
Oct 26 #PHP
You might like
php面向对象全攻略 (十六) 对象的串行化
2009/09/30 PHP
如何解决CI框架的Disallowed Key Characters错误提示
2013/07/05 PHP
php实现登陆模块功能示例
2016/10/20 PHP
php使用Jpgraph创建3D饼形图效果示例
2017/02/15 PHP
TP5框架页面跳转样式操作示例
2020/04/05 PHP
TP5框架实现上传多张图片的方法分析
2020/03/29 PHP
淘宝搜索框效果实现分析
2011/03/05 Javascript
js+xml生成级联下拉框代码
2012/07/24 Javascript
Jquery创建层显示标题和内容且随鼠标移动而移动
2014/01/26 Javascript
原生javascript实现图片按钮切换
2015/01/12 Javascript
Angular 中 select指令用法详解
2016/09/29 Javascript
javascript replace()第二个参数为函数时的参数用法
2016/12/26 Javascript
vue组件间通信子与父详解(二)
2017/11/07 Javascript
vue + element-ui实现简洁的导入导出功能
2017/12/22 Javascript
如何在基于vue-cli的项目自定义打包环境
2018/11/10 Javascript
vuex存值与取值的实例
2019/11/06 Javascript
vue设置全局访问接口API地址操作
2020/08/14 Javascript
ant design 日期格式化的实现
2020/10/27 Javascript
python 随机数生成的代码的详细分析
2011/05/15 Python
简单的连接MySQL与Python的Bottle框架的方法
2015/04/30 Python
Python利用IPython提高开发效率
2016/08/10 Python
python解析html提取数据,并生成word文档实例解析
2018/01/22 Python
Python实现的简单线性回归算法实例分析
2018/12/26 Python
python 删除系统中的文件(按时间,大小,扩展名)
2020/11/19 Python
10分钟理解CSS3 Grid布局
2018/12/20 HTML / CSS
美国在线乐器和设备商店:Musician’s Friend
2018/07/06 全球购物
写好求职信第一句话的技巧
2013/10/26 职场文书
上班早退检讨书
2014/01/09 职场文书
校园活动宣传方案
2014/03/28 职场文书
批评与自我批评总结
2014/10/17 职场文书
2015年妇委会工作总结
2015/05/22 职场文书
吧主申请感言怎么写
2015/08/03 职场文书
推广普通话主题班会
2015/08/17 职场文书
教你如何使用Python开发一个钉钉群应答机器人
2021/06/21 Python
python使用shell脚本创建kafka连接器
2022/04/29 Python
sql注入报错之注入原理实例解析
2022/06/10 MySQL