导航:首页 > 编程语言 > php带进度条的上传

php带进度条的上传

发布时间:2024-08-23 16:22:34

1. php中上传文件的方法有多少种

一、传统的php写的上传类。
写一个php的上传类,这个方法用到的知识全部是php的,而且技术的难点也不多。
<form method="post" action="upload.php" enctype="multipart/form-data">
<table border=0 cellspacing=0 cellpadding=0 align=center width="100%">
<input type="hidden" name="MAX_FILE_SIZE" value="2000000">//隐藏域。这里name必须设置成MAX_FILE_SIZE,其值就是上传文件的最大长度,单位是B,这里我限制成2M
<input name="file" type="file" value="浏览" >
< input type="submit" value="上传" name="B1">
</table>
</form>

服务端利用php的$_FILES['file']['name']来获取文件后缀名,具体的代码自己查找资料看看,这里就不多说了。
总结;这个方法可以用来上传小于2M的文件或者是图片,基本的功能可以实现。
二、利用uploadify插件
这个是利用jQuery的上传插件,上传可以带进度条,容易配置。
总结:可以上传一些大文件,和图片,而且带进度条,可以多文件上传,在WEB中会经常用。
三、利用网络的webupload
WebUploader 是由 Bai FEX 团队开发的一款以 HTML5 为主,FLASH 为辅的现代文件上传组件。在现代的浏览器里面能充分发挥 HTML5 的优势,同时又不摒弃主流IE浏览器,沿用原来的 FLASH 运行时,兼容 IE6+,iOS 6+, Android 4+。采用大文件分片并发上传,极大的提高了文件上传效率。
四、swfupload的插件

这是一个jquery的上传插件,功能也非常强大,开发也比较容易,网上有很多的资料,可以自行查找。

2. PHP命令行下如何实现动态进度条

echo "Progress : "; // 5 characters of padding at the end
for ($i=0 ; $i<=100 ; $i++) {
echo "\033[5D"; // Move 5 characters backward
echo str_pad($i, 3, ' ', STR_PAD_LEFT) . " %"; // Output is always 5 characters
long
sleep(1); // wait for a while, so we see the animation
}
https://www.mmbyte.com/article/1791.html

3. PHP圆形进度条怎么做

一般实现下载进度条常用的两种解决方案是:一种是需要用socket保持与客户端通信,返回已下载的数据大小,然后可以JS+css显示下载速度,以及进度条之类;二种是php与flash交互,显示进度条。另外PHP5.4起 开始支持 进度条 Upload progress,你可以了解下!

4. PHP中使用Session配合Javascript实现文件上传进度条功能

Web应用中常需要提供文件上传的功能。典型的场景包括用户头像上传、相册图片上传等。当需要上传的文件比较大的时候,提供一个显示上传进度的进度条就很有必要了。
在PHP
5.4以前,实现这样的进度条并不容易,主要有三种方法:
1.使用Flash,
Java,
ActiveX
2.使用PHP的APC扩展
3.使用HTML5的File
API
第一种方法依赖第三方的浏览器插件,通用性不足,且易带来安全隐患。不过由于Flash的使用比较广泛,因此还是有很多网站使用Flash作为解决方案。
第二种方法的不足在于,它需要安装PHP的APC扩展库,要求用户能够控制服务器端的配置。另外,如果安装APC仅仅是为了实现一个上传进度条,那么显然有点杀鸡用牛刀的意思。
第三种方法应该是最为理想的方法,不需要服务器端的支持,仅在浏览器端使用Javascript即可。但是由于HTML5标准尚未确立,各浏览器厂商的支持也不相同,所以暂时这种方法还难以普及。
PHP
5.4中引入的基于session的上传进度监视功能(session.upload_progress),它提供了一个服务器端的上传进度监视解决方案。升级到PHP
5.4之后,可以不必安装APC扩展,仅使用原生PHP和前端的Javascript即可实现上传进度条。
下面我们就详细介绍一下
PHP
5.4
的这个
session.upload_progress
新特性。
原理介绍
当浏览器向服务器端上传一个文件时,PHP将会把此次文件上传的详细信息(如上传时间、上传进度等)存储在session当中。然后,随着上传的进行,周期性的更新session中的信息。这样,浏览器端就可以使用Ajax周期性的请求一个服务器端脚本,由该脚本返回session中的进度信息;浏览器端的Javascript即可根据这些信息显示/更新进度条了。
那么,文件上传信息具体是如何存储的?我们要如何访问它呢?下面我们来详细说明。
PHP
5.4
中引入了一些配置项(在php.ini中进行设置)
复制代码
代码如下:
session.upload_progress.enabled
=
"1"
session.upload_progress.cleanup
=
"1"
session.upload_progress.prefix
=
"upload_progress_"
session.upload_progress.name
=
"PHP_SESSION_UPLOAD_PROGRESS"
session.upload_progress.freq
=
"1%"
session.upload_progress.min_freq
=
"1"
其中enabled控制upload_progress功能的开启与否,默认开启;cleanup
则设置当文件上传的请求提交完成后,是否清除session的相关信息,默认开启。
prefix

name
两项用来设置进度信息在session中存储的变量名/键名。关于这两项的详细使用见下文。
freq

min_freq
两项用来设置服务器端对进度信息的更新频率。合理的设置这两项可以减轻服务器的负担。
在上传文件的表单中,需要为该次上传设置一个标识符,并在接下来的过程中使用该标识符来引用进度信息。具体的,在上传表单中需要有一个隐藏的input,它的name属性为php.ini中
session.upload_progress.name
的值;它的值为一个由你自己定义的标识符。如下:
复制代码
代码如下:
<input
type="hidden"

name="<?php
echo
ini_get('session.upload_progress.name');
?>"

value="test"
/>
接到文件上传的表单后,PHP会在$_SESSION变量中新建键,键名是一个将session.upload_progress.prefix的值与上面你自定义的标识符连接后得到的字符串,可以这样得到:
复制代码
代码如下:
$name
=
ini_get('session.upload_progress.name');
$key
=
ini_get('session.upload_progress.prefix')
.
$_POST[$name];
$_SESSION[$key];
//
这里就是此次文件上传的进度信息了

5. php中怎么实现读取数据进度条功能

<?php//防止执行超时set_time_limit(0);//清空并关闭输出缓存ob_end_clean();//需要循环的数据for($i = 0; $i < 188; $i++){ $users[] = 'Tom_' . $i;}//计算数据的长度$total = count($users);//显示的进度条长度,单位 px$width = 500;//每条记录的操作所占的进度条单位长度$pix = $width / $total;//默认开始的进度条百分比$progress = 0;?><html><head><title>动态显示服务器运行程序的进度条</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><style>body,div input { font-family: Tahoma; font-size: 9pt}</style><script language="JavaScript"> <!-- function updateProgress(sMsg, iWidth) { document.getElementById("status").innerHTML = sMsg; document.getElementById("progress").style.width = iWidth + "px"; document.getElementById("percent").innerHTML = parseInt(iWidth / <?php echo $width; ?> * 100) + "%"; } --> </script></head><body> <div style="margin:50px auto; padding: 8px; border: 1px solid gray; background: #EAEAEA; width: <?php echo $width+8; ?>px"> <div style="padding: 0; background-color: white; border: 1px solid navy; width: <?php echo $width; ?>px"> <div id="progress" style="padding: 0; background-color: #FFCC66; border: 0; width: 0px; text-align: center; height: 16px"></div> </div> <div id="status"></div> <div id="percent" style="position: relative; top: -30px; text-align: center; font-weight: bold; font-size: 8pt">0%</div> </div><?phpflush(); //将输出发送给客户端浏览器foreach($users as $user){ // 在此处使用空循环模拟较为耗时的操作,实际应用中需将其替换; // 如果你的操作不耗时,我想你就没必要使用这个脚本了 :) for($i = 0; $i < 1000000; $i++) { } ?><script language="JavaScript"> updateProgress("正在操作用户 <?php echo $user; ?> ....", <?php echo min($width, intval($progress)); ?>);</script><?php flush(); //将输出发送给客户端浏览器,使其可以立即执行服务器端输出的 JavaScript 程序。 $progress += $pix;} //end foreach?><script language="JavaScript"> //最后将进度条设置成最大值 $width,同时显示操作完成 updateProgress("操作完成!", <?php echo $width; ?>);</script><?phpflush();?></body></html

6. 大神,ThinkPHP 上传文件进度条怎么实现的

Web Uploader
这个插件是网络出的,有进度条,兼容ie7及以上。
原理就是ajax上传,会返回1-100的数值,根据这个值来操作进度条。如果还有不明白的话,你可以在后盾人看看视频找找答案,有空多看看时间长了,慢慢就明白了,希望能帮到你,给个采纳吧谢谢

阅读全文

与php带进度条的上传相关的资料

热点内容
cf游戏服务器IP地址 浏览:598
python地图上画三维柱状图 浏览:798
学大教育程序员 浏览:979
压缩机维修济南 浏览:739
算法21是什么 浏览:311
加密文件解密时非法的标志 浏览:358
哪些php网站有哪些东西 浏览:789
pdf文件转word文件怎么打开 浏览:808
权限的文件夹图标 浏览:827
智能加密门卡怎么弄在手机 浏览:501
程序员改需求 浏览:111
android环信图片 浏览:134
ees算法具有什么特点 浏览:768
安卓手机如何弄恋爱日记 浏览:624
android连接webservice 浏览:221
对于简单的加密和编码方法 浏览:334
XC8编译结果不同 浏览:217
气体隔膜压缩机 浏览:587
新的电脑文件夹打开为什么是空的 浏览:821
制冷压缩机寿命 浏览:734