分类广告


推荐文章

  • 没有找到任何内容!
您当前的位置:中国站长下载网络编程PHP专区 → 文章内容

php3:跨平台的服务器端嵌入式脚本语言(11-14)

  • 作者:佚名    来源:不详    发布时间:2006-2-26 2:01:28
  • 字体大小:
标  题: php3:跨平台的服务器端嵌入式脚本语言(11) 

 

 

        PHP中有一组图像函数
,可以动态生成gif格式的图像数据流并输出到 

服务器
. 

        为了这组函数能够工作
,系统中必须有gd库的支持.如果是在Unix下, 

应该在编译PHP之前先取得gd的源码并编译之
,生成libgd.a和一些.h文件,分别 

拷到系统的库目录和头文件目录中
(例如/usr/lib和/usr/include);如果是在 

Windows
,PHP3.0的安装程序会安装一个gd.dll文件,程序中加一句'dl("gd. 

dll");'
即可使用图像函数. 

        主要的图像函数有
: 

       
(1)ImageCreate(宽度,高度) 

        返回一个图像描述符
. 

       
(2)ImageCreateFromGif(文件); 

        返回一个图像描述符
. 

       
(3)ImageColorAllocate(图像描述符,,绿,); 

        返回一个颜色描述符
.由于Gif图像只能有256色,必须先对它分配调色板, 

这个语句就是分配一个调色板项
. 

       
(4)ImageColorTransparent(图像描述符,颜色描述符); 

        指定某颜色为透明色
. 

       
(5)ImageArc(图像描述符,圆心横坐标,圆心纵坐标,椭圆宽,椭圆高,起始 

,终止角,颜色描述符); 

           ImageChar
(图像描述符,字体,x,y,字符,颜色描述符); 

           ImageCharUp
(图像描述符,字体,x,y,字符,颜色描述符); 

           ImageCopyResized
(目标图像描述符,源图像描述符,目标x,目标y,源x,源y, 

目标宽
,目标高,源宽,源高); 

           ImageDashedLine
(图像描述符,x1,y1,x2,y2,颜色描述符); 

           ImageFill
(图像描述符,起始点x,起始点y,颜色描述符); 

           ImageFilledPolygon
(图像描述符,各顶点数组,顶点数,颜色描述符); 

           ImageFilledRectangle
(图像描述符,x1,y1,x2,y2,颜色描述符); 

           ImageFillToBorder
(图像描述符,起始点x,起始点y,边界色,填充色); 

           ImageLine
(图像描述符,x1,y1,x2,y2,颜色描述符); 

           ImagePolygon
(图像描述符,各顶点数组,顶点数,颜色描述符); 

           ImageRectangle
(图像描述符,x1,y1,x2,y2,颜色描述符); 

           ImageSetPixel
(图像描述符,x,y,颜色描述符); 

           ImageString
(图像描述符,字体,x,y,字符,颜色描述符);  

           ImageStringUp
(图像描述符,字体,x,y,字符,颜色描述符);  

           

        这些都是画图函数
,需要略做解释的就是多边形的顶点数组内依次存放着 

第一点x
,第一点y,第二点x,第二点y,... 

       
(6)ImageLoadFont(文件); 

        文件应该是一个位图字体文件
,返回一个字体号.系统缺省带有1-5字体号, 

可以直接使用
. 

       
(7)ImageSX,ImageSY 

        分别得到一个图像的宽度和高度
,接收一个图像描述符参数. 

       
(8)ImageColorAt(图像描述符,x,y); 

           ImageColorClosest
(图像描述符,,绿,); 

           ImageColorExact
(图像描述符,,绿,); 

           ImageColorSet
(图像描述符,颜色描述符,,绿,); 

           ImageColorsForIndex
(图像描述符,颜色描述符); 

           ImageColorsTotal
(图像描述符); 

        前三个返回一个颜色描述符
.ImageColorExact如果找不到匹配则返回-1. 

        ImageColorsForIndex返回一个三项的数组
,元素分别是红,绿,蓝值. 

        ImageColorsTotal返回总颜色数
. 

       
(9)ImageFontHeight,ImageFontWidth 

        接收一个字体号作为参数
. 

       
(10)ImageGif(图像描述符,[文件]); 

        如无文件
,则将gif数据流送往浏览器.这时程序一开始应该有一句: 

                Header
("Content-type: image/gif")           

       
(11)ImageDestroy(图像描述符); 

 

        图像函数中有一个小Bug
(至少在PHP3.0RC和PHP3.0RC3 For Unix的源码中 

已经发现
,现在www.php.net上的下载文件应该已经更改),就是ImageSetPixel总是 

(y,y)处画点,不管x的值是什么,不过这个问题不是很大. 

         

 

 

标  题
: php3:跨平台的服务器端嵌入式脚本语言(12) 

 

 

        PHP的数据库功能应该说是它最有用的功能之一
.它的特点就是内置了对很多 

数据库的支持
,而不再需要重新扩充. 

        Perl和Tcl也都是常用的跨平台语言
,都有很强的字符能力,前者字符能力更 

强一些
,性能更高一些;而后者有GUI能力.它们都可以扩充以支持数据库,但这时如果 

仍旧希望应用程序有跨平台能力
,则需要在各种平台上各自扩充,比如在Unix平台上 

对Perl扩充DBI包
,Windows 95/NT下对Perl扩充Win32::ODBC包,有时候这是很麻烦 

.而PHP由于内置了数据库支持,就为编程人员省去了这些麻烦. 

        PHP3
.0支持以下数据库: 

        Adabas_D
,dBase,dbm,filePro,mSQL,MySQL,Sybase,Oracle,PostgreSQL,Solid 

        另外
,支持Windows下的ODBC接口. 

        文档中说如果需要使用Microsoft SQL Server
,可以用Sybase接口或ODBC接口 

访问
. 

        在Unix下编译时
,应该在Configure时指定要带哪些数据库支持,系统中应该有 

这些数据库的客户程序
(至少是头文件和库文件)

        对各种数据库
,访问函数并不完全相同,例如那些基于SQL的数据库显然不能用 

和dBase或dbm相同的方式访问
.以下比较详细地介绍几种数据库的访问函数: 

        一
.dBase 

       
(1)dbase_create(文件,域数组); 

        域数组的每一项又是一个数组
,内容为该域的名称,类型,长度和精度(后两项 

不一定要有
)

        域类型是一个字符
,有这么几种值: 

       
"L"--逻辑,"M"--备注,"D"--日期,"N"--数字,"C"--字符串 

        返回一个数据库描述符
,失败则返回false. 

       
(2)dbase_open(文件,打开方式); 

        打开方式与C的open函数中的一样
. 

        返回一个数据库描述符
,失败则返回false. 

       
(3)dbase_numfields(数据库描述符),dbase_numrecords(数据库描述符); 

       
(4)dbase_add_record(数据库描述符,记录); 

        记录是一个数组
.失败则返回false. 

       
(5)dbase_get_record(数据库描述符,记录号); 

        返回一个数组
,下标从0开始.该数组如果用下标"deleted"访问,可以得到 

该记录是否已被删除的信息
. 

       
(6)dbase_delete_record(数据库描述符,记录号); 

       
(7)dbase_pack(数据库描述符); 

       
(8)dbase_close(数据库描述符); 

 

 

标  题
: php3:跨平台的服务器端嵌入式脚本语言(13) 

 

 

        二
,dbm 

        dbm是Unix下的一种非关系数据库
(至少我感觉是这样),它实际上是文件形式 

的哈希表
,每一对名字/值项称为一个记录. 

        dbm有好几个版本
,如ndbm,gdbm,等等. 

       
(1)dbmopen(文件,标志); 

        标志是
"r"(只读),"w"(可写)"n"(新建)

        返回一个数据库标识符
. 

       
(2)dbmfirstkey(数据库标识符); 

        取得第一个名字
(),返回一个字符. 

       
(3)dbmnextkey(数据库标识符,当前键); 

        返回下一个键
. 

       
(4)dbmexists(数据库标识符,); 

        确认该键是否存在
,返回true/false. 

       
(5)dbmfetch(数据库标识符,);  

        返回该键对应的值
(字符)

       
(6)dbminsert(数据库标识符,,); 

        插入一个记录
,如指定键已存在则返回false,否则返回true. 

       
(7)dbmreplace(数据库标识符,,);  

        替换一个记录
,如原来没有该记录则插入. 

       
(8)dbmdelete(数据库标识符,); 

        删除一个记录
. 

       
(9)dbmclose(数据库标识符);  

 

标  题
: php3:跨平台的服务器端嵌入式脚本语言(14) 

 

 

        三
,mSQL与MySQL. 

        mSQL
(mini SQL)是一种小型的关系数据库,性能不是太好,对SQL语言的 

支持也不够完全
,但在一些网络数据库应用中是足够了. 

        MySQL是mSQL的一个变种
,性能有所提高,增加了用户访问控制. 

        这两种数据库都是通过SQL语言访问的
,但MySQL基本支持全部SQL92规范, 

只是
"select ... where select .."不支持,另外还扩充了一些数据类型,而mSQL 

则基本上不支持任何嵌套SQL语句
,也不支持"update set column1=column1-1"这 

样的语句
. 

        mSQL由于较简单
,在运行简单的SQL语句时速度比MySQL略快,而MySQL在 

线程和索引上下了功夫
,运行复杂的SQL语句时比mSQL,PostgreSQL,Oracle等都 

要快一些
. 

        安全性方面
,mSQL通过ACL文件设定各主机上各用户的访问权限,缺省是 

全部可读
/,而MySQL通过一个授权库设定用户名,口令和访问权限,较可靠一些. 

        mSQL的存储能力不是很清楚
,MySQL的存储能力受文件系统限制,例如在 

Linux下不能超过2G
(3G?记不清楚了)

        它们的好处就是都能免费得到并在Linux下安装
,不过如果用于商业用途 

需要付费
. 

        PostgreSQL也是Linux下的免费数据库
,RedHat5里面就带了,不过我没有 

用过
,就不说了. 

        mSQL与MySQL既然本来就是差不多的两个东西
,PHP中对它们的访问语句也 

都差不多
,例如msql_close与mysql_close就分别完成同样的关闭动作.所以以下介绍 

时只对mysql介绍
,msql的访问语句只需换个前缀即可(特殊情况另行说明)

注意
:mSQL与MySQL访问函数都需要有相应的权限才能运行. 

       
(1)mysql_connect(主机,用户名,口令); 

        返回一个连接号
. 

        注意
:mysql各用户的口令可以随该用户所在机器IP地址不同而改变. 

        另外
,mSQL没有用户名机制,所以msql_connect只需要一个主机参数. 

        主机可以是IP地址或域名
. 

       
(2)mysql_create_db(数据库); 

       
(3)mysql_select_db(数据库,连接号); 

        连接一个数据库
. 

       
(4)mysql_query(SQL语句,连接号); 

        如果SQL语句是select
,则返回一个结果号.否则返回的值可以不理会. 

         如果失败
,返回false. 

       
(5)mysql_fetch_array(结果号); 

        取出下一行
,返回一个数组.可以用数字下标访问(第一个字段是下标 

0
),也可以用字符串下标访问(即使用各字段名)

        如已取了最后一行
,返回false. 

       
(6)mysql_fetch_field(结果号,[字段序号]); 

        如无字段序号
,取下一个字段. 

        返回一个哈希表
,下标有: 

        name
,table,max_length,not_null,primary_key,unique_key, 

        multiple_key
,numeric,blob,type,unsigned,zerofill 

        各下标的意思应该比较明白了
. 

       
(7)mysql_num_rows(结果号);mysql_num_fields(结果号); 

       
(8)mysql_free_result(结果号); 

       
(9)mysql_list_dbs();mysql_list_tables(数据库); 

       
(10)mysql_close(连接号); 

       
(11)mysql_pconnect(主机,用户名,口令); 

        与mysql_connect完全相似
,但建立一个"永久连接",该连接一经建立永不关闭, 

即使使用mysql_close函数或程序执行完毕也不关闭
.下一次试图建立永久连接时,系统 

如发现已存在一个永久连接
,则直接返回该连接号而不重新创建. 

 

        还有很多mSQL与MySQL函数
,不一一介绍了.  
<