欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【学习动态网页技术PHP:GD库安装问题详解】,下面是详细的分享!
学习动态网页技术PHP:GD库安装问题详解
使php支持 gif , jpeg , ttf ,wbmp
为了安装方便,我自己写了一分GD安装的过程,现在发表出来.希望朋友们多提意见,谢谢! 原来GD不支持WBMP,现在扩充GD支持WBMP.
问题:
安装RedHat 7.2 后,进行PHP编程,发现只能处理GIF图像,不能处理JPEG图像。
后来知道PHP处理图像,使用了GD库,而GD库开始时是支持GIF的,但由于GIF使用了有版权争议的LZW算法,会引起法律问题,于是从GD-1.6开始,GD库不再支持GIF,改为支持更好的,无版权争议的PNG。而我现在希望同时支持GIF,PNG和JPEG。由底向上的顺序介绍,即Jpeg->ttf->zlib->png->GD->PHP->Apache。
1.Jpeg6b的安装和配置
Jpeg的主要文件有jpeglib.h, libjpeg.a, libjpeg.so等。首先检查系统中安装了没有,到/usr/include目录下看有无jpeglib.h,到/usr/lib目录下看有无libjpeg.a和libjpeg.so。我的系统中没有,因而要安装。
取得的文件为jpegsrc.v6b.tar.gz,放于/usr/src目录下。
进入/usr/src目录中,开始安装过程。进入/usr/src:
cd /usr/src
解开压缩文件:
tar xzvf jpegsrc.v6b.tar.gz
命令完成后多了一个子目录jpeg-6b,Jpeg的源码文件就在其中。进入该子目录:
cd jpeg-6b
该目录中的install.doc文件详细介绍了如何安装Jpeg,照章行事即可。配置生成Makefile文件:
./configure
命令完成后该目录下多了个Makefile文件。Makefile文件是许多软件编译、安装的配置和过程控制文件,十分重要,应该学会看懂它的内容。开始编译:
make
命令完成后该目录下多了许多文件,其中重要的是libjpeg.a和libjpeg.so。安装:
make install
命令完成后,jpeglib.h被拷到/usr/include目录下,libjpeg.a和libjpeg.so被拷到/usr/local/lib目录下
2. ttf 的安装和配置
freetype-1.3.1.tar.gz
tar -xzvf freetype-1.3.1.tar.gz
./configure
命令完成后该目录下多了个Makefile文件。Makefile文件是许多软件编译、安装的配置和过程控制文件,十分重要,应该学会看懂它的内容。开始编译:
make
make install
编译gd 的时候有error don't found the freetype.h 所以
cp /usr/local/include/freetype/* /usr/local/include/3, zlib 安装:
Becaust the note, you must install the zlib first!
Before installing libpng, you must first install zlib. zlib
can usually be found wherever you got libpng. zlib can be
placed in another directory, at the same level as libpng.
Note that your system might already have a preinstalled
zlib, but you will still need to have access to the
zlib.h and zconf.h include files that correspond to the
version of zlib that's installed.
http://www.gzip.org/zlib/
ftp://ftp.uu.net/graphics/png/src/zlib-1.1.3.tar.gz
./configure
make
make install
4. libpng 安装:
Read INSTALL
http://www.libpng.org/pub/png/
libpng-1.2.0.tar.gz
UNIX example: cp scripts/makefile.std makefile
make
make install
5.GD-1.8.3的安装和配置
GD的主要文件有gd.h, libgd.a等。
取得的文件为gd-1.8.3.tar.gz,放于/usr/src目录下。已知道该版本的GD不支持GIF,但想来象我一样希望GD同时支持GIF和JPEG的人不少,于是有人做了个补丁,把对GIF的支持加回去了。看起来这是个英国人吧, 他的Email地址为adam@elysium.ltd.uk。获取补丁源码的地址为:http://www.webofsin.com/gd-1.8.3-gif.patch 取得的文件为gd-1.8.3-gif.patch,放于/usr/src目录下。进入/usr/src:
cd /usr/src
解开压缩文件:
tar xzvf gd-1.8.3.tar.gz
命令完成后多了一个子目录gd-1.8.3,GD的源码文件就在其中。给源码打补丁:
patch -p0
命令完成后gd-1.8.3子目录下多了个gd_gif.c文件,而文件gd.h和Makefile也被作了相应修改。进入该子目录:
cd gd-1.8.3
缺省情况下,GD库编译时并不加入JPEG支持,得修改Makefile文件。修改Makefile文件,使得:
CFLAGS=-O -DHAVE_XPM -DHAVE_JPEG -DHAVE_LIBTTF
LIBS=-lm -lgd -lpng -lz -ljpeg -lttf -lXpm -lX11
此后,编译并安装:
make
make install
命令完成后,gd.h被拷到/usr/local/include目录下,libgd.a被拷到/usr/local/lib目录下。
php apache 以SO方式安装:
6、 php-4.0.6的安装和配置
PHP的主要文件有libphp4.a, libphp4.so等。
取得的文件为php-4.0.6.tar.gz,放于/usr/src目录下。
进入/usr/src目录并解压文件:
cd /usr/src
tar xzvf php-4.0.6.tar.gz
命令完成后多了一个子目录php-4.0.6,PHP的源码文件就在其中。进入该子目录:
cd php-4.0.6
php
./configure
--with-apache=/usr/local/apache_1.3.26
--enable-track-vars
--enable-debug
--enable-url-includes
--enable-sockets
--with-gd=/usr/local
--enable-gd-native-ttf
--with-ttf=/usr/local
--with-jpeg-dir=/usr/local
--with-zlib-dir=/usr/local
--with-png-dir=/usr/local
编译并安装:
make
make install
命令完成后,libphp4.so被拷到/usr/lib/apache目录下。
7、apache_1.3.12的安装和配置
./configure
--prefix=/usr/local/apache
--activate-module=src/modules/php4/libphp4.a
--enable-module=so
--enable-module=negotiation
--enable-module=status
--enable-module=include
--enable-module=autoindex
--enable-module=cgi
--enable-module=asis
--enable-module=imap
--enable-module=actions
--enable-module=userdir
--enable-module=alias
--enable-module=setenvif
make
make install
以上所分享的是关于学习动态网页技术PHP:GD库安装问题详解,下面是编辑为你推荐的有价值的用户互动:
相关问题:小弟想学习下PHP开发动态网页,但什么都不会,我该...
答:现在我们有了强大的搜搜,百度,还要必要问到哪去学吗? 1)先看些基础 2)多看些例子程序 3)加一些群,加一些同样的好友。 4)坚持每天都学一点,然后记录下来 我不是在做广告。因为我们PHP群经常200人满线。你可以查找 群。晕了我说的是QQ群... >>详细
相关问题:我想自学jsp,或者asp,php,想学习一门动态网页的...
答:其实主要思路是这样的:php和jsp属于不同的编程语言,给你分别介绍下吧。 php主要是配置环境和架设网站,先安装个wamp或者是easyphp,目前比较流行的是easyphp,只下载它一个,就不需要配置复杂的环境了。然后就是下载个php的产品安装,比如你可... >>详细
相关问题:我想学习自己可以做出网页,动态网页中需要做HTML ...
答:当然需要了,PHP最终生成的就是HTML,CSS是HTML的样式,而JS是前端脚本,是在客户端运行的 例如: .class1{color:#FF0000} >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
