PHP:图片上传
文章来源:http://www.cnblogs.com/hello-tl/p/7593033.html
<?php
class TL_Update_File{
private $file = null;//接受图片名称
private $files = [];//图片属性
public $size = null;//上传文件大小限制
public $save_path = null;//保存路径
public $mime = null;//文件上传支持类型
private $error = null;//图片不符合要求者
//接受图片
function __construct($file=null){
$this->save_path = str_replace("\\","/",dirname(__FILE__))."/";
$this->file = $file;
if($file){
$this->files = $_FILES[$file];
}else{
$this->files = $_FILES;
}
}
//一系列属性向
private function attribute(){
if($this->file){
$this->empty_ture();
}else{
$this->empty_false();
}
if($this->size){
if($this->file){
$this->Size_ture();
}else{
$this->Size_false();
}
}
if($this->mime){
if($this->file){
$this->mime_ture();
}else{
$this->mime_false();
}
}
}
//判断图片是否为空
function empty_false(){
foreach ($this->files as $key => $value){
if($this->files[$key]['error']){
$this->error[$key] = $value;
$this->error[$key]['tl_error'] = "改图片为空";
unset($this->files[$key]);
}else{
$this->files[$key]['mime'] = substr($value['name'], strrpos($value['name'], ".")+1);
}
}
}
//判断图片是否为空
function empty_ture(){
if($this->files['error']) {
$this->error[$this->file] = $this->files;
$this->error[$this->file]['tl_error'] = "改图片为空";
$this->files=[];
}else{
$this->files['mime'] = substr($this->files['name'], strrpos($this->files['name'], ".") + 1);
}
}
//文件后缀名是否受限制
function mime_ture(){
if($this->files){
if(!in_array($this->files['mime'],$this->mime)){
$this->error[$this->file] = $this->files;
$this->error[$this->file]['tl_error'] = "不支持改后缀名";
$this->files=[];
}
}
}
//文件后缀名是否受限制
function mime_false(){
foreach ($this->files as $key => $value){
if(!in_array($this->files[$key]['mime'],$this->mime)){
$this->error[$key] = $value;
$this->error[$key]['tl_error'] = "不支持改后缀名";
unset($this->files[$key]);
}
}
}
//文件大小是否受限制
function Size_ture(){
if($this->files['size'] > $this->size){
$this->error[$this->file] = $this->files;
$this->error[$this->file] = $this->files;
$this->error[$this->file]['tl_error'] = "文件过大";
$this->files=[];
}
}
//文件大小是否受限制
function Size_false(){
foreach ($this->files as $key => $value){
if($this->files[$key]['size'] > $this->size){
$this->error[$key] = $value;
$this->error[$key]['tl_error'] = "文件过大";
unset($this->files[$key]);
}
}
}
//保存图片
function save_file(){
if($this->files){
$file_path_dir = date('Ym',time()) ."/";
$file_name = time() . rand(00000,99999) . "." . $this->files["mime"];
$this->is_dir_on_off($this->save_path . date('Ym',time()) ."/");
if($this->file){
$this->save_file_ture($file_path_dir,$file_name);
}else{
$this->save_file_false($file_path_dir,$file_name);
}
}
}
//保存图片
function save_file_ture($file_path_dir,$file_name){
move_uploaded_file($this->files["tmp_name"] , $this->save_path . $file_path_dir . $file_name);
}
//保存图片
function save_file_false($file_path_dir,$file_name){
foreach ($this->files as $key => $value){
move_uploaded_file($this->files[$key]["tmp_name"] , $this->save_path . $file_path_dir . $file_name);
}
}
//创建目录
function is_dir_on_off($file_path){
if(!is_dir($file_path)){
mkdir($file_path,0777);
}
}
//保存文件
function move(){
$this->attribute();
$this->save_file();
}
}
文章来源:http://www.cnblogs.com/hello-tl/p/7593033.html
PHP:图片上传的更多相关文章
- Asp.Net Mvc 使用WebUploader 多图片上传
来博客园有一个月了,哈哈.在这里学到了很多东西.今天也来试着分享一下学到的东西.希望能和大家做朋友共同进步. 最近由于项目需要上传多张图片,对于我这只菜鸟来说,以前上传图片都是直接拖得控件啊,而且还是 ...
- 06.LoT.UI 前后台通用框架分解系列之——浮夸的图片上传
LOT.UI分解系列汇总:http://www.cnblogs.com/dunitian/p/4822808.html#lotui LoT.UI开源地址如下:https://github.com/du ...
- JS图片上传预览插件制作(兼容到IE6)
其实,图片预览功能非常地常见.很意外,之前遇到上传图片的时候都不需要预览,也一直没有去实现过.现在手上的项目又需要有图片预览功能,所以就动手做了一个小插件.在此分享一下思路. 一.实现图片预览的一些方 ...
- HTML5笔记:跨域通讯、多线程、本地存储和多图片上传技术
最近做项目在前端我使用了很多新技术,这些技术有bootstrap.angularjs,不过最让我兴奋的还是使用了HTML5的技术,今天我想总结一些HTML5的技术,好记性不如烂笔头,写写文章可以很好的 ...
- 对百度的UEditor多图片上传的一些补充
我已经写了一篇文章关于百度的UEditor提取多图片上传模块.如果还没有看过,请点击以下链接查看 http://www.cnblogs.com/luke1006/p/3719029.html 出差了两 ...
- 使用localResizeIMG3+WebAPI实现手机端图片上传
前言 惯例~惯例~昨天发表的使用OWIN作为WebAPI的宿主..嗯..有很多人问..是不是缺少了什么 - - 好吧,如果你要把OWIN寄宿在其他的地方...代码如下: namespace Conso ...
- TinyMCE的使用(包括汉化及本地图片上传功能)
TinyMCE我就不多介绍了,这是下载地址:https://www.tinymce.com/download/ 下载下来是英文版,要汉化也很简单.首先去网上随便下载个汉化包,然后把汉化包解压后的lan ...
- 包含修改字体,图片上传等功能的文本输入框-Bootstrap
通过jQuery Bootstrap小插件,框任何一个div转换变成一个富文本编辑框,主要特色: 在Mac和window平台下自动针对常用操作绑定热键 可以拖拽插入图片,支持图片上传(也可以获取移动设 ...
- PHP多图片上传实例demo
upload.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...
- .NET MVC实现多图片上传并附带参数(ajaxfileupload)
做网站呢,都免不了要做图片上传. 还记得去年做微信的时候用WebAPI+ajaxfileupload.js做了一个能够附带参数上传的功能,博文地址:.NET WebAPI 实现图片上传(包括附带参数上 ...
随机推荐
- bzoj 3144 [Hnoi2013]切糕【最小割+dinic】
都说了是'切'糕所以是最小割咯 建图: 每个点向下一层连容量为这个点的val的边,S向第一层连容量为inf的边,最后一层向T连容量为自身val的边,即割断这条边相当于\( f(i,j) \)选择了当前 ...
- (图论)51NOD 1298 圆与三角形
给出圆的圆心和半径,以及三角形的三个顶点,问圆同三角形是否相交.相交输出"Yes",否则输出"No".(三角形的面积大于0). 输入 第1行:一个数T, ...
- Codeforces Round #479 (Div. 3)解题代码
A. Wrong Subtraction #include <bits/stdc++.h> using namespace std; int main() { int n,k; cin&g ...
- 题解报告:hdu 2069 Coin Change(暴力orDP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2069 Problem Description Suppose there are 5 types of ...
- 452 Minimum Number of Arrows to Burst Balloons 用最少数量的箭引爆气球
在二维空间中有许多球形的气球.对于每个气球,提供的输入是水平方向上,气球直径的开始和结束坐标.由于它是水平的,所以y坐标并不重要,因此只要知道开始和结束的x坐标就足够了.开始坐标总是小于结束坐标.平面 ...
- h5学习-canvas绘制矩形、圆形、文字、动画
绘制矩形<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...
- 配置Oracle网络服务
Oracle网络服务是什么呢? Oracle网络服务是客户端访问数据库服务器端才需要配置的,也就是说,你的Oracle数据库没有装在你自己的电脑上,你需要去访问别人电脑上的Oracle数据库,那么你就 ...
- composer Failed to decode zlib stream 无法解码zlib流
Win7 中安装 Composer (PHP) 国内有些网络不能访问美国的Composer官网,可访问 Composer 中文网 学习. 目标 可以在任何目录下的项目中执行 PHP composer. ...
- 一段js实现复制文本内容到剪切板
<script type="text/javascript"> function copyUrl2() { var Url2=document.getElementBy ...
- 微信小程序组件解读和分析:六、progress进度条
progress进度条组件说明: 进度条,就是表示事情当前完成到什么地步了,可以让用户视觉上感知事情的执行.progress进度条是微信小程序的组件,和HTML5的进度条progress类似. pro ...