-
用PHP和ImageMagick来处理图片文件的上传和缩放处理
php处理文件的上传是很简便的,但是假如要对上传的图片进行缩放处理的话,虽说能用GD来做,但是要进行比较繁琐的处理,ImageMagick是一个图像处理包,一般的Linux软件包中都会有的,它包含了许多处理图像的工具,它可以进行图像文件格式的转化还可以对图像进行各种处理,其中我们将用到它的图像缩放功能,这个通过它的软件包中的工具convert来实现,这样来调用 convert -geometry 宽x高 源文件 缩放后的文件
请在当前目录下建立一个images的目录,并且能让web执行用户可写,这个目录用来存放上载后的图片和缩放的图片.
下面是一个简单小例子,包括图片上传和处理,在RedHat6.0 php3.0.12下测试通过.
uploadform.html:文件上传表单:
- <HTML>
- <HEAD>
- <TITLE>选择文件</TITLE>
- </HEAD>
- <BODY ALIGN="CENTER">
- <FORM ENCTYPE="multipart/form-data" ACTION="upload.php3" METHOD=POST>
- 选择图片文件: <INPUT NAME="image" TYPE="file">
- <INPUT TYPE="submit" VALUE="Send File">
- </FORM>
- </BODY>
- </HTML>
upload.php:处理上传后的图片文件:
- <html>
- <head>
- <title>处理</title>
- </head>
- <body>
- <?php
- $flag = "true";
- if(isset($image) && $image &&
- ($image_type = "image/gif" || $image_type = "image/png" || $image_type = "image/pjpeg")){ //判定上载文件的格式等
- $dest_image = "./images/".$image_name;
- if(@copy($image,$dest_image)){ //拷贝上载文件到images目录下
- $small_image = "./images/small".$image_name;
- $exec_str = "/usr/bin/X11/convert -geometry 100x100 ".$dest_image." ".$small_image;
- @exec($exec_str); //进行图像的缩放
- }else
- $flag = "false";
- }else{
- $flag = "false";
- }
- if( $flag == "false"){
- echo "error<p>";
- echo "<a href="uploadform.html">重新上载</a>";
- }else{
- echo "<image src="$small_image">";
- echo "<image src="./images/$image_name">";
- }//开源代码phpfensi.com
- ?>
- </body>
- </html>
假如结合GetImageSize函数,我们还可以控制缩放的大小,结合数据库可以对图片文件进行索引或者存储等.
ImageMagick的功能是很强大的,不仅能对图片文件进行缩放,还有进行翻转、格式转化等等功能,读者可以自己参看ImageMagick的帮助文件.
原文链接:http://www.phpfensi.com/php/20140820/4513.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式