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 02 PHP
PHP5中使用PDO连接数据库的方法
Aug 01 PHP
PHP学习笔记 (1) 环境配置与代码调试
Jun 19 PHP
PHP图片等比缩放类SimpleImage使用方法和使用实例分享
Apr 10 PHP
PHP中auto_prepend_file与auto_append_file用法实例分析
Sep 22 PHP
完美实现wordpress禁止文章修订和自动保存的方法
Nov 03 PHP
PHP中创建和验证哈希的简单方法实探
Jul 06 PHP
谈谈PHP中substr和substring的正确用法及相关参数的介绍
Dec 16 PHP
PHP递归遍历多维数组实现无限分类的方法
May 06 PHP
py文件转exe时包含paramiko模块出错解决方法
Aug 12 PHP
浅谈PHPANALYSIS提取关键字
Mar 08 PHP
基于php+MySql实现学生信息管理系统实例
Aug 04 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
第九节 绑定 [9]
2006/10/09 PHP
关于时间计算的结总
2006/12/06 PHP
yii2 RBAC使用DbManager实现后台权限判断的方法
2016/07/23 PHP
php将文件夹打包成zip文件的简单实现方法
2016/10/04 PHP
详解PHP安装mysql.so扩展的方法
2016/12/31 PHP
Javascript 代码也可以变得优美的实现方法
2009/06/22 Javascript
jQuery EasyUI 的EasyLoader功能介绍
2010/09/12 Javascript
基于Jquery的回车成tab焦点切换效果代码(Enter To Tab )
2010/11/14 Javascript
深入理解javascript学习笔记(一) 编写高质量代码
2012/08/09 Javascript
javascript中apply和call方法的作用及区别说明
2014/02/14 Javascript
使用jQuery获得内容以及内容的属性
2015/02/26 Javascript
jQuery简单实现中间浮窗效果
2016/09/04 Javascript
easyui简介_动力节点Java学院整理
2017/07/14 Javascript
JavaScript闭包的简单应用
2017/09/01 Javascript
vue element项目引入icon图标的方法
2018/06/06 Javascript
vue-image-crop基于Vue的移动端图片裁剪组件示例
2018/08/28 Javascript
mpvue将vue项目转换为小程序
2018/09/30 Javascript
Vue跨域请求问题解决方案过程解析
2020/08/07 Javascript
详解微信小程序动画Animation执行过程
2020/09/23 Javascript
Python实现字典依据value排序
2016/02/24 Python
python抓取京东小米8手机配置信息
2018/11/13 Python
解决Python中pandas读取*.csv文件出现编码问题
2019/07/12 Python
Tensorflow实现酸奶销量预测分析
2019/07/19 Python
python使用openCV遍历文件夹里所有视频文件并保存成图片
2020/01/14 Python
草莓网英国官网:Strawberrynet UK
2017/02/12 全球购物
应届大学毕业生找工作的求职信范文
2013/11/29 职场文书
新学期班主任寄语
2014/01/18 职场文书
《大作家的小老师》教学反思
2014/04/16 职场文书
五好关工委申报材料
2014/05/31 职场文书
责任书格式范文
2014/07/28 职场文书
计算机实训报告范文
2014/11/05 职场文书
个人工作表现自我评价
2015/03/06 职场文书
本科毕业论文致谢词
2015/05/14 职场文书
golang 实现两个结构体复制字段
2021/04/28 Golang
JavaScript实现简单图片切换
2021/04/29 Javascript
Sentry的安装、配置、使用教程(Sentry日志手机系统)
2022/07/23 Python