欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

php上传文件并显示上传进度的方法

程序员文章站 2022-10-05 16:36:32
本文实例讲述了php上传文件并显示上传进度的方法。分享给大家供大家参考。具体如下: 记得上传文件的时候要大点,不然还没看出来就上传完了,并且上传的文件不要太大,上g的就算...

本文实例讲述了php上传文件并显示上传进度的方法。分享给大家供大家参考。具体如下:

记得上传文件的时候要大点,不然还没看出来就上传完了,并且上传的文件不要太大,上g的就算了,2g的我试了,php受不了,我测试的是300多m的,记得要调整小php.ini参数啊 “选文件=》提交=》获取信息”要一气呵成哦^ ^

<?php
$prefix = ini_get('session.upload_progress.prefix');
$name  = ini_get('session.upload_progress.name');
$key  = $prefix . $name;
session_start();
if (isset($_post['get_info'])) {
  $logo = $prefix . $_post['logo'];
  exit(json_encode($_session[$logo]));
} elseif ($_post) {
  echo '<script>var finashed = true;</script>';
}
?>
<div id="show_info_div"></div>
<form action="index.php" method="post" enctype="multipart/form-data">
  <input type="hidden" name="<?php echo $name; ?>" value="test">
  <input type="file" name="file"><br>
  <input type="submit" value="提交">
  <input type="button" value="获取信息" onclick="getuploadinfo()">
</form>
<script src="jquery.js"></script>
<script>
var sto = null;
var progress = null;
function getuploadinfo()
{
  $.post("index.php", {"get_info": 1, "logo": "test"}, function(data)
  {
    data = eval("(" + data + ")");
    progress = parseint(parseint(data.bytes_processed) * 10000 / parseint(data.content_length)) / 100 + "%";
    document.getelementbyid("show_info_div").innerhtml = progress;
    sto = settimeout("getuploadinfo()", 1000);
  });
}
if (typeof(finashed) !== "undefined")
{
  document.getelementbyid("show_info_div").innerhtml = "100.00% (上传成功!)";
}
</script>

希望本文所述对大家的php程序设计有所帮助。