关于单文件上传函数封装

前端页面

<form action="doAction1.php" method="post" enctype="multipart/form-data">

文件上传<input type="type" name="myFile"></br>

<input type="submit" value="上传">

</form>

下面是upload.func.php封装单文件的函数

<?php

require_once "../lib/string.func.php";

其中string.func.php封装以下函数

function getUniName(){

return md5(uniqid(microtime(true),true);

}

function uploadFile($fileInfo,$allowext=array(‘jpg‘,‘png‘,‘gif‘,‘wmbp‘),$maxsize=512000,$imgFlag=true){

if($fileInfo[‘error‘]==UPLOAD_ERR_OK){

$ext=pathinfo($fileInfo[‘name‘],PATHINFO_EXTENSION);

$filename=getUniName().".".$ext;

$destination="uploads/".$filename;

if(is_uploaded_file($fileInfo[‘tmp_name‘]){

if(move_uploaded_file($fileInfo[‘tmp_name‘],$destination){

echo "<script>alert(‘文件移动成功‘)</script>";

}else

{

echo  "<script>alert(‘文件移动失败‘);</script>";

}

else{

echo "<script>alert(’文件不是通过HTTP POST方式上传文件的‘);</script>";

}

}

}else{

switch($fileInfo[‘error‘]){

case 1:

echo "文件超过 配置文件的大小";

break;

case 2:

echo 2:"文件超过了表单设置文件的最大的大小";

case 3:

echo "文件部分被上传";

break;

case 4:

echo "文件没有被上传";

break;

case 6:

echo "没有找到临时目录"

break;

case7:

echo  "文件不可写";

break;

case 8:

echo "由于php的扩展中断了文件的扩展"

break;

}

}

}

在doAction1.php页面

require_once "upload.func.php";

require_once "../lib/string.func.php";

$fileInfo=$_FILES[‘myFile‘];

$info=uploadFile($fileInfo);

recho $info;

实现文件的上传和确定文件类型。

时间: 2024-10-22 08:37:01

关于单文件上传函数封装的相关文章

优化后的单文件上传函数

$fileInfo = @$_FILES ['myFile'];//接收表单上传的文件 //5个参数中,第一个是必须,后面都有默认值 upload($fileInfo,"626800",false,"imgs",array("txt")); function upload($fileInfo,$maxSize=2097152,$flag=true,$path="upload",$allowedExt=array("j

PHP单文件上传原理及上传函数的封装

<?php //单文件上传函数的封装 //文件上传原理:将客户端的文件上传到服务器端,再将服务器端的临时文件移动到指定目录即可. //文件的方向:客户端-->服务器(临时文件)-->指定目录,当文件进入服务器时它就是临时文件了,这时操作中要用临时文件的名称tmp_name. //在客户端设置上传文件的限制(文件类型和大小)是不安全的,因为客户能通过源代码修改限制,所以在服务端这里设置限制. //设置编码为UTF-8,以避免中文乱码 header('Content-Type:text/ht

Struts2单文件上传原理及示例

一.文件上传的原理 表单元素的enctype属性指定的是表单数据的编码方式,该属性有3个值: 1.application/x-www-form-urlencoded:这是默认编码方式,它只处理表单域里的value属性值,采用这种编码方式的表单会将表单域的值处理成URL编码方式. 2.multipart/form-data:这种编码方式的表单会以二进制流的方式来处理表单数据,这种编码方式会把文件域指定文件的内容也封装到请求参数里. 3.text/plain:这种方式主要适用于直接通过表单发送邮件的

2014-07-23 利用ASP.NET自带控件实现单文件上传与下载

效果图 上传文件页面: 下载文件页面:  1.母版页site.Master <%@ Master Language="C#" AutoEventWireup="true" CodeBehind="Site.master.cs" Inherits="upAndDown.SiteMaster" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict/

SpringMVC实现单文件上传、多文件上传、文件列表显示、文件下载

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 本文详细讲解了SpringMVC实例单文件上传.多文件上传.文件列表显示.文件下载. 一.新建一个Web工程,导入相关的包 springmvc的包+commons-fileupload.jar+connom-io.jar+commons-logging,jar+jstl.jar+standard.jar 整个相关的包如下: 整个工程目录如下: 二.配置web.xml和SpringMVC文件

关于Struts2单文件上传

要实现Struts2框架的文件上传,需要用到2个jar包 commons-fileupload-1.2.2.jar commons-io-2.0.1.jar 由于文件解析Struts2内部已经帮我们做好了,大大降低了开发难度,我们只需要在Action里设置好对应的参数,目录进行使用即可. 来个小示例: upload.jsp 这个页面的表单有三点需要注意的: 1.表单必须使用post方式提交 2.表单编码类型 enctype="multipart/form-data"   3.<s

asp.net.mvc 的单文件上传和多文件上传的简单例子

首先打开vs2012,创建空的mvc4项目,名称为MVCStudy,选择基本模板 1)创建项目后,基本结构是这样的 2)建立对应的HomeController,视图index.fileupload.success.error页面 3)控制器源码 using System;using System.Collections.Generic;using System.IO;using System.Linq;using System.Web;using System.Web.Mvc;using Sys

springMVC之单文件上传

springmvc对form表单的支持已经很成熟,仅仅两步: 配置支持文件上传的bean:org.springframework.web.multipart.commons.CommonsMultipartResolver  同时设置文件编码.单次提交表单上传文件最大字节数.以及写文件时使用的缓冲区大小 开发处理:handler[org.hy.ssm.web.controller.FormController.uploadOne(MultipartFile)]  Java代码   /** * @

springMVC数据校验与单文件上传

spring表单标签:    <fr:from/> 渲染表单元素    <fr:input/>输入框组件    <fr:password/>密码框组件标签    <fr:hidden/>隐藏框组件标签0    <fr:textarea/>多行输入框组件标签    <fr:radiobutton/>单选框组件标签    <fr:checkbox/>复选框组件标签    <fr:select/>下拉列表组件标签