服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|编程技术|正则表达式|C/C++|

服务器之家 - 编程语言 - PHP教程 - php使用APC实现实时上传进度条功能

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

2020-11-27 15:34PHP教程网 PHP教程

这篇文章主要介绍了php使用APC实现实时上传进度条功能,php本身不具备可以带有实时上传进度条功能,但是php提供了一个apc,它可以与php配置实现上传进度条,感兴趣的小伙伴们可以参考一下

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

代码如下 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?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
代码如下

?
1
2
3
4
5
6
7
8
<?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
代码如下 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<?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实现实时上传进度条功能的方法,希望对大家的学习有所帮助。

延伸 · 阅读

精彩推荐