php에는 실시간 업로드 진행률 표시줄 기능이 없습니다. 이 기능을 사용하려면 일반적으로 ajax를 사용하지만 php에서는 업로드 진행률 표시줄을 구현하기 위해 php로 구성할 수 있는 apc를 제공합니다. 기능.
주로 Windows의 응용 프로그램을 대상으로 합니다.
1. 서버는 apc 확장을 지원해야 합니다. 해당 확장이 없는 경우 확장을 다운로드하려면 php.5.2 이상이 필요합니다.
2. APC 관련 구성을 구성하고 Apache를 다시 시작합니다
코드는 다음과 같습니다
확장자=php_apc.dll
apc.rfc1867 = 켜짐
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.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>
위 내용은 APC를 사용하여 PHP에서 실시간 업로드 진행률 표시줄 기능을 구현하는 방법을 여러분과 공유하는 방법입니다. 모든 분들의 학습에 도움이 되기를 바랍니다.