今天研究了一下PHP的FILES函数,使用PHP实现本地图片的上传,验证文件是否为图片,并将图片保存在指定目录下,实现游览图片的功能,感觉还是很好玩的,一共有两个PHP页面,一个作为前台的上传和图片展示,另一个用来处理保存图片,代码里做了很详细的注释,并将FILES函数的语法,error报错类型写了出来,还有一些注意事项。
FILES函数
1、$_FILES[‘myFile'][‘name'] 客户端文件的原名称
2、$_FILES[‘myFile'][‘type'] 文件的 MIME类型,需要浏览器提供该信息的支持,例如”image/gif”
3、$_FILES[‘myFile'][‘size'] 已上传文件的大小,单位为字节
4、$_FILES[‘myFile'][‘tmp_name'] 文件被上传后在服务端储存的临时文件名,一般是系统默认,可以在php.ini的upload_tmp_dir指定
关于FILES中error报错类型及其注意:
过滤错误号
0: 没有错误发生,文件上传成功
1: 上传的文件超过了 php.ini 中 upload_max_filesize选项限制的值
2: 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值
3: 文件只有部分被上传
4: 没有文件被上传
5: 上传文件大小为0
注意:
1、文件被上传结束后,默认地被存储在了临时目录中,这时必须将它从临时目录中删除或移动到其它地方,如果没有,则会被删除。也就是不管是否上传成功,脚本执行完后临时目录里的文件肯定会被删除。所以在删除之前要用PHP的copy() 函数将它复制到其它位置,此时,才算完成了上传文件过程。
2、在 PHP 4.1.0 版本以前该数组的名称为$HTTP_POST_FILES,它并不像_FILES 一样是自动全局变量。PHP 3 不支持HTTP_POST_FILES数组。
3、用form上传文件时,一定要加上属性内容enctype=”multipart/form-data”,否则用$_FILES[filename]获取文件信息时会报异常。
以下是代码
index.php
<"Content-Type:text/html;charset=utf-8");
"center">
<h1>上传功能</h1>
<form action="index_ok.php" method="post" enctype="multipart/form-data">
上传图片:<input type="file" name="pic">
<input type="submit" name="sub" value="上传">
</form>
<table width="500">
<tr bgcolor="#cccccc">
<th>序号</th>
<th>图片</th>
<th>添加时间</th>
<th>操作</th>
</tr>
<"./uploads");
//2 遍历目录,输出里面的图片
$i=0;
while($f=readdir($dir)){
$i++;
//读取目录中的文件,模拟数据库操作
if($f!="." && $f!=".."){
$filename="./uploads/$f";
echo "<tr>";
echo "<td>{$i}</td>";
echo "<td><img src='./uploads/{$f}' width='80' height='60'></td>";
echo "<td>".date("Y-m-d",filectime($filename))."</td>";
echo "<td><a href='./uploads/{$f}'>查看</a></td>";
echo "</tr>";
}
}
//3 关闭目录
closedir($dir);
"#cccccc"><td colspan="4"> </td></tr>
</table>
</div>
upload.php
<"Content-Type:text/html;charset=utf-8");
if($_FILES['pic']['error']>0){
echo $_FILES['pic']['error'];
echo "上传文件错误!";
echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自动跳转回index文件
}else{
//开始获取上传文件的信息
$file=$_FILES['pic'];
//var_dump($file);打印文件里的全部信息
//name:上传文件名
//type:上传文件的类型
//tmp_name:上传成功后的临时文件
//size:上传文件的大小
//error:上传文件的错误信息
$uploaddir="./uploads/"; //选择要上传的文件存放目录
//$uploadfile=$uploaddir.basename($file['name']);//获得上传文件的名称
//解析文件的名字
$fileinfo=pathinfo($file['name']);
// echo $fileinfo['extension']; 获取文件的类型
do{
$newfile=date("YmdHis").rand(1000,9999).".".$fileinfo['extension'];//更改文件的名字,获取一个新的名字
}while(file_exists($uploaddir.$newfile));
//上传文件的类型限制
if (!(($file['type'] == "image/gif")||($file['type'] == "image/jpeg")||($file['type'] == "image/pjpeg"))){
die("文件类型错误!");
echo '<meta http-equiv="refresh" content="3;url=index.php">';
}
//上传文件的大小限制
if($file['size'] > 2*1024*1024){
die("上传文件超过2MB!");
echo '<meta http-equiv="refresh" content="3;url=index.php">';
}
//开始上传文件
if (is_uploaded_file($file['tmp_name'])) {
if (move_uploaded_file($file['tmp_name'], $uploaddir.$newfile)) {
echo "上传成功!";
echo '<meta http-equiv="refresh" content="3;url=index.php">';//自动跳转回index文件
} else {
echo "上传失败,请稍等!";
echo '<meta http-equiv="refresh" content="3;url=index.php">'; //自动跳转回index文件
}
}
}
?>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]