PHP图像处理类库及演示分享
简单写了一个PHP的图像处理类库,虽然功能比较少,但是目前也没用到太高级的,以后用到了再填吧,或者哪位给点建议加上什么功能,或者有什么需求可以跟我说,我有时间加上,如果哪位对这个类库进行了扩展的话,还麻烦拿出来大家分享一下,代码现在是能用就行,考虑的东西不是很多,有什么更好的建议请告诉我,谢谢
Img.php
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 |
/** * Created by PhpStorm. * User: MCtion * Date: 2015/5/14 0014 * Time: 15:36 * 简单的图像类库,本类中所有相对路径均基于网站根目录,如需修改,则修改常量__WEBROOT__即可 * 功能:指定文字内容创建图片(不支持中文)、创建验证码图片、创建缩略图、其他功能待续 * 方法: * Style(array $Options) 设置图片样式,每次设定前将重置为默认样式 * Create_Img_Png() 创建PNG图像,相关属性由Style指定 * Create_Img_Jpeg() 创建JPEG图像,相关属性由Style指定 * Create_Verify() 创建验证码图像,相关属性由Style指定 * Get_Verify() 获得创建的验证码值,MD5加密 * Load_Img(string $FilePath) 加载图像,创建图像源,供其他方法调用源,FilePath为图像相对路径 * Create_Thumb(string $FileName,string $FilePath) 创建由Load_Img()加载的图像的缩略图,FileName为保存后的图像前缀,FilePath为保存图像的相对路径,不包含文件名(例:/Uploads/images/Thumb/) */
if(!defined("__WEBROOT__")) define("__WEBROOT__",$_SERVER['DOCUMENT_ROOT']);
class Img { protected $_Img; //图片源 protected $_FileImg; //加载的图片源 protected $_FileInfo; //加载的图片的信息数组 protected $_PicInfo; //加载的图片的宽高等信息数组 protected $_Rand = 'abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNOPQRSTUVWXYZ1234567890'; //随机因子 protected $_Code = ''; //验证码 public $Width = 300;//图片默认宽 public $Height = 80; //图片默认高 public $BackgroundColor = "000000"; public $Font = "/phps/Public/Font/ARIALNB.TTF"; //默认字体 public $FontSize = 16; //默认字体字号 public $FontColor = "ffffff"; //默认字体颜色 public $Content = "Test Word"; public $Align = "left"; public $Codes = 4; //验证码个数 public $Line = 6; //干扰线条的个数 public $LoadErr = ''; //错误信息
//public function __construct(){}
/** 设置图片属性 * @param array $Options 属性数组 * @return $this 返回对象 */ public function Style($Options){ $this -> _Re_Set(); foreach($Options as $K=>$V){ if(in_array($K,array('Width','Height','BackgroundColor','Font','FontSize','FontColor','Content','Align','Codes','Line','Snow'))){ if($K == "BackgroundColor" || $K == "FontColor"){ if(preg_match("#([a-zA-Z0-9]{6})#",$V)) $this -> $K = $V; }else{ $this -> $K = $V; } } } return $this; }
/** * 重置属性,不提供外部访问 */ protected function _Re_Set(){ $this -> Width = 100; $this -> Height = 30; $this -> BackgroundColor = "000000"; $this -> Font = "/phps/Public/Font/ARIALNB.TTF"; $this -> FontSize = 16; $this -> FontColor = "ffffff"; $this -> Align = "left"; $this -> Codes =4; $this -> Line = 6; }
/** * 创建图像源、添加背景、创建图像 * @param bool $BGC 指定是否创建背景色及矩形块 */ protected function _Create_Img_GB($BGC = True){ $this -> _Img = imagecreatetruecolor($this -> Width,$this -> Height); //创建背景源 if($BGC){ preg_match("#([a-zA-Z0-9]{2})([a-zA-Z0-9]{2})([a-zA-Z0-9]{2})#",$this -> BackgroundColor,$ColorArr); //将颜色值分隔成三组16位进制数 $Color = imagecolorallocate($this -> _Img,hexdec($ColorArr[1]),hexdec($ColorArr[2]),hexdec($ColorArr[3])); //给Img图像源添加背景色 imagefilledrectangle($this -> _Img,0,$this -> Height,$this -> Width,0,$Color); //创建图像 } }
/** * 创建随机验证码 */ protected function _Create_Code(){ $Len = strlen($this -> _Rand) - 1; for($i = 0;$i Codes;$i++){ $this -> _Code .= $this -> _Rand[mt_rand(0,$Len)]; } }
/** * 向图像中写入字符串,暂不支持中文 */ protected function _Write_Text(){ $FontWidth = imagefontwidth($this -> FontSize); //获取字号的一个字符的宽度 preg_match_all('/(.)/us', $this -> Content, $TextArr); //将内容分隔成数组一遍统计个数 $FontHeight = imagefontheight($this -> FontSize); //获取字号的高度 $X = ceil(($this -> Width - ($FontWidth * count($TextArr[0]))) / 2); //设置X轴距左边距的距离 $Y = ceil(($this -> Height + $FontHeight) / 2); //设置Y轴距上边距的距离 preg_match("#([a-zA-Z0-9]{2})([a-zA-Z0-9]{2})([a-zA-Z0-9]{2})#",$this -> FontColor,$ColorArr); $Color = imagecolorallocate($this -> _Img,hexdec($ColorArr[1]),hexdec($ColorArr[2]),hexdec($ColorArr[3])); //设置文字颜色 imagettftext($this -> _Img,$this -> FontSize,0,$X,$Y,$Color,__WEBROOT__.$this -> Font,$this -> Content); //写入内容 }
/** * 向图像中写入验证码 */ protected function _Write_Code(){ $_X = $this -> Width / $this -> Codes; //设置宽高比 for($i = 0;$i Codes;$i++){ //循环Codes次,每次生成一位验证码值 $Color = imagecolorallocate($this -> _Img,mt_rand(0,156),mt_rand(0,156),mt_rand(0,156)); //随机生成验证码值的颜色 imagettftext($this -> _Img,$this -> FontSize,mt_rand(-30,30),$_X*$i+mt_rand(1,5),$this -> Height / 1.3,$Color,__WEBROOT__.$this -> Font,$this -> _Code[$i]); //生成一位验证码值 } }
/** * 向图像中写入干扰线条 */ protected function _Write_Line() { //生成干扰线条 for ($i=0;$i Line;$i++) { $Color = imagecolorallocate($this -> _Img,mt_rand(0,156),mt_rand(0,156),mt_rand(0,156)); imageline($this -> _Img,mt_rand(0,$this -> Width),mt_rand(0,$this -> Height),mt_rand(0,$this -> Width),mt_rand(0,$this -> Height),$Color); } }
/** * 设置图像类型为JPEG */ protected function _Img_Jpeg(){ header('Content-type:image/jpeg'); imagejpeg($this -> _Img); imagedestroy($this -> _Img); }
/** * 设置图像类型为PNG */ protected function _Img_Png(){ header('Content-type:image/png'); imagepng($this -> _Img); imagedestroy($this -> _Img); }
/** * 创建JPEG的字符串图像 */ public function Create_Img_Jpg(){ $this -> _Create_Img_GB(True); $this -> _Write_Text(); $this -> _Img_Jpeg(); }
/** * 创建PNG的字符串图像 */ public function Create_Img_Png(){ $this -> _Create_Img_GB(True); $this -> _Write_Text(); $this -> _Img_Png(); }
/** * 创建验证码的PNG图像 */ public function Create_Verify(){ $this -> BackgroundColor = ''; for($I = 0;$I $this -> BackgroundColor .= dechex(mt_rand(20,155)); } $this -> _Create_Img_GB(True); $this -> _Create_Code(); $this -> _Write_Line(); $this -> _Write_Code(); $this -> _Img_Png(); }
/** * 外部获取MD5加密后的验证码 * @return string */ public function Get_Verify(){ return md5($this -> _Code); }
/** * 加载一个图像文件,并获取图像相关信息 * @param string $FilePath 图像相对路径地址 * @return $this|bool 成功返回对象,否则返回FALSE */ public function Load_Img($FilePath){ $FilePath = __WEBROOT__.$FilePath; if(!is_file($FilePath)){ $this -> LoadErr = "路径错误,文件不存在"; Return False; } $this -> _PicInfo = getimagesize($FilePath); $this -> _FileInfo = pathinfo($FilePath); switch($this -> _PicInfo[2]){ case 1:$this ->_FileImg = imagecreatefromgif($FilePath);break; case 2:$this ->_FileImg = imagecreatefromjpeg($FilePath);break; case 3:$this ->_FileImg = imagecreatefrompng($FilePath);break; default:$this -> LoadErr = "类型错误,不支持的图片类型";Return False; } Return True; }
/** * 创建缩略图 * @param string $FileName 保存的图片名称前缀 * @param string $FilePath 保存图片的相对路径 * @return mixed 返回生成的图片的信息数组 */ public function Create_Thumb($FileName,$FilePath){ $SavePath = __WEBROOT__.$FilePath; if(!file_exists($SavePath)){ mkdir($SavePath,0777,true); } $FileName = $FileName.date("YmdHis").rand(100,999).'.'.$this -> _FileInfo['extension']; $FilePath = $FilePath.$FileName; $SavePath = $SavePath.$FileName; $this -> _Create_Img_GB(False); imagecopyresampled($this -> _Img,$this -> _FileImg,0,0,0,0,$this -> Width,$this -> Height,$this -> _PicInfo[0],$this -> _PicInfo[1]); switch($this -> _PicInfo[2]){ case 1:imagegif($this -> _Img,$SavePath);break; case 2:imagejpeg($this -> _Img,$SavePath);break; case 3:imagepng($this -> _Img,$SavePath);break; } $FIleInfo['FileName'] = $FileName; $FIleInfo['FilePath'] = $FilePath; Return $FIleInfo; } } |
使用示例
?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
$Img = new Img();
$Options['Width'] = 300; $Options['Height'] = 100; $Options['Content'] = "Test Create Img"; $Options['FontColor'] = "FF0000"; $Options['BackgroundColor'] = "AAAAAA"; $Img -> Style($Options) -> Create_Img_Jpg();
if($Img -> Load_Img("/Public/images/ad1.png")){ $FileInfo = $Img -> Style(array('Width'=>30,'Height'=>30)) -> Create_Thumb("Thumb","/Uploads/images/"); var_dump($FileInfo); }else{ die("加载图像失败,".$Img -> LoadErr); } |
以上所述就是本文的全部内容了,希望大家能够喜欢。

要保护应用免受与会话相关的XSS攻击,需采取以下措施:1.设置HttpOnly和Secure标志保护会话cookie。2.对所有用户输入进行输出编码。3.实施内容安全策略(CSP)限制脚本来源。通过这些策略,可以有效防护会话相关的XSS攻击,确保用户数据安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显着提升应用在高并发环境下的效率。

thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceIsiseededeedeedeedeedeedeedto to to avoidperformance andununununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函数配置会话名称。具体步骤如下:1.使用session_name()函数设置会话名称,例如session_name("my_session")。2.在设置会话名称后,调用session_start()启动会话。配置会话名称可以避免多应用间的会话数据冲突,并增强安全性,但需注意会话名称的唯一性、安全性、长度和设置时机。

会话ID应在登录时、敏感操作前和每30分钟定期重新生成。1.登录时重新生成会话ID可防会话固定攻击。2.敏感操作前重新生成提高安全性。3.定期重新生成降低长期利用风险,但需权衡用户体验。

在PHP中设置会话cookie参数可以通过session_set_cookie_params()函数实现。1)使用该函数设置参数,如过期时间、路径、域名、安全标志等;2)调用session_start()使参数生效;3)根据需求动态调整参数,如用户登录状态;4)注意设置secure和httponly标志以提升安全性。

在PHP中使用会话的主要目的是维护用户在不同页面之间的状态。1)会话通过session_start()函数启动,创建唯一会话ID并存储在用户cookie中。2)会话数据保存在服务器上,允许在不同请求间传递数据,如登录状态和购物车内容。

如何在子域名间共享会话?通过设置通用域名的会话cookie实现。1.在服务器端设置会话cookie的域为.example.com。2.选择合适的会话存储方式,如内存、数据库或分布式缓存。3.通过cookie传递会话ID,服务器根据ID检索和更新会话数据。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!