发信人: lanman() 
整理人: znw(2000-08-10 14:08:10), 站内信件
 | 
 
 
【 以下文字转载自 ASP 讨论区 】 【 原文由 con 所发表 】 标  题: 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函数,不一一介绍了.  
  -- ※ 来源:.网易 BBS bbs.netease.com.[FROM: 203.208.6.244] -- ※ 转载:.网易 BBS bbs.netease.com.[FROM: 202.104.82.188]
  | 
 
 
 |