PHP中封装上传文件函数

<?php

/*
*文件上传
*
*
*/

//var_dump($_FILES);
/* 多文件上传处理
$data = $_FILES[‘icon‘];

$name = $data[‘name‘];

if (is_array($name)) {
	for ($i=0; $i<count($name); $i++) {
		echo $data[‘tmp_name‘][$i].‘<br />‘;
	}
} else {
	echo ‘单个文件上传‘;
}
*/

$mimes = [‘image/jpeg‘,‘image/png‘,‘image/gif‘];
$suffixs = [‘jpg‘,‘jpeg‘,‘pjpeg‘,‘png‘,‘gif‘];

//var_dump(upload(‘icon‘,$mimes,$suffixs,‘upload‘,true));

function upload($key,$mimes,$suffixs,$path=null,$rand_name=false)
{
	$data = $_FILES[$key];
	if ($error = $data[‘error‘]) {
		switch ($error) {
			case UPLOAD_ERR_INI_SIZE:
				$msg = ‘超过了upload_max_filesize的值‘;
				break;
			case UPLOAD_ERR_FORM_SIZE:
				$msg = ‘超过了表单中MAX_FILE_SIZE的值‘;
				break;
			case UPLOAD_ERR_PARTIAL:
				$msg = ‘部分文件上传‘;
				break;
			case UPLOAD_ERR_NO_FILE:
				$msg = ‘没有文件上传‘;
				break;
			case UPLOAD_ERR_NO_TMP_DIR:
				$msg = ‘没有找到临时目录‘;
				break;
			case UPLOAD_ERR_CANT_WRITE:
				$msg = ‘文件写入失败‘;
				break;
		}
		return [‘error‘=>$error,‘msg‘=>$msg];
	} else if ($data[‘size‘] > pow(1024,2)*2) {
		$msg = ‘文件超过自定义的大小2M‘;
		return [‘error‘=>0,‘msg‘=>$msg];
	}

	if (!in_array($data[‘type‘],$mimes)) {
		$msg = ‘不支持的MIME‘;
		return [‘error‘=>0,‘msg‘=>$msg];
	}

	$suffix = pathinfo($data[‘name‘])[‘extension‘];
	if (!in_array($suffix, $suffixs)) {
		$msg = ‘不支持的后缀名‘;
		return [‘error‘=>0,‘msg‘=>$msg];
	}

	if (!is_uploaded_file($data[‘tmp_name‘])) {
		$msg = ‘不是上传文件‘;
		return [‘error‘=>0,‘msg‘=>$msg];
	}
	if ($path) {
		$path = rtrim($path,‘/\\‘) . ‘/‘;
	} else {
		$path = ‘./‘;
	}
	$path .= date(‘Y/m/d‘) . ‘/‘;
	if (!file_exists($path)) {
		mkdir($path, 0777, true);
	}
	if ($rand_name) {
		$name = uniqid(). ‘.‘ . $suffix;
	} else {
		$name = $data[‘name‘];
	}
	$pathname = $path . $name;

	if (move_uploaded_file($data[‘tmp_name‘],$pathname)) {
		return [‘error‘=>200,‘msg‘=>$pathname];
	} else {
		$msg = ‘上传失败‘;
		return [‘error‘=>0,‘msg‘=>$msg];
	}
}
时间: 2024-11-03 16:13:23

PHP中封装上传文件函数的相关文章

MVC中如何上传文件

本文导读:在MVC中实现文件上传与传统的WebForm上传文件方法都差不多,在cshtml视图页面放一个file标签,然后在actionname方法中处理用户上传的文件.下面简单介绍MVC中上传文件的方法. 一.MVC中如何上传文件 1.在Web Forms中,当你把一个FileUpload控件拖到设计器中,你或许没有注意到在生成的HTML中会在form标签中加入一条额外属性 enctype="multipart/form-data". 而FileUpload控件本身会生成为<i

java开发中截取上传文件的文件名和后缀名

java开发中截取上传文件的文件名和后缀名 /** * Return the extension portion of the file's name . * * @see #getExtension */ public static String getExtension(File f) { return (f != null) ? getExtension(f.getName()) : ""; } public static String getExtension(String f

使用Ajax.BeginForm 中需要 上传文件 但 Request.files获取不到

使用Mvc里的插件jquery.unobtrusive-ajax.min.js 之前一直困在这里,一开始以为添加属性enctype="multipart/form-data"就可以 网上看到都是用另外一个插件jquery.form.js 于是,从某篇文章的附件中下载了jquery.form.js,弄了许久,还不行,顿时泪崩了, 最后在官网下载最新的jquery.form.js就解决了  ==|| 使用Ajax.BeginForm 中需要 上传文件 但 Request.files获取不到

asp.net中fileupload上传文件的方法

FileUpload 控件显示一个文本框控件和一个浏览按钮,使用户可以选择客户端上的文件并将它上载到 Web 服务器.用户通过在控件的文本框中输入本地计算机上文件的完整路径(例如,C:\MyFiles\test.txt)来指定要上载的文件.用户也可以通过单击“浏览”按钮,然后在“选择文件”对话框中定位文件来选择文件. 用户选择要上载的文件后,FileUpload 控件不会自动将该文件保存到服务器.您必须显式提供一个控件或机制,使用户能提交指定的文件.例如,可以提供一个按钮,用户单击它即可上载文件

上传文件函数的思路

<form action="" method="post" enctype="multipart/form-data"> 请选择要上传的文件:<input type="file" name="myFile" value="" /> <input type="submit" value="开始上传" /> <

SpringMvc (注解)中的上传文件

第一步:导入commons-fileupload-1.3.1.jar 和commons-io-2.2.jar 架包 第二步:在applicationContext.xml中 配置 <bean id=”multipartResolver” class=”org.springframework.web.multipart.commons.CommonsMultipartResolver”/> 第三步:在页面 <form>标签添加属性enctype=”multipart/form-dat

【springmvc】springmvc中如何上传文件

使用到的组件:可自行根据情况选择版本 <!--上传依赖包--> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.2</version> </dependency> <!--commons-upload依赖包begin-->

Android应用开发中webview上传文件的几种思路

1. 常规方法,重写WebChromeClient 的 openFileChooser 方法 private class MyWebChromeClient extends WebChromeClient { // For Android 3.0+ public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType) { if (mUploadMessage != null) return; mUploadMe

Juploader 1.0 谷歌(chrome)浏览器中成功上传文件后返回信息异常

在项目中使用了Juploader 1.0无刷新上传文件的js组件,在IE8以上没有问题,代码如下: function InitialUploadDirectly(OnUploadFunc, buttonID, allowedExts) { $.jUploader({ button: buttonID, // 这里设置按钮id eventType: 1, //触发类型 addeventbutton: buttonID, // 要绑定事件的元素的id filenamed: buttonID + 'd