100)PHP,文件上传总代码整理
首先是我的目录关系:
然后我的html表单代码:
<html>
<head>
<title>Form</title>
<meta
http-equiv="Content-Type" content="text/html;charset=UTF-8">
</head> <body>
<form action="BBB.php" method="post" name="form1" enctype="multipart/form-data" >
<table width="" border="" align="center" cellpadding="" cellspacing="">
<tr>
<td width="">
<div align="right">姓名:</div></td>
<td width="">
<label>
<input name="username" type="text" id="username">
</label>
</td> </tr>
<tr>
<td>
<div align
="right">职业:</div></td>
<td>
<label>
<input name
="job" type="text" id="job">
</label></td>
</tr>
<tr>
<td>
<label>
文件上传:<input type="file" name="picture">
</label>
</td>
</tr>
</table>
<p align="center">
<input type="submit" value="Submit">
</p>
</form>
</body>
</html>
然后是我的BBB.php代码
<?php
/**
* 上传函数
* @param $tmp_file $_FILES的五个信息,比如upload($_FILES('mingzi')
* $_FILES里面的名字是你的对应的html代码中的上传文件的那个name
* @return bool 失败返回false,成功就是true
*/
$tmp_file=$_FILES['picture'];
function upload($tmp_file){ /**
* 是否存在错误
*/ if($tmp_file['error']!=){
echo '文件上传错误';
return false;
}
/**
* 尺寸,
* 这个函数自己定的,但是应该是初始化设定的,就是这个值是变化的,不是一个固定的值。
*/ $max_size=*;//自己设定的最大尺寸
if($tmp_file['size']>$max_size){
echo "文件过大";
return false;
}
/**
* 验证后缀名,
* 用验证后缀和MIME方法
*/
//首先是验证后缀名
$tmp_file_zhui=strrchr($tmp_file['name'],'.') ;
//strrchr函数是来剪切字符串的最后出现.的包括这个.后面的全部截取
//后缀的映射数组,其实就是那个满足条件的后缀表(用关联数组表示)
$tmp_file_zhui_list=array(
'.png','.gif','.jpeg','.jpg'
);
if(!in_array($tmp_file_zhui,$tmp_file_zhui_list)){
echo "文件格式有问题";
return false;
}
//就是那个$_FILES['type']有一个格式,下面的是对应那个映射表
$tmp_file_zhui_MIMElist=array(
'.png'=>array('image/png','image/x-png'),
'.jpg'=>array('image/jpeg','image/x-pjpeg'),
'.jpeg'=>array('image/jpeg','image/pjpeg'),
'.gif'=>array('image/gif'),
);
$old_list=array();//下面直接用$old_list不行,我觉得这个就是声明,这是自己加的
//得出真正的映射表,因为在我的后缀映射表中,可能不是这四个,一旦发生改动,我的下面的映射关系,我还得自己改,所以,我就用一个foreach,上面有什么后缀,我的下面就给他对应上什么$_FILE['type']格式,然后得到我要的MIME映射表
foreach ($tmp_file_zhui_list as $value){
foreach($tmp_file_zhui_MIMElist[$value] as $key=>$item){
// var_dump($tmp_file_zhui_MIMElist[$value][$key]);
$new_MIME_list=array_merge($old_list,(array)$tmp_file_zhui_MIMElist[$value][$key]);
$old_list=$new_MIME_list;
} }
//去重
$new_MIME_list=array_unique($new_MIME_list); //然后用MIME验证
$phpfinfo=new finfo(FILEINFO_MIME_TYPE);
$f_type=$phpfinfo->file($tmp_file['tmp_name']);
echo $f_type;
if(!in_array($f_type,$new_MIME_list)){
echo "文件格式有误";
return false;
}
//后缀验证完成。
//建立一个文件夹,来存我的临时文件
if(!is_dir('./wangchao')){
mkdir('./wangchao');
} $sub_dir_name=date('Y--m-d-H');//截取年月日小时
//unipid是产生一个随机名字,可以试验一下 echo uniqid();
move_uploaded_file($tmp_file['tmp_name'],'./wangchao/'.uniqid('wang_'.$sub_dir_name.'_').$tmp_file_zhui);
return true;
}
upload($tmp_file);
100)PHP,文件上传总代码整理的更多相关文章
- WebLogic 任意文件上传远程代码执行_CVE-2018-2894漏洞复现
WebLogic 任意文件上传远程代码执行_CVE-2018-2894漏洞复现 一.漏洞描述 Weblogic管理端未授权的两个页面存在任意上传getshell漏洞,可直接获取权限.Oracle 7月 ...
- php课程---文件操作及文件上传的代码总结
php里面文件包含目录和文件两种 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...
- Rxjava+Retrofit2+Okhttp3多文件上传(服务器端代码+客户端代码)
所有代码亲测可用,如有问题,欢迎指正. 首先在ApiService接口文件中新建文件上传接口 public interface ApiService { static final String BAS ...
- js 实现 input type="file" 文件上传示例代码
在开发中,文件上传必不可少但是它长得又丑.浏览的字样不能换,一般会让其隐藏点其他的标签(图片等)来时实现选择文件上传功能 在开发中,文件上传必不可少,<input type="file ...
- selenium之 文件上传所有方法整理总结【转】
本文转自:https://blog.csdn.net/huilan_same/article/details/52439546 文件上传是所有UI自动化测试都要面对的一个头疼问题,今天博主在这里给大家 ...
- WebLogic 任意文件上传 远程代码执行漏洞 (CVE-2018-2894)------->>>任意文件上传检测POC
前言: Oracle官方发布了7月份的关键补丁更新CPU(Critical Patch Update),其中针对可造成远程代码执行的高危漏洞 CVE-2018-2894 进行修复: http://ww ...
- selenium之 文件上传所有方法整理总结
本文转载“灰蓝”的原创博客.http://blog.csdn.net/huilan_same/article/details/52439546 文件上传是所有UI自动化测试都要面对的一个头疼问题,今天 ...
- JSCH实现文件上传的代码实例
package com.vcredit.ddcash.monitor.sendmail; import java.io.File;import java.io.FileInputStream;impo ...
- php之文件上传类代码
/* 单个文件上传 功能 上传文件 配置允许的后缀 配置允许的大小 获取文件后缀 判断文件的后缀 报错 */ class UpTool{ protected $allowExt = 'jpg,jpeg ...
随机推荐
- 解决: java.io.IOException: 打开的文件过多 的问题
问题 前一阵子公司项目做了一次压力测试, 中间出现了一个问题: 在50多个并发的时候会出现 java.io.IOException: 打开的文件过多 这个异常. 但是在没有并发的时候是不会出现这个问题 ...
- centos 7 内存压测测试--memtester工具
1.下载memteste工具 官方:http://pyropus.ca/software/memtester/ wget http://pyropus.ca/software/memtester/ol ...
- hadoop cmd
一.hadoop文件操作 1.Ls hadoop fs -ls / 2.Put hadoop fs -put xx /path 3.Mkdir hadoop fs -mkdir 4.要从HDFS中删除 ...
- Java--二维码生成&图片和流转化
package test; import java.awt.image.BufferedImage; import java.io.ByteArrayInputStream; import java. ...
- h5-拖拽接口
1.原效果网页 拖拽后: 2.主要实现代码 <div class="div1" id="div1"> <!--在h5中,如果想拖拽元素,久必须 ...
- 刷题33. Search in Rotated Sorted Array
一.题目说明 这个题目是33. Search in Rotated Sorted Array,说的是在一个"扭转"的有序列表中,查找一个元素,时间复杂度O(logn). 二.我的解 ...
- 股票数据的原始数据形态&数据驱动来设计金融股票业务场景
1. 数据源 其实金融数据没大家想象的那麽复杂,只需要最原始状态的数据,保存到本地即可以. 那麽,怎样才是股票数据的原始状态呢.那就看看1920's年代的道氏理论,他是怎样计算道琼斯指数,那麽他采用的 ...
- 有几个水洼(DFS)
#include <iostream> #include<cstdio> using namespace std; #define maxn 105 char field[ma ...
- 关于redis的使用总结
简介 redis是一个开源的用c语言编写的数据库,但并不像常规的关系型数据库那样把数据存储在表中 , 而是像Java中的Map集合一样,存储的是一系列key=value键值对,redis属于NoSQL ...
- HttpClient apache上篇
1.什么是HttpClient Http 是Hyper-Text Transfer Protocol简写,迄今为止互联网应用最广泛的协议.网络服务.互联网应用.网络计算需求的增长,持续推动http协议 ...