上传的主体页面

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
<title>Document</title>
</head>
<body>
<form action="doAction.php" method='post' enctype='multipart/form-data'>
请选择头像: <input type="file" name="myFile" id="" /><br/>
<input type="submit" value="上传" />
</form>
</body>
</html>
处理页面 doAction.php
<?php
header('content-type:text/html;charset=utf-8');
//1.接受数据
$fileInfo=$_FILES['myFile'];
$filename=$fileInfo['name'];
$type=$fileInfo['type'];
$tmp_name=$fileInfo['tmp_name'];
$size=$fileInfo['size'];
$error=$fileInfo['error']; //2.判断错误号 if($error>0){
//匹配错误信息
switch($error){
case 1:
$msg='超过了PHP配置文件中upload_max_filesize的值';
break;
case 2:
$msg='超过了MAX_FILE_SIZE选项的值';
break;
case 3:
$msg='文件部分被上传';
break;
case 4:
$msg='没有选择上传文件';
break;
case 6:
case 7:
case 8:
$msg='系统错误';
break;
}
exit($msg);
} //检测上传文件的大小
$maxSize=2097152;//2M 允许上传的最大大小
if($size>$maxSize){
exit('上传文件过大');
} //检测上传文件的类型
$ext=strtolower(pathinfo($filename,PATHINFO_EXTENSION));
$allowExt=array('jpeg','jpg','png','gif');//允许上传文件的扩展名
if(!in_array($ext,$allowExt)){
exit('非法文件类型');
}
//检测是否是真实图片
$flag=true;//默认检测是否是真实图片
if($flag){
if(!getimagesize($tmp_name)){
exit('文件不是真实图片');
}
}
//检测是否是通过HTTP POST方式上传上来的 if(!is_uploaded_file($tmp_name)){
exit('文件不是通过HTTP POST方式上传上来的');
} //开始移动文件
$uploadPath='uploads';
//检测目录是否存在,如果不存在则创建
if(!file_exists($uploadPath)){
//创建目录
mkdir($uploadPath,0777,true);
}
//防止文件重名,生成唯一的文件名
$uniName=md5(uniqid()).'.'.$ext;
$destination=$uploadPath.'/'.$uniName;
if(!@move_uploaded_file($tmp_name, $destination)){
exit('文件移动失败');
}
echo "文件{$filename}上传成功";

另一种写法

<?php
header('content-type:text/html;charset=utf-8');
//在服务器端做限制 $fileInfo=$_FILES['myFile'];
$filename=$fileInfo['name'];
$type=$fileInfo['type'];
$tmp_name=$fileInfo['tmp_name'];
$error=$fileInfo['error'];
$size=$fileInfo['size'];//上传文件的大小
$maxSize=2097152;//字节,允许上传文件的最大值
$allowExt=array('jpeg','jpg','png','gif');//允许上传文件的扩展名
$reUpload="<p><a href='upload.php'>重新上传</a></p>";
//2.判断错误号
if($error==UPLOAD_ERR_OK){
//3.检测上传文件的大小是否符合规范
if($size<=$maxSize){
//4.检测上传文件的扩展名在允许的范围内
//取出上传文件的扩展名
$arr=explode('.',$filename);
$ext=end($arr);
$ext=strtolower($ext);
//echo $ext;
if(in_array($ext,$allowExt)){
//echo '上传成功<br/>';
//5.检测文件是否是通过HTTP POST方式上传上来
//is_uploaded_file($tmp_name):检测服务器端的临时文件
//是否是通过HTTP POST方式上传上来的
if(is_uploaded_file($tmp_name)){
//6.移动文件
if(@move_uploaded_file($tmp_name, "../uploads/".$filename)){
echo '文件上传成功,信息如下:<hr/>';
echo '文件名:'.$filename,'<br/>';
echo '文件大小:'.$size,'<br/>';
echo '文件类型:'.$type,'<br/>';
}else{
die('文件移动失败'.$reUpload);
} }else{
die('文件不是通过HTTP POST方式上传上来的'.$reUpload);
} }else{
die('非法文件类型'.$reUpload);
} }else{
die('上传文件过大<br/>'.$reUpload);
}
}else{
//匹配错误信息
switch($error){
case 1:
$msg='超过了PHP配置文件upload_max_filesize选项的值';
break;
case 2:
$msg='超过了表单的MAX_FILE_SIZE选项的值';
break;
case 3:
$msg='文件部分被上传';
break;
case 4:
$msg='没有选择上传文件';
break;
case 6:
case 7:
case 8:
$msg='系统错误';
break;
}
die($msg); }

上传类

<?php
class Upload{
//把文件保存
function saveFile($toPath="./",$allowType=array('image/png','image/gif','image/jpeg','image/pjpeg'),$allowSize=2000000){
if(!empty($_FILES)){//有文件上传
$reArr=array();
foreach($_FILES['upload']['error'] as $k=>$v){
if($v===0){//文件上传没有出错
//获取类型进行判断
$type=$_FILES['upload']['type'][$k];
if(in_array($type,$allowType)){//类型是否合法
//判断size
$size=$_FILES['upload']['size'][$k];
if($size<=$allowSize){
//转移
$oldName=$_FILES['upload']['name'][$k];
$newName=$this->newName($oldName);
//保存
$re=move_uploaded_file($_FILES['upload']['tmp_name'][$k],$toPath."/".$newName);
if($re){
$reArr[$k]=$newName;
}else{
$reArr[$k]=false;
}
}else{
$reArr[$k]=false;
}
}else{
$reArr[$k]=false;
}
}else{
$reArr[$k]=false;
}
}
return $reArr;
}else{
return false;
}
}
//产生新名称
private function newName($oldName){//a.jpg
$name=md5(uniqid(microtime(),true));
$ext=pathinfo($oldName,PATHINFO_EXTENSION);
return $name.".".$ext;
}
}
 

php上传(二)的更多相关文章

  1. 文件上传二:FormData上传

    介绍三种上传方式: 文件上传一:伪刷新上传 文件上传二:FormData上传 文件上传三:base64编码上传 Flash的方式也玩过,现在不推荐用了. 真正的异步上传,FormData的更多操作,请 ...

  2. SpringBoot图片上传(二)

    需求简介:做新增的时候,需要上传图片.(⊙o⊙)…这需求描述也太简单了吧,限制文件大小60*60 512kb ,第一次做,记录一下嗷,废话就不啰嗦了 上代码 代码: //html代码<div c ...

  3. 使用ImageIO.write上传二维码文件时候,提示系统找不到指定路径

    报错如图所示: java.io.FileNotFoundException: E:\SF\.metadata\.plugins\org.eclipse.wst.server.core\tmp1\wtp ...

  4. ckeditor图片上传二三事

    最近实验室要用ckeditor,踩了几个小坑记录下. 1.出现iframe跨域问题 response.setHeader("X-Frame-Options", "SAME ...

  5. 实战maven私有仓库三部曲之二:上传到私有仓库

    在上一章<实战maven私有仓库三部曲之一:搭建和使用>我们搭建了maven私有仓库,并体验了私有仓库缓存jar包的能力,避免了局域网内开发人员去远程中央仓库下载的痛苦等待,本章我们再来体 ...

  6. Java实现上传下载

    一.上传 二.下载 import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.Fi ...

  7. JS实现多附件上传(asp.net)

    前几天,用户提出一个需求-多附件上传,另外,每个上传文件要加一个别名,本人创新少,从网上收集了资料,稍微改写,满足了 客户的需求.在应用到程序之前,先做了个小测试,测试通过,小高兴,就记录下了这个小测 ...

  8. Web---文件上传-用apache的工具处理、打散目录、简单文件上传进度

    我们需要先准备好2个apache的类: 上一个博客文章只讲了最简单的入门,现在来开始慢慢加深. 先过渡一下:只上传一个file项 index.jsp: <h2>用apache的工具处理文件 ...

  9. [原创] linux 下上传 datapoint数据到yeelink 【golang版本】同时上传2个数据点

    /* Create by sndnvaps<sndnvaps@gmail.com> * data: 2015-04-12* upload 2 datapoint to yeelink.ne ...

随机推荐

  1. React 使用antd 清空表单

    handleResetClick = e => { this.props.form.resetFields();};

  2. rabbitmq使用延迟时报异常

    声明交换机为延迟时报异常( unknown exchange type 'x-delayed-message')的解决方法 服务端需下载安装插件: 1.下载插件包 2.将下载后的插件包移至服务安装目录 ...

  3. HIVE常用函数(1)聚合函数和序列函数

    SUM--sum(汇总字段) over (partition by 分组字段 order by 排序字段) 如果不指定ROWS BETWEEN,默认为从起点到当前行;如果不指定ORDER BY,则将分 ...

  4. 深入理解Magento-第九章-修改、扩展、重写Magento代码

    (博主提示:本章应该不是原作者的第九章,仅作补充和参考) 作为一个开发者的你,肯定要修改Magento代码去适应你的业务需求,但是在很多时候我们不希望修改Magento的核心代码,这里有很多原因,例如 ...

  5. Vue学习笔记【15】——Vue实例的生命周期

    生命周期与生命周期钩子 什么是生命周期:从Vue实例创建.运行.到销毁期间,总是伴随着各种各样的事件,这些事件,统称为生命周期! 生命周期钩子:就是生命周期事件的别名而已: 生命周期钩子 = 生命周期 ...

  6. 每天一个Linux命令:mkdir(4)

    mkdir mkdir命令 用来创建指定的名称的目录,要求创建目录的用户在当前目录中具有写权限,并且指定的目录名不能是当前目录中已有的目录 格式 mkdir [选项] [目录..] 参数选项 参数 备 ...

  7. PHP FILTER_UNSAFE_RAW 过滤器

    定义和用法 FILTER_UNSAFE_RAW 过滤器不进行任何过滤,去除或编码特殊字符. 该过滤器删除那些对应用程序有潜在危害的数据.它用于去除标签以及删除或编码不需要的字符. 如果不规定标志,则该 ...

  8. (转)OpenFire源码学习之十七:HTTP Service插件

    转:http://blog.csdn.net/huwenfeng_2011/article/details/43457645 HTTP Service插件 这里的http接口插件是神马? Openfi ...

  9. 【mac】配置sublime开发C

    1.sublime text3,Tools/Build System/New Build system创建一个新配置文件. {"cmd": ["gcc", &q ...

  10. hive调用MapReduce之后遇到kill command之后卡住或者一直开在MapReduce之前

    https://blog.csdn.net/weixin_42158422/article/details/88876943