设为首页收藏本站language 语言切换
查看: 1585|回复: 0
收起左侧

PHP编程常用技巧

[复制链接]
发表于 2010-2-24 13:42:02 | 显示全部楼层 |阅读模式
PHP编程常用技巧四则 <BR><BR>  1.配置PHP文件目录 <BR><BR>  作为服务器端解释执行的脚本语言,PHP程序放置在某个服务器可以访问的目录下,一般可以通过修改Apache的httpd.conj进行配置,例如我们在该文件中的一句: <BR><BR>  Alias /test/ "d:/phpwebsite/php/" 那么在浏览器端输入:“http://www.it055.com/test/+PHP文件名”就可以访问d:/phpwebsite/php/下的PHP文件了;可见该行不过是为存放PHP文件的目录起一个别名。 <BR><BR>  其次,还可以通过指定DocumentRoot路径得到存放服务器文件的目录,在httpd.conj找到以下两行,其中的路径可以随意指定,你的PHP文件也可以放在该目录下,服务器同样可以运行它们,如“http://www.it055.com/+PHP文件名”。 <BR><BR>  一般的,将PHP文件放在同一个地方比较好,可以方便管理,而其他文件放在另外一个地方。 <BR><BR>DocumentRoot "C:/usr/bin/html/" <BR><BR>2.服务器端目录的索引文件 <BR>在httpd.conj中,有一行: <BR>DirectoryIndex index.html <BR><BR>  该行指定目录默认打开文件为index.html,当访问某个目录时,服务器就会自动查找index.html, 若果不存在,则显示目录中的所有文件列表,默认打开文件可以改为别的,如index.php3等等,但是也许我们有很多目录,无论是存放图片,文本等资料的,还是存放PHP文件或别的文件的目录,我们并不希望用户能看到目录中的文件列表,在httpd.conj 中指定了一个.htacess文件,该文件产生一个目录索引文件,例如我们用写字板建立一个.htacess文件: <BR><BR># .htacess # <BR>DirectoryIndex error_open.php <BR>再建立一个错误警告文件: <BR># error_open.php # <BR><BR><BR>  其中的error_open.php为权限错误警告文件,将此2文件放在所有保护目录下,当用户企图打开目录时,自动转向执行error_open.php,显示错误警告。 <BR><BR>  3.目录删除巧实现 <BR>我们知道,PHP4 for/win32中有个rename()函数可以支持对目录/文件进行重命名,如: <BR>rename( oldpath, newpath) // oldpath为文件或目录原来路径; <BR>// newpath为新定义路径; <BR><BR>  实现将 oldpath改名为 newpath。 <BR><BR>  PHP4中没有删除目录/文件的函数,怎么作到删除呢?我们知道,php.ini中有一行用来完成HTTP上传操作的临时文件目录配置行: <BR>upload_tmp_dir= ; <BR><BR>  PHP4支持该临时目录的配置(PHP3不支持),当上载操作完成则自动清空临时目录,好了,用它我们可以巧妙的实现文件/目录的删除,比如设置: upload_tmp_dir="d:/phpwebsite/php/tmp/" ; <BR>要删除某个目录 path,执行: <BR><BR>tmp="d:/phpwebsite/php/tmp/;" <BR>rename( path, tmp) <BR>?&gt; <BR><BR>  那么文件或目录 path改名为 tmp后, tmp目录下的所有文件/目录自动清除,就完成了删除操作。 <BR><BR>  4.快速建立MySql数据库表 <BR><BR>  PHP和MySql数据库达到了完美结合,在网页上,比如在论坛或书屋发表作品的新用户,我们要把他的言论信息在线写入数据库中,往往要在相应的数据库中为该用户新建一个数据表。win32下建立新的MySQL空数据库很简单,只要在“/mysql/data/”目录下建立一个文件夹,如:"/usrinfo/",就可以了。而向库中增添新表可通过以下程序实现: <BR><BR>  # connect.mysql--连接数据库 # <BR>connection = mysql_connect(); <BR>mysql_select_db("usrinfo", connection); <BR>?&gt; <BR># make.php-- 建立如下结构的,以用户名为表名的数据表 # <BR>//调用connect.mysql <BR>require("connect.mysql"); <BR>//检查以用户名为表名的数据表存在否? <BR>query="select count(*) from usrname"; <BR>result=mysql_db_query( query); <BR>//不存在则创建,如存在就是老用户; <BR>if(! result){ <BR>mysql_query(" <BR>create table usrname( <BR>id tinyint(6), <BR>title text, <BR>body longtext, <BR>dateof date; <BR>timeof time; <BR>)")_or_die(mysql_error()); <BR>} <BR>//此处为向数据表插入新的数据部分 <BR>?&gt; </div>
您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2025-4-17 04:38 , Processed in 0.063437 second(s), 24 queries , Redis On.  

  Powered by Discuz!

  © 2001-2025 HH010.COM

快速回复 返回顶部 返回列表