当前位置: 编程技术>php
本页文章导读:
▪PHP脚本的10个技巧(3)
包含文件 如果你目前着手的Web站点开发项目规模较大,那你对代码重用必定深有体会,比方说,不管是HTML还是PHP代码块,只要项目足够大,比如有1000个Web页,你即便是一年只修改一次包含.........
▪社区(php&&mysql)六
//此为bbs.sql CREATE TABLE bbs_area ( id int(10) unsigned DEFAULT '0' NOT NULL auto_increment, master varchar(150) NOT NULL, banner varchar(150) NOT NULL, body text NOT NULL, email varchar(50), login varchar(20).........
▪判“新”函数:得到今天与明天的秒数
如果你想根据时间来判断某一时间值(用秒数表示)是否在今天的范围之内。下面这个函数,将帮你轻而易举的判断。 函数源代码: --------------------------------------------- 说明:若$varTime在今天.........
[1]PHP脚本的10个技巧(3)
来源: 互联网 发布时间: 2013-11-30
包含文件
如果你目前着手的Web站点开发项目规模较大,那你对代码重用必定深有体会,比方说,不管是HTML还是PHP代码块,只要项目足够大,比如有1000个Web页,你即便是一年只修改一次包含版权信息的页脚也会让你痛不欲生。
而PHP可以通过一些函数帮助你重用代码,你要具体用到的函数依赖于你打算重用的内容。
主要的函数是:
* include() 和 include_once()
* require() 和require_once()
include()函数包含给定的文件,比如:
include('/home/me/myfile');
包含文件中的任何代码都将在include() 所在的代码页的变量范围之内执行。你可以包含服务器上的静态文件或者包含在其他服务器上的目标文件,方法是组合使用include()和fopen()。
include_once()函数和include()函数功能类似,只是该函数会检查被包含文件内的代码是否已经被目前的脚本所包含过。如果代码已经被脚本所包含,该函数就不再包含相应的文件了。
require()函数用给定文件的内容取代自身。这一替换过程发生在PHP引擎编译你的代码而不是执行代码阶段,这可和include()不一样,后者首先被计算再加到文挡中。require()函数多用于静态元素,而include()函数则主要用于动态元素。和include_once()类似,require_once()函数会检查给定代码是否早已经插入到了文挡内,如果这样,给定代码就不会被再次插入文档。
我建议你最好对诸如版权、静态文本和其他不含变量的元素这类信息采用require函数,那些依赖其他脚本来实现自己内容的元素也最好采用require函数,例如:
<HTML>
<HEAD><TITLE>Something</TITLE></HEAD>
<BODY>
[a lot of content]
<?
// insert copyright
require('/home/me/mycopyright');
?>
</BODY>
</HTML>
另一方面,我经常用include()函数把函数库或类似的内容放到脚本之外:
<?
// get my function library
include('/home/me/myfunctions');
// do PHP things with my functions ?>
<HTML>
<HEAD><TITLE>Something</TITLE></HEAD>
<BODY>
[a lot of content]
</BODY>
</HTML>
你肯定会问:“那么,被included或者被required的文件都来自哪里呢?”答案很简单:“你的系统。”不过,有时,有些代码会包含了诸如带有用户名和密码的数据库连接函数之类的安全信息,在这样的情况下,显而易见,你肯定不希望这些东西也成为文档的一部分弄得全世界都知道。
你可以把包含文件(included或者required)放在系统的任何地方,只要用户所能用到的PHP可以访问这些文件即可。你还可以给这些文件以任何你希望给出的文件扩展名,或者不设扩展名。
使用include()和require()函数可以让Web站点上普遍存在或者经常变动的元素变得更加容易处理。
如果你目前着手的Web站点开发项目规模较大,那你对代码重用必定深有体会,比方说,不管是HTML还是PHP代码块,只要项目足够大,比如有1000个Web页,你即便是一年只修改一次包含版权信息的页脚也会让你痛不欲生。
而PHP可以通过一些函数帮助你重用代码,你要具体用到的函数依赖于你打算重用的内容。
主要的函数是:
* include() 和 include_once()
* require() 和require_once()
include()函数包含给定的文件,比如:
include('/home/me/myfile');
包含文件中的任何代码都将在include() 所在的代码页的变量范围之内执行。你可以包含服务器上的静态文件或者包含在其他服务器上的目标文件,方法是组合使用include()和fopen()。
include_once()函数和include()函数功能类似,只是该函数会检查被包含文件内的代码是否已经被目前的脚本所包含过。如果代码已经被脚本所包含,该函数就不再包含相应的文件了。
require()函数用给定文件的内容取代自身。这一替换过程发生在PHP引擎编译你的代码而不是执行代码阶段,这可和include()不一样,后者首先被计算再加到文挡中。require()函数多用于静态元素,而include()函数则主要用于动态元素。和include_once()类似,require_once()函数会检查给定代码是否早已经插入到了文挡内,如果这样,给定代码就不会被再次插入文档。
我建议你最好对诸如版权、静态文本和其他不含变量的元素这类信息采用require函数,那些依赖其他脚本来实现自己内容的元素也最好采用require函数,例如:
<HTML>
<HEAD><TITLE>Something</TITLE></HEAD>
<BODY>
[a lot of content]
<?
// insert copyright
require('/home/me/mycopyright');
?>
</BODY>
</HTML>
另一方面,我经常用include()函数把函数库或类似的内容放到脚本之外:
<?
// get my function library
include('/home/me/myfunctions');
// do PHP things with my functions ?>
<HTML>
<HEAD><TITLE>Something</TITLE></HEAD>
<BODY>
[a lot of content]
</BODY>
</HTML>
你肯定会问:“那么,被included或者被required的文件都来自哪里呢?”答案很简单:“你的系统。”不过,有时,有些代码会包含了诸如带有用户名和密码的数据库连接函数之类的安全信息,在这样的情况下,显而易见,你肯定不希望这些东西也成为文档的一部分弄得全世界都知道。
你可以把包含文件(included或者required)放在系统的任何地方,只要用户所能用到的PHP可以访问这些文件即可。你还可以给这些文件以任何你希望给出的文件扩展名,或者不设扩展名。
使用include()和require()函数可以让Web站点上普遍存在或者经常变动的元素变得更加容易处理。
[2]社区(php&&mysql)六
来源: 互联网 发布时间: 2013-11-30
//此为bbs.sql
CREATE TABLE bbs_area (
id int(10) unsigned DEFAULT '0' NOT NULL auto_increment,
master varchar(150) NOT NULL,
banner varchar(150) NOT NULL,
body text NOT NULL,
email varchar(50),
login varchar(20),
passwd varchar(20),
PRIMARY KEY (id)
);
INSERT INTO bbs_area VALUES ( '1', 'master', '癚阶跋', '', 'jerry@mail.jerry.com.tw', 'master', '111111');
CREATE TABLE bbs_sml (
id int(8) unsigned DEFAULT '0' NOT NULL auto_increment,
sid int(8) unsigned DEFAULT '0' NOT NULL,
email char(60) NOT NULL,
PRIMARY KEY (id),
KEY sid (sid),
KEY email (email)
);
CREATE TABLE bbs_subj (
id int(10) unsigned DEFAULT '0' NOT NULL auto_increment,
aid int(10) unsigned DEFAULT '0' NOT NULL,
banner varchar(150) NOT NULL,
body text NOT NULL,
poster varchar(20) NOT NULL,
email varchar(50),
pip varchar(20) NOT NULL,
wdate datetime DEFAULT '0000-00-00 00:00:00' NOT NULL,
views int(8) unsigned DEFAULT '1' NOT NULL,
good int(2) unsigned DEFAULT '0' NOT NULL,
PRIMARY KEY (id),
KEY aid (aid),
KEY good (good),
KEY wdate (wdate)
);
CREATE TABLE bbs_docs (
id int(10) unsigned DEFAULT '0' NOT NULL auto_increment,
aid int(10) unsigned DEFAULT '0' NOT NULL,
sid int(10) unsigned DEFAULT '0' NOT NULL,
banner varchar(150) NOT NULL,
body text NOT NULL,
poster varchar(20) NOT NULL,
email varchar(50),
pip varchar(20) NOT NULL,
wdate datetime DEFAULT '0000-00-00 00:00:00' NOT NULL,
views int(8) unsigned DEFAULT '1' NOT NULL,
good int(2) unsigned DEFAULT '0' NOT NULL,
PRIMARY KEY (id),
KEY aid (aid),
KEY good (good),
KEY wdate (wdate)
);
CREATE TABLE bbs_sel (
id int(8) unsigned DEFAULT '0' NOT NULL auto_increment,
sid int(8) unsigned DEFAULT '0' NOT NULL,
banner char(80) NOT NULL,
sel_0 char(80) NOT NULL,
sel_1 char(80) NOT NULL,
sel_2 char(80) NOT NULL,
sel_3 char(80) NOT NULL,
sel_4 char(80) NOT NULL,
sel_5 char(80) NOT NULL,
sel_6 char(80) NOT NULL,
sel_7 char(80) NOT NULL,
sn_0 int(8) DEFAULT '0' NOT NULL,
sn_1 int(8) DEFAULT '0' NOT NULL,
sn_2 int(8) DEFAULT '0' NOT NULL,
sn_3 int(8) DEFAULT '0' NOT NULL,
sn_4 int(8) DEFAULT '0' NOT NULL,
sn_5 int(8) DEFAULT '0' NOT NULL,
sn_6 int(8) DEFAULT '0' NOT NULL,
sn_7 int(8) DEFAULT '0' NOT NULL,
PRIMARY KEY (id)
);
//此为sql.php3
<?
$sql['user']="root";
$sql['passwd']="戈畐盞絏";
$sql['db']="恶戈畐嘿";
$sql['host']="localhost";
?>
CREATE TABLE bbs_area (
id int(10) unsigned DEFAULT '0' NOT NULL auto_increment,
master varchar(150) NOT NULL,
banner varchar(150) NOT NULL,
body text NOT NULL,
email varchar(50),
login varchar(20),
passwd varchar(20),
PRIMARY KEY (id)
);
INSERT INTO bbs_area VALUES ( '1', 'master', '癚阶跋', '', 'jerry@mail.jerry.com.tw', 'master', '111111');
CREATE TABLE bbs_sml (
id int(8) unsigned DEFAULT '0' NOT NULL auto_increment,
sid int(8) unsigned DEFAULT '0' NOT NULL,
email char(60) NOT NULL,
PRIMARY KEY (id),
KEY sid (sid),
KEY email (email)
);
CREATE TABLE bbs_subj (
id int(10) unsigned DEFAULT '0' NOT NULL auto_increment,
aid int(10) unsigned DEFAULT '0' NOT NULL,
banner varchar(150) NOT NULL,
body text NOT NULL,
poster varchar(20) NOT NULL,
email varchar(50),
pip varchar(20) NOT NULL,
wdate datetime DEFAULT '0000-00-00 00:00:00' NOT NULL,
views int(8) unsigned DEFAULT '1' NOT NULL,
good int(2) unsigned DEFAULT '0' NOT NULL,
PRIMARY KEY (id),
KEY aid (aid),
KEY good (good),
KEY wdate (wdate)
);
CREATE TABLE bbs_docs (
id int(10) unsigned DEFAULT '0' NOT NULL auto_increment,
aid int(10) unsigned DEFAULT '0' NOT NULL,
sid int(10) unsigned DEFAULT '0' NOT NULL,
banner varchar(150) NOT NULL,
body text NOT NULL,
poster varchar(20) NOT NULL,
email varchar(50),
pip varchar(20) NOT NULL,
wdate datetime DEFAULT '0000-00-00 00:00:00' NOT NULL,
views int(8) unsigned DEFAULT '1' NOT NULL,
good int(2) unsigned DEFAULT '0' NOT NULL,
PRIMARY KEY (id),
KEY aid (aid),
KEY good (good),
KEY wdate (wdate)
);
CREATE TABLE bbs_sel (
id int(8) unsigned DEFAULT '0' NOT NULL auto_increment,
sid int(8) unsigned DEFAULT '0' NOT NULL,
banner char(80) NOT NULL,
sel_0 char(80) NOT NULL,
sel_1 char(80) NOT NULL,
sel_2 char(80) NOT NULL,
sel_3 char(80) NOT NULL,
sel_4 char(80) NOT NULL,
sel_5 char(80) NOT NULL,
sel_6 char(80) NOT NULL,
sel_7 char(80) NOT NULL,
sn_0 int(8) DEFAULT '0' NOT NULL,
sn_1 int(8) DEFAULT '0' NOT NULL,
sn_2 int(8) DEFAULT '0' NOT NULL,
sn_3 int(8) DEFAULT '0' NOT NULL,
sn_4 int(8) DEFAULT '0' NOT NULL,
sn_5 int(8) DEFAULT '0' NOT NULL,
sn_6 int(8) DEFAULT '0' NOT NULL,
sn_7 int(8) DEFAULT '0' NOT NULL,
PRIMARY KEY (id)
);
//此为sql.php3
<?
$sql['user']="root";
$sql['passwd']="戈畐盞絏";
$sql['db']="恶戈畐嘿";
$sql['host']="localhost";
?>
[3]判“新”函数:得到今天与明天的秒数
来源: 互联网 发布时间: 2013-11-30
如果你想根据时间来判断某一时间值(用秒数表示)是否在今天的范围之内。下面这个函数,将帮你轻而易举的判断。
函数源代码:
---------------------------------------------
说明:若$varTime在今天的范围内,返回ture,否则返回false.
function bTodayToTomorrow($varTime)
{
$nowYear=date("Y");
$nowMonth=date("n");
$nowDay=date("j");
$aryTodayAndTomorrow["Today"]=date("U",mktime(0,0,0,$nowMonth,$nowDay,$nowYear));
$aryTodayAndTomorrow["Tomorrow"]=date("U",mktime(0,0,0,$nowMonth,($nowDay+1),$nowYear));
if($varTime>=$aryTodayAndTomorrow["Today"]&&$varTime<$aryTodayAndTomorrow["Tomorrow"])
{
return true;
}
else
{
return false;
}
}
------------------
类似的你可以进行任意时间段的判断。
函数源代码:
---------------------------------------------
说明:若$varTime在今天的范围内,返回ture,否则返回false.
function bTodayToTomorrow($varTime)
{
$nowYear=date("Y");
$nowMonth=date("n");
$nowDay=date("j");
$aryTodayAndTomorrow["Today"]=date("U",mktime(0,0,0,$nowMonth,$nowDay,$nowYear));
$aryTodayAndTomorrow["Tomorrow"]=date("U",mktime(0,0,0,$nowMonth,($nowDay+1),$nowYear));
if($varTime>=$aryTodayAndTomorrow["Today"]&&$varTime<$aryTodayAndTomorrow["Tomorrow"])
{
return true;
}
else
{
return false;
}
}
------------------
类似的你可以进行任意时间段的判断。
最新技术文章: