写的用于图片上传的公共方法
类调用方法:
$upload_name='pic';
$type = 'logo_val';
$file_name = 'logo_' . $user_id .create_strcode(5). '.jpg'; //保存文件名
$savepath = "/uploads/user_logo/"; //上传文件的存放路径
$img_width=$img_height='100';
$result=upload_images_core($_FILES,$upload_name,$file_name,$savepath,$img_width,$img_height);

/*
* 图片上传核心处理方法(按图片宽高缩放)
* @param $file_arr array 图片上传$_FILES获取的数组
* @param $upload_name 页面file控件name值
* @param $img_name 图片名称(含后缀)
* @param savepath 新图片保存目录
* @param maxwidth 新图片最大宽度
* @param maxwidth 新图片最大高度
* @author xufeng 837274769@qq.com
* */
function upload_images_core($file_arr,$upload_name,$file_name,$savepath,$maxwidth=100,$maxheight=100){
if(empty($file_arr) || empty($upload_name)){//当接收文件为空或控件名称为空时,直接返回错误
return array('state'=>RESULT_FAILURE,'msg'=>'不知名错误');
}else{
$file_arr=$file_arr[$upload_name];
}
$type = strtolower(substr($file_arr['name'],strrpos($file_arr['name'],'.')+1)); //得到文件类型,并且都转化成小写
$allow_type = array('jpg','jpeg','gif','png'); //允许上传的类型
$maxsize = 2048000; //最大限制 2M
$base_path = APPPATH . '../htdocs';
$img_path=$base_path.$savepath.$file_name;
//检测是否是正常HTTP POST上传的
if(!is_uploaded_file($file_arr['tmp_name'])){
return array('state'=>RESULT_FAILURE,'msg'=>'非法来源文件');
}
/** 检查目录是否可写 */
if (!@is_writable($base_path.$savepath)) {
return array('state'=>RESULT_FAILURE,'msg'=>'目录不可写');
}
/*检查文件是否超过限制*/
if ($maxsize!= 0) {
if ($file_arr['size'] > $maxsize) {
return array('state'=>RESULT_FAILURE,'msg'=>'文件太大');
}
}
if(!in_array($type, $allow_type)){
return array('state'=>RESULT_FAILURE,'msg'=>'不允许该格式文件');
}
if(move_uploaded_file($file_arr['tmp_name'],$img_path)){
switch($type){
case 'jpg': $im=imagecreatefromjpeg($img_path);
break;
case 'jpeg': $im=imagecreatefromjpeg($img_path);
break;
case 'gif': $im=imagecreatefromgif($img_path);
break;
case 'png': $im=imagecreatefrompng($img_path);
break;
default: return array('state'=>RESULT_FAILURE,'msg'=>'不允许该格式文件');
}
$pic_width = imagesx($im);
$pic_height = imagesy($im);
if(($maxwidth && $pic_width > $maxwidth) || ($maxheight && $pic_height > $maxheight))
{
if($maxwidth && $pic_width>$maxwidth) //原图宽度大于最大宽度
{
$widthratio = $maxwidth/$pic_width;
$resizewidth_tag = true;
} if($maxheight && $pic_height>$maxheight) //原图高度度大于最大高度
{
$heightratio = $maxheight/$pic_height;
$resizeheight_tag = true;
} if($resizewidth_tag && $resizeheight_tag) //如果新图片的宽度和高度都比原图小
{
if($widthratio<$heightratio) //那个比较小就说明它的长度要长,就取哪条,以长边为准缩放保证图片不被压缩
$ratio = $widthratio;
else
$ratio = $heightratio;
} if($resizewidth_tag && !$resizeheight_tag)
$ratio = $widthratio;
if($resizeheight_tag && !$resizewidth_tag)
$ratio = $heightratio; $newwidth = $pic_width * $ratio; //原图的宽度*要缩放的比例
$newheight = $pic_height * $ratio; //原图高度*要缩放的比例 if(function_exists("imagecopyresampled"))
{
$newim = imagecreatetruecolor($newwidth,$newheight); //生成一张要生成的黑色背景图 ,比例为计算出来的新图片比例
imagecopyresampled($newim,$im,0,0,0,0,$newwidth,$newheight,$pic_width,$pic_height); //复制按比例缩放的原图到 ,新的黑色背景中。
}
else
{
$newim = imagecreate($newwidth,$newheight);
imagecopyresized($newim,$im,0,0,0,0,$newwidth,$newheight,$pic_width,$pic_height);
}
@imagejpeg($newim,$img_path);
@imagedestroy($newim);
}
else
{
@imagejpeg($im,$img_path);
}
return array('state'=>RESULT_SUCCESS,'msg'=>$savepath.$file_name);
}else{
return array('state'=>RESULT_FAILURE,'msg'=>'不知名错误');
}
}

php 图片上传的公共方法(按图片宽高缩放或原图)的更多相关文章

  1. js判断图片上传时的文件大小,和宽高尺寸

    今天在做图片上传的小功能,使用了一个kissy上传组件.很好奇它是如何在图片上传前,检测到图片的大小和尺寸的?我们来写个小实例实现一下吧 如何读取图片的size 首先,原生input file控件有个 ...

  2. input type=file实现图片上传,预览以及图片删除

    背景 前两天在做一个PC网站的意见反馈,其中涉及到了图片上传功能,要求可以上传多张图片,并且支持图片上传预览及图片删除, 图片上传这一块以前没怎么搞过,而且一般也很少会碰到这样的需求,所以在做这个功能 ...

  3. 在ASP.NET MVC下实现单个图片上传, 客户端服务端双重限制图片大小和格式, 服务端裁剪图片

    在"MVC文件图片ajax上传轻量级解决方案,使用客户端JSAjaxFileUploader插件01-单文件上传"一文中,使用JSAjaxFileUploader这款插件实现了单文 ...

  4. jsp+springmvc实现文件上传、图片上传和及时预览图片

    1.多文件上传:http://blog.csdn.net/a1314517love/article/details/24183273 2.单文件上传的简单示例:http://blog.csdn.net ...

  5. php图片上传检测是否为真实图片格式

    PHP 图片上传,如果不做任何判断的话,随便一个文件如 rar,zip,php,java等文件改个文件名,改个后缀就能以图片形式上传的服务器,往往会造成极大的危害! 工具/原料   PHP apach ...

  6. thinkphp图片上传+validate表单验证+图片木马检测+缩略图生成

    目录 1.案例 1.1图片上传  1.2进行图片木马检测   1.3缩略图生成   1.4控制器中调用缩略图生成方法 1.案例 前言:在thinkphp框架的Thinkphp/Library/Thin ...

  7. 小程序实现图片上传,预览以及图片base64位处理

    最近一段时间在做小程序项目,第一期功也完工了.需要好好总结一下经验,把项目中遇到的问题好好总结一下,遇到的问题,踩过的坑.今天写一个小程序实现图片上传,预览,以及删除,图片base64位处理.下面就是 ...

  8. layui图片上传之后后台如何修改图片的后缀名以及返回数据给前台

    const pathLib = require('path');//引入node.js下的一个path模块的方法,主要处理文件的名字等工作,具体可看文档 const fs = require(''fs ...

  9. asp.net多图片上传同时保存对每张图片的描述

    前台aspx //图片预览和描述 function previewImage(file) { var div = document.getElementById('preview'); div.inn ...

随机推荐

  1. cell单选

    先上图给看看效果 cell单选逻辑就是取出上一个选中的cell 设置图片为默认图片 在取出点击的cell 设置图片为选中图片即可 废话不多说直接上代码 p.p1 { margin: 0.0px 0.0 ...

  2. SimpleXML操控XML

    复杂字符串如下: $_xml=<<<_xml <?xml version="1.0" encoding="utf-8"?> < ...

  3. Flashback Data Archive ( Oracle Total Recall ) introduced in 11g

    Flashback Data Archive feature is part of Oracle Total Recall technology. Flashback Data Archive fea ...

  4. 手机端页面rem自适应脚本

    什么是rem 参照 web app变革之rem 在我看来,rem就是1rem单位就等于html节点fontsize的像素值.所以改变html节点的fontsize是最为关键的一步.根据手机宽度改变相对 ...

  5. ubuntu14.04下配置Java环境以及安装最新版本的eclipse

    首先是配置JDK 步骤一:下载最新版本的JDK,链接:http://www.oracle.com/technetwork/java/javase/downloads/index.html 步骤二:首先 ...

  6. 开发日志_Jan.6.2017

    Github Jan.2 接到了汤松岩的GUI框架,开始复习和学习C++的使用方法(之前的开发经历主要使用的Java,对C++和QT环境都需要一个再了解). Jan.3 正式开始工作.开始在Ubunt ...

  7. html 超文本标记语言

    1.html超文本标记语言 2.在html中存在着大量的标签,我们用html中存在的标签将要显示在网页的内容包含起来. 3.css 控制网页显示内容的效果. 4.html+css 只能是静态网页. 5 ...

  8. Blend打不开wpf项目,提示无法识别的工具版本“12.0”

          讲项目文件用记事本打开然后修改为“14.0”即可        

  9. LeetCode 389. Find the Difference

    Given two strings s and t which consist of only lowercase letters. String t is generated by random s ...

  10. jQuery.lazyload

    Lazy Load延迟加载也有的称为惰性加载,是一个用 JavaScript 编写的 jQuery 插件. 它可以延迟加载长页面中的图片. 在浏览器可视区域外的图片不会被载入, 直到用户将页面滚动到它 ...