社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 3956阅读
  • 9回复

[讨论](转)十天学会PHP

级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
第一天 R0DWjN$j  
以前写了十天学会ASP,十天学会ASP.NET什么的,现在想想再写个PHP吧,也算比较全了。 PHP的调试方法我这里就不说了,外面很多文章都有介绍,也有很多不同的组合。我这里暂时是以 Apache web server 和 MY SQL 作为WEB服务器和数据库,在php-4.3.3下的环境做的程序。当然要简单的构建和访问查看数据库 PHPMYADMIN 不可少。 #a|.cm>6  
alz2F.%Y  
至于表单设计什么的,我这里也不想多说了,在《十天学会ASP》中已经有介绍。 A{,ZfX;SPO  
V0)F/qY  
下面简单介绍一下PHP的语法。 +L>?kr[i[  
}n[<$*W^  
1、嵌入方法: pj/w9j G6  
t IO 'ky  
类似ASP的<%,PHP可以是<?php或者是<?,结束符号是?>,当然您也可以自己指定。 dWDM{t\}\  
bUS"1Tg]*6  
2、引用文件: vAH`tPi>  
,'z=cB`+o  
引用文件的方法有两种:require 及 include。 H%^j yGS  
require 的使用方法如 require("MyRequireFile.php"); 。这个函数通常放在 PHP 程序的最前面,PHP 程序在执行前,就会先读入 require 所指定引入的文件,使它变成 PHP 程序网页的一部份。常用的函数,亦可以这个方法将它引入网页中。 @teNT"  
gK+/wTQ%  
include 使用方法如 include("MyIncludeFile.php"); 。这个函数一般是放在流程控制的处理部分中。PHP 程序网页在读到 include 的文件时,才将它读进来。这种方式,可以把程序执行时的流程简单化。 p"ElO,\  
*p=a-s5-  
3、注释方法: rUOl+p_47  
N"Mw1R4  
<?php ]46#u=y~3  
echo "这是第一种例子。 " ; // 本例是 C++ 语法的注释 F!pgec%]'  
/* 本例采用多行的 ccm(r~lhJ  
注释方式 */ KE*8Y4#9  
echo "这是第二种例子。 " ; A[6D40o  
NR|t~C+  
echo "这是第三种例子。 " ; # 本例使用 UNIX Shell 语法注释 ]UFbG40Zo  
?> J rgpDZ  
71(C@/J  
4、变量类型: u/S{^2`b  
.]D7Il  
$mystring = "我是字符串" ; y L|'K}  
$NewLine = "换行了 " ; |z%:{  
$int1 = 38 ; hCFgZiH2  
$float1 = 1.732 ; Exu>%  
$float2 = 1.4E+2 ; !,z ==Qp|v  
$MyArray1 = array( "子" , "丑" , "寅" , "卯" ); IyJHKDFk  
.|Y&,?k| Y  
这里引出两个问题,首先PHP变量以$开头,第二PHP语句以;结尾,可能ASP程序员会不适应。这两个遗漏也是程序上大多错误所在。 gt Vnn]Jh  
%{*)-_M  
5、运算符号: h-+GS%  
f tE2@}  
数学运算: 符号 意义 SoPiEq  
+ 加法运算 (m%A>e B  
- 减法运算 G>>TB{}  
* 乘法运算 4te QG  
/ 除法运算  66 @#V  
% 取余数 G,fh/E+  
++ 累加 ZA{T0:  
-- 递减 *uG!U%jY)  
zC<k4[.  
字符串运算: 9Impp5`/B  
e$=UA%  
运算符号只有一个,就是英文的句号。它可以将字符串连接起来,变成合并的新字符串。类似ASP中的& H68~5lJY^]  
<? 'PK;Fg\  
c4i%9E+Af  
$a = "PHP 4" ; SNl% ?j| f  
$b = "功能强大" ; fqp!^-!X  
echo $a.$b; .XTR HL*:  
?> wR]jJb F  
这里也引出两个问题,首先PHP中输出语句是echo,第二类似ASP中的<%=变量%>,PHP中也可以<?=变量? >。 XMpa87\  
o +KDK{MD  
逻辑运算: t'{IE!_  
RF$2p4=[  
符号 意义 Z\. n6  
< 小于 _`-trE.  
> 大于 05PRlz *x=  
<= 小于或等于 jqv"8S5  
>= 大于或等于 hw9qnSeRy  
== 等于 OPe3p {]  
!= 不等于 B3C%**~:e  
&& 而且 (And) SR8)4:aKW  
and 而且 (And) 6>=yX6U1q^  
|| 或者 (Or) rK@XC +`S  
or 或者 (Or) :XFr"aSt  
xor 异或 (Xor) n> tru L  
! 不 (Not) |9'`;4W  
1=U NA :t<  
今天就说到这里,明天说一下流程控制。
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 1 发表于: 2006-09-03
学习目的:掌握php的流程控制 rHaj~s 4  
'^!#*O  
1、if..else 循环有三种结构 JEh(A=Eu>  
fPBJ%SZ  
第一种是只有用到 if 条件,当作单纯的判断。解释成 "若发生了某事则怎样处理"。语法如下: &m=73 RN  
}5]2tH${  
if (expr) { statement } 6Q*Zy[=  
mxEn iy  
其中的 expr 为判断的条件,通常都是用逻辑运算符号当判断的条件。而 statement 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {}。 gzd<D}2F~  
s~'"&0Gz  
范例:本例省略大括号。 @i <vlHpl  
SUC'o"  
<?php z;Jz^m-  
if ($state==1)echo "哈哈" ; sXaudT  
?> ;_p$5GVR|  
qd<-{  
这里特别注意的是,判断是否相等是==而不是=,ASP程序员可能常犯这个错误,= 是赋值。 fW=vN0Z  
LE}V{%)xD  
范例:本例的执行部分有三行,不可省略大括号。 ItD&L ))  
L6x;<gj  
<?php :Xi&H.k)p  
if ($state==1) { r t0_[i  
echo "哈哈 ; MSaOFv_Q  
echo "<br>" ; _)kTlX:,  
} ).3riR  
?> uL{CUt  
4G2iT+X-  
|i\%> Y,  
第两种是除了 if 之外,加上了 else 的条件,可解释成 "若发生了某事则怎样处理,否则该如何解决"。语法如下 LU $=j  
 alH6~  
if (expr) { statement1 } else { statement2 } 范例:上面的例子来修改成更完整的处理。其中的 else 由于只有一行执行的指令,因此不用加上大括号。 $1 t IC_  
<?php &u2H^ j  
if ($state==1) { +"1fr  
echo "哈哈" ; B~B,L*kC2  
echo "<br>"; ^Na3VP  
} AO238RC!:  
else{ ON9L+"vqv0  
echo "呵呵"; Ggry,3X3  
echo "<br>"; 5=#2@qp  
} GTM@9^  
?> GL%)s?   
[/o B jiBA  
U"RA*|  
第三种就是递归的 if..else 循环,通常用在多种决策判断时。它将数个 if..else 拿来合并运用处理。 6UI6E)g  
n^|SN9 _r  
直接看下面的例子 y$+=>p|d.^  
\%&):OD1  
<?php ,rV;T";r  
if ( $a > $b ) { xXlx}C  
echo "a 比 b 大" ; ,FwpHs $A  
} elseif ( $a == $b ) { g/frg(KF  
echo "a 等于 b" ; RN&6z"|jR  
} else { *q"1I9zvT  
echo "a 比 b 小" ; T|,/C|L  
} cJf&R^[T  
?> x_t$*  
9k \M<jA  
上例只用二层的 if..else 循环,用来比较 a 和 b 两个变量。实际要使用这种递归 if..else 循环时,请小心使用,因为太多层的循环容易使设计的逻辑出问题,或者少打了大括号等,都会造成程序出现莫名其妙的问题。 jx{ fel  
Tm$8\c4V:*  
2、 for 循环就单纯只有一种,没有变化,它的语法如下 CaV@<T  
{#~A `crO  
for (expr1; expr2; expr3) { statement } <0;G4fE7[H  
8"TlWHF`  
其中的 expr1 为条件的初始值。expr2 为判断的条件,通常都是用逻辑运算符号 (logical operators) 当判断的条件。expr3 为执行 statement 后要执行的部份,用来改变条件,供下次的循环判断,如加一..等等。而 statement 为符合条件的执行部分程序,若程序只有一行,可以省略大括号 {}。 &@FufpPw/  
\H&;.??W  
下例是用 for 循环写的的例子。 yuC|_nL  
O0;mXH  
<?php %k<+#j6ZH  
for ( $i = 1 ; $i <= 10 ; $i ++) { -oTdi0P  
echo "这是第".$i."次循环<br>" ; -Kw7! =_ g  
} *pDS%,$xe  
?> Tq SjL{l%  
k{O bm g  
3、 switch 循环,通常处理复合式的条件判断,每个子条件,都是 case 指令部分。在实作上若使用许多类似的 if 指令,可以将它综合成 switch 循环。 VCVKh  
D<:zw/IRE  
语法如下 cY Qm8TR<  
Nv|0Z'M  
switch (expr) { case expr1: statement1; break; case expr2: statement2; break; default: statementN; break; } -?l`LbD  
;O|u`fAqT  
其中的 expr 条件,通常为变量名称。而 case 后的 exprN,通常表示变量值。冒号后则为符合该条件要执行的部分。注意要用 break 跳离循环。 ]"^ p}:  
4 L 5$=V  
<?php gW^4@q  
switch ( date ( "D" )) { QyY<Zi;6  
case "Mon" : qA[cF$CIl)  
echo "今天星期一" ; ~1aM5Ba{  
break; <Ql2+ev6  
case "Tue" : # 2FrP5rC  
echo "今天星期二" ; cj^hwtx   
break; =Ot_P7'5gv  
case "Wed" : Q5l+-  
echo "今天星期三" ; ;U$Rd,T4S  
break; j<6+p r  
case "Thu" : 17`-eDd  
echo "今天星期四" ; aK]AhOG   
break; x8x-b>|$&<  
case "Fri" : [>U2!4=$M  
echo "今天星期五" ; :`lP+y?a1  
break; kem(U{m  
default: B&BL<X r  
echo "今天放假" ; FUZuS!sJ  
break; gX$gUB) x  
} KfYT  
?> JStEOQF4  
Gm3`/!r  
这里需要注意的是break;别遗漏了,default,省略是可以的。 HIt9W]koO  
uHRxV"@}[1  
很明显的,上述的例子用 if 循环就很麻烦了。当然在设计时,要将出现机率最大的条件放在最前面,最少出现的条件放在最后面,可以增加程序的执行效率。上例由于每天出现的机率相同,所以不用注意条件的顺序。 zD<8.AIGC  
t @a&&  
今天就说到这里,明天开始说数据库的使用。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 2 发表于: 2006-09-03
学习目的:学会构建数据库 .TDg`O24c,  
8J- ?bo  
在ASP中,如果是ACCESS数据库你可以直接打开ACCESS来编辑MDB文件,如果是SQL SERVER你可以打开企业管理器来编辑SQL SERVER数据库,但是在PHP中,MY SQL的命令行编辑可能会令初学者感到很麻烦,不要紧,你下载一个PHPMYADMIN安装一下,以后建立编辑数据库可以靠它了。 ITEf Q@#jU  
C N}0( 2n  
下面说一下它的使用。 @?;)x&<8?3  
进入了phpmyadmin后,我们首先需要建立一个数据库,Language (*) 这里选择中文简体,然后在左边的 创建一个新的数据库 这里填写数据库名字,点击创建即可。 QAMcI:5  
^<uQ9p^B  
然后在左边下拉菜单中选择那个已经创建的数据库。在下面的 vA[7i*D{w  
a;nYR5f  
在数据库 shop 中创建一个新表 : U[OUIXUi  
名字 : ts("(zI1E  
字段数 : Fey^hx w =  
feeHXKD|  
中填写表名字和大致你认为的字段数(不够或者多了都不要紧,以后可以再添加或者缺省),按执行。 #?eMEws  
然后就可以开始建立表了。 }R YPr  
第一栏是字段的名字;第二栏选择字段类型: PnB2a'(^@?  
我们常用的是以下几个: TZ3gJ6 Cb  
1)VARCHAR,文本类型 yD`pUE$  
2)INT,整数类型 cS2]?zI  
3)FLOAT,浮点数类型 o>T+fBHE  
4)DATE,日期型 QFoCi&  
5)大家或许会问,自动添加的ID在哪里?这个只要选择INT类型,在后面的额外中选择 auto_increment 就可以了。 fY #Yn  
#XqiXM~^R  
建立了表以后,可以在左边看到你建立的表,点击以后,你可以: a<>cbP  
1)按右边的结构:查看修改表结构 #`l&HV   
2)按右边的浏览:查看表中的数据 2+p XtP@O  
3)按右边的SQL:运行SQL语句 4d}n0b\d  
4)按右边的插入:插入一行记录 @`Dh 7Q  
5)按右边的清空:删除表中所有记录 0ia-D`^me  
6)按右边的删除:删除表 -mo4`F  
\q24E3zS&  
还有一个很重要的功能就是导入和导出,当我们本机做好了程序和数据库的时候,需要在服务器上也有一个本地镜像,如果是ASP的ACCESS简单了,直接上传MDB文件即可,如果是SQL SERVER也可以连接远端服务器进行导入。那么MY SQL中你可以导出所有的SQL语句,到了远端服务器的PHPMYADMIN上,创建数据库后按SQL,粘帖你刚才复制下来的所有本级生成的SQL语句即可。 _\= /~>Xl  
B<$6Dj%L  
今天就说到这里,明天继续说数据库操作。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 3 发表于: 2006-09-03
学习目的:学会连接数据库 78<fbN5}r  
JE*?O*&|Q  
PHP简直就是一个函数库,丰富的函数使PHP的某些地方相当简单。建议大家down一本PHP的函数手册,总用的到。 A{T> Aac  
olXfR-2>1  
我这里就简单说一下连接MYSQL数据库。 Bsd~_y}8  
J~ +p7S  
1、mysql_connect TC@F*B;  
A1z<2.R  
打开 MySQL 服务器连接。 X &G]ci  
语法: int mysql_connect(string [hostname] [:port], string [username], string [password]); 返回值: 整数 7uF @Xh  
Tn(uH17  
本函数建立与 MySQL 服务器的连接。其中所有的参数都可省略。当使用本函数却不加任何参数时,参数 hostname 的默认值为 localhost、参数 username 的默认值为 PHP 执行行程的拥有者、参数 password 则为空字符串 (即没有密码)。而参数 hostname 后面可以加冒号与端口号,代表使用哪个端口与 MySQL 连接。当然在使用数据库时,早点使用 mysql_close() 将连接关掉可以节省资源。 9(_n8br1  
O#>,vf$  
2、 mysql_select_db Gc5mR9pV   
"d M-3o<  
选择一个数据库。 i~M-V=Zg  
语法: int mysql_select_db(string database_name, int [link_identifier]); 返回值: 整数 R? N+./{  
D`.\c#;cN  
本函数选择 MySQL 服务器中的数据库以供之后的资料查询作业 (query) 处理。成功返回 true,失败则返回 false。 O0bOv S  
IF<T{/MA  
最简单的例子就是: 3vQVk  
$conn=mysql_connect ("127.0.0.1", "", ""); YdB/s1|G  
mysql_select_db("shop"); Z[,,(M  
连接机MY SQL数据库,打开SHOP数据库。在实际应用中应当加强点错误判断。 b.}J'?yLm  
/c4$m3?]  
今天就说到这里,明天再说一下数据库的读取。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 4 发表于: 2006-09-03
学习目的:学会读取数据 S T4[d'|j  
N f}ZG  
先看两个函数: T$;BZ=_  
1、mysql_query m Q<Vwx0  
送出一个 query 字符串。 语法: int mysql_query(string query, int [link_identifier]); 返回值: 整数 0wF)bQv1  
60D6UW  
本函数送出 query 字符串供 MySQL 做相关的处理或者执行。若没有指定 link_identifier 参数,则程序会自动寻找最近打开的 ID。当 query 查询字符串是 UPDATE、INSERT 及 DELETE 时,返回的可能是 true 或者 false;查询的字符串是 SELECT 则返回新的 ID 值,当返回 false 时,并不是执行成功但无返回值,而是查询的字符串有错误。 E% Ko[G  
XG5T`>Yl  
2、mysql_fetch_object 返回类资料。 语法: object mysql_fetch_object(int result, int [result_typ]); 返回值: 类 BgB0   
3u s^\w#  
本函数用来将查询结果 result 拆到类变量中。若 result 没有资料,则返回 false 值。 wARd^Iw  
X2P8Zq=%a  
看一个简单的例子: >rYMOC~  
<? i.FdZN{  
$exec="select * from user"; y"K[#&,0  
$result=mysql_query($exec); DV*e.Y>  
while($rs=mysql_fetch_object($result)) G1 I<B  
{ 8zjJshE/  
echo "username:".$rs->username."<br>"; (I{+ %  
} uNqN &7g  
?> N,F[x0&?  
当然,表user中有一个username的字段,这就类似asp中的 gXY]NWI  
<% 6.|[;>Km  
exec="select * from user" Oz "_KMz  
set rs=server.createobject("adodb.recordset") 'S9jMyZrZ  
rs.open exec,conn,1,1 tQTjqy{K  
do while not rs.eof X'xnJtk  
response.write "username:"&rs("username")&"<br>" w.+G+ r=  
rs.movenext {rygIl{V  
loop xF 3Z>  
%> sy6[%8D$  
当然先要连接数据库,一般我们 require_once('conn.php');而conn.php里面就是上一次说的连接数据库的代码。 ^t`0ul]c  
~;t/VsgGW  
小小的两条命令可以完成读取数据的工作了,今天说到这里下一次说数据的添加删除修改。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 5 发表于: 2006-09-03
学习目的:学会添加删除修改数据 I:;umyRH  
J M;WCV%NM  
mysql_query($exec); hK %FpGYA  
单这个语句就可以执行所有的操作了,不同的就是$exec这个sql语句 YmHu8H_Q  
 | 1a}p  
添加:$exec="insert into tablename (item1,item2) values ('".$_POST['item1']."',".$_POST['item1'].")"; !';;q  
m<J:6^H@  
删除:$exec="delete from tablename where..."; ROO@EQ#`Z  
#W4 "^#2  
修改:$exec="update tablename set item1='".$_POST['item1']."' where ..."; 0="wxB  
CbOCL~ "  
说到这里就要说一下表单和php变量传递,如果表单中的一个 <input name="item1" type="text" id="item1"> {9cjitl  
表单以POST提交的,那么处理表单文件就可以用$_POST['item1']得到变量值,同样以GET提交的就是$_GET['item1'] , hp8b$  
(N9g6V  
是不是很简单?但是通常$exec会有问题,因为可能您的SQL语句会很长,您会遗漏.连接符,或者'来包围字符型字段。 a/[)A _-  
我们可以注释mysql_query($exec);语句用echo $exec;代替来输出$exec以检查正确性。如果您还不能察觉$exec有什么错误的话,可以复制这个sql语句到phpmyadmin中执行,看看它的出错信息。还有需要注意的是,我们不要使用一些敏感的字符串作为字段名字,否则很可能会出现问题,比如说date什么的。变量的命名,字段的命名遵循一点规律有的时候对自己是一种好处,初学者并不可忽视其重要性。 Sf2xI'  
'*<I<? z;  
今天就说到这里,大家可以DOWN一个SQL语句的参考手册,再研究研究。明天继续说SESSION。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 6 发表于: 2006-09-03
学习目的:学会SESSION的使用 F(Je$c/J|~  
\p^'[B(O77  
SESSION的作用很多,最多用的就是站点内页面间变量传递。在页面开始我们要session_start();开启SESSION; FB %-$  
然后就可以使用SESSION变量了,比如说要赋值就是:$_SESSION['item']="item1";要得到值就是$item1=$_SESSION['item'];,很简单吧。这里我们可能会使用到一些函数,比如说判断是不是某SESSION变量为空,可以这么写:empty($_SESSION['inum'])返回true or false。 Zh`[A9I/  
dk0} q6~  
下面综合一下前面所说的我们来看一个登陆程序,判断用户名密码是否正确。 1Vs>G  
登陆表单是这样:login.php }hcY5E-n  
<table width="100%" height="100%" border="0" align="center" cellpadding="0" cellspacing="0"> I__ a}|T%  
<tr> [$#G|>x  
<form action="checklogin.php" method="post"><td align="center" valign="middle"><table width="400" border="0" cellpadding="5" cellspacing="1" class="tablebg"> m>*~ tP  
<tr class="tdbg"> IsDwa qd|  
<td colspan="2"><div align="center">Administrators Login</div></td> F^5\w-gLY  
</tr> b.RFvq5Z  
<tr class="tdbg"> #5iy^?N"w  
<td><div align="center">Username</div></td> oVW>PEgB-  
<td><div align="center"> yD@1H(yM  
<input name="username" type="text" id="username"> ~ e a K]|  
</div></td> d\25  
</tr> T wzpq1  
<tr class="tdbg"> g{f7 } gTG  
<td><div align="center">Password</div></td> ?# RhHD  
<td><div align="center"> B>@l(e)b  
<input name="password" type="password" id="password"> )KGz -!1c  
</div></td> &y7xL-xP  
</tr> U2v;GIo$yU  
<tr class="tdbg"> #)3 B  
<td colspan="2"><div align="center"> eHR]qy 0_X  
<input type="submit" name="Submit" value="Submit"> }daU/  
<input type="reset" name="Submit2" value="Clear"> n~0MhE0H  
</div></td> /!qP=ngw9  
</tr> CyXaHO  
</table></td></form> fK2r6D9  
</tr> :}-?X\|\  
</table> {|B[[W\TN  
}0iHf'~DH*  
处理文件是这样 JoZS p"R  
<? JpxQS~VX  
require_once('conn.php'); #%w)w R3  
session_start(); wuW{ 2+)B  
$username=$_POST['username']; \ FJ ae  
$password=$_POST['password'];  +cKOIMu9  
$exec="select * from admin where username='".$username."'"; lD-2 5~YV  
if($result=mysql_query($exec)) ap2g^lQXq  
{ >0uj\5h)I]  
if($rs=mysql_fetch_object($result)) 96P&+  
{ @;N(3| n7  
if($rs->password==$password) n{&;@mgI  
{ M?GkHJ%!  
$_SESSION['adminname']=$username; ,eWLig  
header("location:index.php"); ).A9>^6?{  
} e m0 hTxb  
else )lz~Rt;1i  
{ H6Bw3I[  
echo "<script>alert('Password Check Error!');location.href='login.php';</script>"; \9uK^oS  
} 67 ~pn  
} Z`U+ a  
else R[)bGl6#  
{ ZKq#PB/.  
echo "<script>alert('Username Check Error!');location.href='login.php';</script>"; `xx3JQv[  
} j%Xa8$  
} 7upWM~H^  
else $R NHRA.  
{ /J&ks>St  
echo "<script>alert('Database Connection Error!');location.href='login.php';</script>"; WW>m`RU`  
} .wyuB;:  
WuFBt=%  
?> EU04U  
_zi| GD  
conn.php是这样: r-*6# "  
<? 08D:2 z1z  
$conn=mysql_connect ("127.0.0.1", "", ""); ^!0z+M:>^  
mysql_select_db("shop"); os&FrtDg  
?> +|7N89l  
%u_dxpx  
由于 $_SESSION['adminname']=$username;我们可以这样写验证是否登陆语句的文件:checkadmin.asp x<' $  
<? K]G(u"'  
session_start(); YbnXAi\y|  
if($_SESSION['adminname']==') ~8"oH5  
{ S^|U"  
echo "<script>alert('Please Login First');location.href='login.php';</script>"; (DS"*4ty  
} :Fu7T1  
?> g_N^Y  
aM(#J7;  
呵呵,今天说到这里,明天说一下怎么弄一个分页。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 7 发表于: 2006-09-03
学习目的:做一个分页显示 gIusp917  
-mn/Yv  
关键就是用到了SQL语句中的limit来限定显示的记录从几到几。我们需要一个记录当前页的变量$page,还需要总共的记录数$num LME&qKe5  
1q3"qY H  
对于$page如果没有我们就让它=0,如果有<0就让它也=0,如果超过了总的页数就让他=总的页数。 ~zG)<S"q  
>]xW{71F@  
$execc="select count(*) from tablename "; LExm#T`  
$resultc=mysql_query($execc); 0I<L<^s3^U  
$rsc=mysql_fetch_array($resultc); ,\cV,$  
$num=$rsc[0]; F:q8.^HTJ  
JbS[(+o  
这样可以得到记录总数 "DfjUk  
ceil($num/10))如果一页10记录的话,这个就是总的页数 M \  
,(zV~-:9  
所以可以这么写 +,AzxP _y  
if(empty($_GET['page'])) |+::sL\r  
{ $u'"C|>8  
$page=0; `O%nDry  
} VltM{-k^  
else qtozMa  
{ kGo2R]Dd[  
$page=$_GET['page']; iLNUydiS  
if($page<0)$page=0; ]+3M\ ib  
if($page>=ceil($num/10))$page=ceil($num/10)-1;//因为page是从0开始的,所以要-1 k ,+,,W  
} c%^B '  
]1Wxa?  
这样$exec可以这么写 $exec="select * from tablename limit ".($page*10).",10"; bhIShk[  
//一页是10记录的 9d-'%Q>+  
<tZZ]Y]  
最后我们需要做的就是几个连接: fCF.P"{W"  
<a href="xxx.php?page=0">FirstPage</a> qHdUnW  
<a href="xxx.php?page=<?=($page-1)?>">PrevPage</a> 6kLy!QS  
<a href="xxx.php?page=<?=($page+1)?>">NextPage</a> 6Aq]I$  
<a href="xxx.php?page=<?=ceil($num/10)-1?>">LastPage</a> ~%g,Uypi  
T 4p}5ew'  
这是一个大致的思路,大家可以想想怎么来优化?今天说到这里,明天说一下一些注意的问题。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 8 发表于: 2006-09-03
学习目的:注意事项 SO(BkxV@  
w9VwZow  
因为我是先学ASP的,所以再做PHP的时候会发现很多地方需要适应。 l5Ko9CG  
Ao}<a1f  
1、注意不要漏了分号 ?HZ^V  
2、注意不要漏了变量前的$ h8 N|m0W  
3、使用SESSION的时候注意不要遗漏session_start(); SJa>!]U'xI  
'@hUmrl  
如果发生错误的时候,可以采用以下方法: qve'Gm)  
1、如果是SQL语句出错,就注释了然后输出SQL语句,注意也要注释调后续的执行SQL语句 7<MEMNYX  
2、如果是变量为空,大多是没有传递到位,输出变量检查一下,检查一下表单的id和name 43B0ynagN  
3、如果是数据库连接出错,检查是否正确打开MY SQL和是否遗漏了连接语句 ~5%3]  
4、注意缩进,排除括号不区配的错误 @0 P4pt;(  
.!0Rh9yyl  
在做大网站的时候,我的思路是先构建数据库,确定每一个字段的作用,和表之间的关系。然后设计后台界面,从添加数据开始做起,因为添加是否成功可以直接到数据库里面验证,做好了添加再做显示的页面,最后才是两者的结合。一般来说后台就包括添加删除修改和显示,后台没有问题了,前台也没有什么大问题。前台还需要注意安全性和容错还有就是输出格式。 IauLT;!X  
P658 XKE  
好了,今天说到这里,明天说一下如果用PHP上传文件和发邮件。
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 9 发表于: 2006-09-03
学习目的:学会用PHP上传文件和发邮件 6A]I" E]5  
%\sE\]K  
上传文件表单必须加上 enctype="multipart/form-data" S%}G 8Ty  
和 <input type="file" name="file"> |6bvUFr  
下面看一下代码: NWFh<  
X5/fy"g&  
$f=&$HTTP_POST_FILES['file']; lqmQQ*Z  
$dest_dir='uploads';//设定上传目录 s.Z{mnD6  
$dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//我这里设置文件名为日期加上文件名避免重复 r[}nrH&8  
$r=move_uploaded_file($f['tmp_name'],$dest); n ng|m  
chmod($dest, 0755);//设定上传的文件的属性 ]goJ- &  
dLb$3!3  
上传的文件名为date("ymd")."_".$f['name'] ,可以在以后插入到数据库的时候用到,PHP实际上是把你上传的文件从临时目录移动到指定目录。move_uploaded_file($f['tmp_name'],$dest);这是关键 |rk.t g9  
*w(n%f  
至于发邮件就更加简单,可以使用mail()函数 99ZWB  
 2hF^U+I}  
mail("收件人地址","主题","正文","From:发件人 Reply-to:发件人的地址"); sU&v B:]~  
7{O iV}]"  
不过mail()需要服务器的支持,在WINDOWS下还需要配置SMTP服务器,一般来说外面的LINUX空间都行。 d%qi~koN_  
好像上传文件和发邮件比ASP简单很多,只要调用函数就可以了。ASP还需要用到服务器的不同组件比如FSO、JMAIL什么的。 7afG4 (<k  
7,p.M)t)  
十天学会PHP说到这里了,我的三大系列文章都用《十天学会》作为名字,想告诉大家的是ASP,PHP,ASP.NET入门都可以是十天,但是精通决不是十天啊,还需要大家自己去研究。
描述
快速回复

您目前还是游客,请 登录注册
欢迎提供真实交流,考虑发帖者的感受
认证码:
验证问题:
10+5=?,请输入中文答案:十五