1:为什么我得不到变量, r3 T8 L" N5 d9 I3 A. s
- D% K3 Q5 X# h; y! {5 q4 D
我在一网页向另一网页POST数据name,为什么输出$name时却得不到任何值?
* K, w+ E0 y+ q. Y; @6 H) U5 y( g
在PHP4.2以后的版本中register_global默认为off5 }( T Y; ? h2 T
若想取得从另一页面提交的变量:
* `0 q% v5 H1 e, b# E, Y- L7 ]
. A4 C' T! k/ U) [) Q4 D0 i 方法一:在PHP.ini中找到register_global,并把它设置为on.
. `6 R) i& i, e8 Q4 T2 F 方法二:在接收网页最前面放上这个extract($_POST);extract($_GET);(注意extract($_SESSION)前必须要有Session_Start()).( E/ ~+ P' w/ v/ S' C" O0 u
方法三:一个一个读取变量$a=$_GET["a"];$b=$_POST["b"]等,这种方法虽然麻烦,但比较安全.9 `) b2 X$ C6 N$ L% M
$ C" p+ g+ h' u 2:调试你的程序
' T, K0 M+ a8 [. r& I: F; P
$ `% O3 h% x; G- k; ~ 在运行时必须知道某个变量为何值。我是这样做的,建立一文件debug.php,其内容如下:; J+ K+ r6 y8 Y V* d
; w1 V- V- O. D1 n3 g, V PHP代码:5 X/ r8 b% k4 {
. i# ~! E$ u) J( p) A: l5 L
. x/ f" v. g. b- Y. G( y Ob_Start();
; X( r& f% _* R, r: Q+ f1 q" s- ? Session_Start();/ X. f: `+ E" m% {
Echo "
";7 T- |$ G" M! /7 C9 _6 Q7 k: f. n
( J: U" J( ^3 G ]5 r7 e. l Echo "本页得到的_GET变量有:";9 t" Y: `( ]& H4 x& k
Print_R($_GET);
5 W3 t( a; G' U5 ?
+ G% } n+ N6 / Echo "本页得到的_POST变量有:";/ t4 w% x, p+ j% O( r
Print_R($_POST);' n4 a, ~ @* Z: R$ _# v
* z- |# b6 ^2 o7 ] Echo "本页得到的_COOKIE变量有:";
4 W8 p' o. m' X3 O, } Print_R($_COOKIE);+ @3 b8 U' s# K0 H& s' ]
: r( ~+ }( Y' W& |( O) V
Echo "本页得到的_SESSION变量有:";
6 I7 B) @9 r6 W' O- Z) N7 t Print_R($_SESSION);9 |, c# |7 ]# Z8 x
; H8 h/ @0 o( w- f
Echo "
";
/ R( M8 j/ h$ r) R i- P ?>
" z* H( Z5 p: `, Z" Q2 E, g/ _. S1 x) C. q; X% `* `2 |1 T$ ? 然后在php.ini中设置:include_path = "c:/php",并将debug.php放在此文件夹,以后就可以在每个网页里包含此文件,查看得到的变量名和值.
5 W+ T- `2 h: C& v" V) |3 e' c) j B* p+ S, s" D; P; L( f8 d 3:如何使用
session, }, }" Q, q7 y% V7 C6 F5 E' Z/ H8 c% a% d, ^ 凡是与session有关的,之前必须调用
函数session_start();
; n) j9 j- Q5 F* c9 G# M# T! X0 B/ `8 s+ i5 B* /9 e 为session付值很简单,如:
8 n0 P5 t4 T+ f; ]5 F' d0 ? }0 ~+ I" f0 o0 i$ Z5 T PHP代码:
* q% d' k" f4 y# { + k3 X! [+ h, m: d$ E" } 8 Q3 I- s+ M% O; l; Y# T Session_start();
& _2 U, d' R2 S" f# h# A Q $Name = "这是一个Session例子";
( ]* E( A; [- o& d) ]% n3 Z- h Session_Register("Name");//注意,不要写成:Session_Register("$Name");
7 ]7 ~* w3 U$ p+ _+ @7 T8 m. T' y Echo $_SESSION["Name"];
! J0 z/ R u6 C. m //之后$_SESSION["Name"]为"这是一个Session例子"
& ]" N/ p: j/ g# s+ Z6 N6 A" E ?>
, b$ b* ?, i* ?$ r3 r. W% f9 Z* L 在php4.2之后,可以为session直接付值:
# B5 y+ q$ A9 r2 q& g$ i' {3 Y! g0 ` PHP代码:
) W9 N8 J& F6 Q4 d) ~5 K/ d2 e2 A m W2 s! q- W4 _& x % H( b) Q" Z) N8 o! Q
Session_Start();
3 /1 [6 /' J. G$ m $_SESSION["name"]="value";
4 X% @$ c& a$ H9 L ?>
- U0 R' y8 F3 Y3 /, K+ R; w. v$ |0 b 取消session可以这样:
5 Z3 J. Y% n; d1 z6 ^) I- U. S( S0 b5 Y& m( U lPHP代码:
) S0 G, B5 s/ U* Q) _9 _+ B1 _$ T& z0 d- e8 d1 v# D1 Z. N 9 T$ O* i# x1 x9 S7 p$ T6 b session_start();
g5 J3 ]1 v# u- @/ y session_unset();
+ D/ H3 L& A- s% G: P( g* |; m session_destroy();
- S, x1 l' `8 j* D ?>
& ~3 {7 U& C% w8 S7 e3 }& g1 ~; B9 J/ d# Q 取消某个session变量在php4.2以上还有BUG.
& _/ S" x2 Q/ x- L' W k2 D) V' h# Y( z 注意:
8 l" Q) l Q A3 R) ~1 u- B. l5 Z) E+ F 1:在调用Session_Start()之前不能有任何输出.例如下面是错误的.
4 j3 G* U7 n/ e3 p ==========================================
/. R/ s5 _8 D4 L9 v 1行
0 |* Q2 {! c! G* D1 s 2行 3行 Session_Start();//之前在第一行已经有输出
! M9 r6 w# v3 ?4 `5 Y& v 4行 .....
1 d( P& g+ P1 V. M 5行 ?>
& a" c, b5 z0 o; v ==========================================
! ?5 M$ P# N# v$ A7 R2 M8 E6 K- {3 z9 d0 l. Z4 ^0 F2 G 提示1:
9 ^( ?0 [; K5 D2 e j5 T, K# t3 A1 g& ]& c6 h' n 凡是出现" ........headers already sent.......... ",就是Session_Start()之前向浏览器输出信息.去掉输出就正常,(COOKIE也会出现这种错误,错误原因一样)
) E5 B7 C( Q% k+ p5 q3 K$ B8 c H% W/ b; n) Z( t* J$ _ 提示2:
/ O2 B- a" j1 g) j! i, M, _* s; r- N) V8 p* o3 z. q1 M 如果你的Session_Start()放在循环
语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:
. o7 C4 g. K2 O* W 1行
, X; q' k1 M$ k: / ........这里是你的程序......
' v! W6 e& ]/ j3 _: F' D+ ^; X2 N$ v1 k: ?1 L; Y" B1 o 2:这是什么错误
3 H Y8 E9 a) n9 `6 t* g; I+ ^; {4 s1 z2 A0 m R Warning: session_start(): open(/tmp/sess_7d190aa36b4c5ec13a5c1649cc2da23f, O_RDWR) failed:....
) S# }6 c4 }2 G! ^- N因为你没有指定session文件的存放路径.
. T# e4 @/ m; d: V w8 E7 s; k% O) h! /+ D 解决方法:
( J2 Z: T! Z% M! l: A (1)在c盘建立文件夹tmp
+ u2 i% /- [6 d3 t (2)打开php.ini,找到session.save_path,修改为session.save_path= "c:/tmp"
+ B0 V" H4 _! k1 V& o: ]" l! S8 H- w- j$ /1 K; K1 f) N' j 4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失
5 r- h1 l7 V" ?. y6 /- B3 q$ O/ y% a- d: w8 J8 z& s PHP代码:
0 R( V6 X0 u p& L& J, t o+ C1 [+ B9 K C8 v$ u1 j 2 r9 F$ J$ |( [8 G& F9 r
$Var="hello php";//修改为$Var=" hello php";试试得到什么结果
, |( W9 o' F0 m3 x& o; Y D $post= "receive.php?Name=".$Var;
6 N0 }0 m; D5 L2 d7 p header("location:$post");
2 h8 l# B8 e% W+ ?# U7 p, Y% I$ @, O/ Y ?>
1 {$ s: I( e W7 H6 z1 Q! n0 M: T7 h; e0 V receive.php的内容:
& n, }& n1 s: A j: G9 P1 i7 S+ l9 {5 _+ G' h PHP代码:
) j: O6 X- n- D; C" [4 _; g# |! j8 v' [2 L3 c7 O" M3 s T( K, _5 |6 ?3 w! r7 b Echo "
";4 e, ]7 [) A% ?7 B
Echo $_GET["Name"];: p' J/ L! @ c+ p5 F" r/ M
Echo "
";
# v) i# r1 U! K4 U ?>
% R. l& E& P$ D# j' H9 I7 `4 R K2 Q; U8 ?4 { 正确的方法是:
+ ]8 m1 i$ l, s/ U- c4 / [4 a2 r: s- w+ {- w2 N PHP代码:
* Z( ?" l9 f7 c2 u7 Q; y# m1 d+ E0 ^* D+ }1 R8 E$ r ' A8 Z; ~% _! O1 i1 N, J# n
$Var="hello php";
) U( ^/ T# z# W $post= "receive.php?Name=".urlencode($Var);
9 B5 b. B! F7 N" /* m/ @ header("location:$post");
! I0 c' u9 z) h( E ?>
1 Z: K7 @' a& V+ n( [6 u- K" u5 q6 R. ^. }' ^/ _ 在接收页面你不需要使用Urldecode(),变量会
自动编码.
2 S) g1 x3 g i) s7 H+ ] o5 h# y2 T2 w, g: J! |9 B2 |5:如何截取指定长度汉字而不会出现以"?>"结尾,超出部分以"..."代替
0 y" / F; p- d( J. z& I# {9 Z0 C- L6 i/ ? 一般来说,要截取的变量来自Mysql,首先要保证那个字段长度要足够长,一般为char(200),可以保持100个汉字,包括标点.
6 E7 e' o; N* D. L& X* A# P% n% W) v- U PHP代码:
1 ^; M3 h( E/ {* F" g. h9 U9 c5 U; ]. n- g W5 V 4 Y! e" P0 K; F1 I4 o& T $str="这个字符好长呀,^_^";
3 f+ F2 m' r' @4 T8 N8 S7 / $Short_Str=showShort($str,4);//截取前面4个汉字,结果为:这个字符...
. c- `2 z/ m; B K6 o2 X, ` Echo "$Short_Str";
. p; ~2 S7 _% y8 e7 G) c Function csubstr($str,$start,$len)
2 G* w7 g+ J" p2 j5 m {
5 J1 D, b1 m6 {% M $strlen=strlen($str);
; u8 U3 j/ Z0 | $clen=0;
4 a, ^) Q7 e+ [/ N for($i=0;$i<$strlen;$i++,$clen++)
5 c9 h, e- e/ ?; z {
4 o# F+ m3 I" C4 H if ($clen>=$start+$len)
% _" X# K: Y7 _) x }. G4 M+ N break;
# p1 X# U5 m o, A& x if(ord(substr($str,$i,1))>0xa0)
* R: [. [# u$ T; Q- ^ {
' V8 V$ V3 ]: Z if ($clen>=$start)
. m3 `/ f) E/ a8 i5 x $tmpstr.=substr($str,$i,2);
: k0 B8 V2 H* T# B0 v1 f; l $i++;
$ q1 I' _' J' T9 `, [ }
% F0 j. Q) c0 o; f; A else
+ `; /7 h' h1 r {
# w/ V2 `+ g/ |; c' n if ($clen>=$start)
% Z. v+ a5 /$ E6 Y' V$ W# F: c" } $tmpstr.=substr($str,$i,1);
; j. f7 ^' /# [$ q# e+ ]$ a }
1 ]6 J; E4 d1 N }
/ G2 L. W, w4 O/ z+ s" l/ v0 v t; p% u* L1 b' s) f& B9 k return $tmpstr;
% @" x: l1 N) f3 i1 m8 ] }
1 e# L. G8 s, I Function showShort($str,$len)
0 ^, O, k* f. p' V* m {
& ~+ `- D) _& F; q* ? $tempstr = csubstr($str,0,$len);
! ]( B: } F! x; ^8 V if ($str<>$tempstr)
+ B# E; Y# A, u3 X6 { $tempstr .= "..."; //要以什么结尾,修改这里就可以.
2 }6 ]: m2 a" z( I( k4 G4 P- Q- B! x9 H2 U, f, A return $tempstr;
" c' Y! k& A/ Y& ~9 J! H }
1 B& E n# E) w( n! J" t9 [, l; `& m6 _8 g6 S* i; ~6 U D. N, T3 n+ O+ d& K; z 6:
规范你的
SQL语句
& ?7 {" e0 e7 T. W/ X$ `6 u8 e& o* l4 C# R( L4 } 在
表格,字段前面加上"`",这样就不会因为误用关键字而出现错误,当然我并不
推荐你使用关键字.
8 n. {. g3 B$ r3 R! x5 a( h& S. a2 Q2 a* i 例如
% ?& L0 P: q5 E4 ~+ g% ~0 ]( w. G $Sql="INSERT INTO `xltxlm` (`author`, `title`, `id`, `content`, `date`) VALUES ('xltxlm', 'use`', 1, 'criterion your sql string ', '2003-07-11 00:00:00')"
+ x, R8 D% O- B7 }! y1 F1 J3 f4 }& `; Q$ }0 Y "`"怎么输入? 在TAB键上面.
1 [. `# p; b0 t- D0 ^# G. a% N) D7 V2 q) K( D- C: r5 T: D$ o( D; k u 7:如何使Html/PHP格式的字符串不被解释,而是照原样显示
( P5 g* ]9 n% j/ V2 F' m6 w! Q4 /+ [ PHP代码:
a3 O) u8 @ t9 g$ g+ y, r, Y5 t: h! i6 Q: ^$ J % T+ Y9 P3 o H
$str="
;PHP
";
* {) t& S9 S$ s. I+ / Echo "被解释过的: ".$str."
经过处理的:";
6 {3 x% u6 N8 c3 G4 K7 `) P Echo htmlentities(nl2br($str));
0 W! |5 G3 V9 M7 R: K8 V: i ?>
" G9 /' A$ v$ g4 t* E' A# E2 y5 z; t6 g* A* ~$ t4 F @( I% B9 |1 z 8:怎么在函数里取得函数外的变量值
2 @% c5 x# f) P4 y: e2 R) x/ /- P, h E# {9 Z PHP代码:
) n7 a& C$ V( ~7 B2 t2 Q& E6 A) v& v3 |! /6 @& ^ ( i6 l. r( ]! [# i $a=";PHP";
! o- B- x3 c7 F0 T1 C: i. M8 y" p foo();
& a2 Q( d+ o) B2 x: ~ Function foo()
9 w r$ O4 a. i. _' ^ {
4 Z" o0 M u( ^- { global $a;//删除这里看看是什么结果
/ L" }1 C* x% H9 J( o1 f! x* w Echo "$a";
& `+ E0 z6 u4 O/ {) Q* v$ E8 ] }
& S1 H' |1 ]: }. ~* T4 t ?>
* i6 h/ j' m, g. N$ I7 y, x* ~, x# |6 _/ C. a: h/ C9:我怎么知道
系统默认支持什么函数
B( _3 |/ j; n; ? x8 c( r/ C0 O) I' d1 `) p6 N& p PHP代码:
: P- j7 r. V1 Z2 Q/ i$ |+ v1 z7 [1 A ' F8 R5 M+ /# T+ D- o* @) q/ |. E. ] $arr = get_defined_functions();
! [! J1 |$ H3 /# ^ Function php() {
+ ]* P3 C* i4 S8 x$ e6 H, z }
. U5 t4 F3 R' x9 F9 }) u0 h echo "
"; - u& /* K0 U* L+ W
Echo "这里显示系统所支持的所有函数,和自定以函数php/n";0 A" Z9 S a3 s: y/ K) @
print_r($arr); # g7 B* K: H9 E5 d8 d) c9 K
echo "
";
* _2 u7 l! C. B$ n/ h5 b# P ?>
+ p+ G, e; R$ N2 `, a6 m' O4 H: j' y: W( Q2 f+ u& ?0 O1 F# }& k" @ 10:如何比较两个日期相差几天
- X1 E# H" A: ~3 l' W7 /) a: g* _& M8 y' O( j- }+ / PHP代码:
: w+ E2 ?" ^/ ]! q, |( ?3 W. i) M2 S ; A4 ]' |3 R3 U3 |6 O, e
$Date_1="2003-7-15";//也可以是:$Date_1="2003-7-15 23:29:14";
, Q# s) ]7 x: e# F& w $Date_2="1982-10-1";
0 U) R) ^, R" X I; X+ O" J $d1=strtotime($Date_1);
2 r# O2 O& Z( f: S( M $d2=strtotime($Date_2);
* b- ~3 r: m6 r% ^8 k3 b $Days=round(($d1-$d2)/3600/24);
# @7 j N. P6 z6 t+ O8 t* d4 Q Echo "偶已经奋斗了 $Days 天^_^";
+ B$ h+ z4 `) W- I* s ?>
/ f E0 b7 P4 b) u( _' ?0 s9 z$ a2 u. B- H. u7 A0 B$ l: t* _, u 11:为什么我升级PHP后,原来的程序出现满屏的 Notice: Undefined variable:
" ^( C1 @9 { g$ R: Q& [ [ x; v' a, y- Z5 ~ 这是警告的意思,由于变量未
定义引起的.
% |* f8 D8 F% _ 打开php.ini,找到最下面的error_reporting,修改为error_reporting = E_ALL & ~E_NOTICE
$ Y, v, p+ t6 D4 V8 N" Q5 q0 |* S0 A) a0 V( K7 / 对于Parse error错误
# O+ ?# v4 J5 M. a error_reporting(0)无法关闭.
4 V' k; J& j# {! ` g 如果你想关闭任何错误提示,打开php.ini,找到display_errors,设置为display_errors = Off.以后任何错误都不会提示.
2 `0 q# [3 n! x* H: k3 {1 C$ P) u' A! Q2 I 那什么是error_reporting?
* P- ]4 ?3 F: L' I8 ~+ E; H* u* h5 u7 b! k! R' l/ x! s 12:我想在每个文件最前,最后面都加上一文件.但一个一个添加很麻烦
6 ~, E- L; Y9 J6 x: e7 R) f+ u5 o! Q9 ~' k* P3 o 1:打开php.ini文件
) s# v- ~9 x; V. U1 ~6 z 设置 include_path= "c:"
" r3 F2 }$ ]$ |3 l y$ a- L1 ` o! p) w2 s$ `2 j 2:写两个文件
- i' |8 Q7 |! e auto_prepend_file.php 和 auto_append_file.php 保存在c盘,他们将自动依附在每个php文件的头部和尾部.
" {/ G* A r( f( A) ^' ?& S( p7 W2 {( ~; w& X( I1 J 3:在php.ini中找到:
( L5 w# Y# M7 Y Automatically add files before or after any PHP document.
+ z0 [( T9 E( k3 w6 c auto_prepend_file = auto_prepend_file.php;依附在头部
, J" E" ]4 Q" H4 l" |2 `% B auto_append_file = auto_append_file.php;依附在尾部
; Z6 K6 g' {' ?: W3 z ~( R1 n! z& y& b 以后你每个php文件就相当于
. g6 d; w( }! x+ A) b5 V$ O; B PHP代码:
R8 `# z7 l% n+ g4 N$ s9 w7 t3 I1 i& y$ H+ j- j* V / V4 [- U: o- k/ E
Include "auto_prepend_file.php" ;
8 /5 i, x0 y" y1 D: ? @; q4 {9 W; ~( k V# o .......//这里是你的程序
9 v2 V4 V+ z6 M0 g: P9 Q( ]# d4 q [7 N! R9 X Include "auto_append_file.php";
5 i7 `2 [: ]# F) j- a ?>
4 L. u6 @( s! U. u: O( F4 n+ A, [+ G# D* b% P' J' v# V" a; R) p( v7 x: J# U& /* Q& }* i% n 13:如何利用PHP上传文件
6 l* r* N8 w/ A3 Y6 r; y3 _# r; [6 i* @ PHP代码:
0 T: U: e+ T" S7 b2 a* [$ z" m# |7 U1 C" C/ e( P1 l # H3 i( e9 X. l( ~6 G- C3 M& A 上载文件表单 & Q9 f/ E A. Z: `' b : g0 w* A3 ]( L 0 z+ d" E r1 p) P( W $ X3 F! a5 Y8 p- {4 s 7 k8 K7 w0 t9 |$ r9 X* R" K. Z& u5 J) D8 S Z. r! ^; e) /1 d9 E6 j) p $upload_file=$_FILES['upload_file']['tmp_name'];
0 W$ B1 S: }* ~" ` $upload_file_name=$_FILES['upload_file']['name'];
, N6 i* f6 s5 @! ^: [% V# Q0 i9 w$ k; f: L% R; d( ?, x if($upload_file){
" c( [* C. ~ w! o7 r2 _( D $file_size_max = 1000*1000;// 1M限制文件上传最大容量(bytes)
$ w& ~+ v$ ?. L $store_dir = "d:/";// 上传文件的储存位置
# M D. I2 y- w! h( l% M $accept_overwrite = 1;//是否允许覆盖相同文件
4 Q1 D5 X7 a" p( g" P // 检查文件大小
: Y6 Z+ O& F; [! l if ($upload_file_size > $file_size_max) {
/ O' B" {7 w4 k; c/ P! k2 y echo "对不起,你的文件容量大于规定";
, S p# q) J$ t& ~) Y4 R exit;
& i4 J" z( ^- q, m6 o; t- ^ }
) F& |9 H4 B& K: j9 p- c3 @ i8 q; [! F. I) ` // 检查读写文件
8 r4 M) M( h' n8 t$ T( N- |- N& T if (file_exists($store_dir . $upload_file_name) && !$accept_overwrite) {
" O' ]" i0 N4 V' y Echo "存在相同文件名的文件";
% Q2 h' C9 L7 [1 |% t exit;
/ d5 w: /2 e) S9 U/ x" c+ b- X }
4 o2 _5 i9 L. L6 v* E9 D [# j% f; g* _/ c" o) w+ L //复制文件到指定
目录& _) {, L- X- V if (!move_uploaded_file($upload_file,$store_dir.$upload_file_name)) {
/ O) E* d& T1 _; V1 I; ]+ t echo "复制文件失败";
0 f' }1 l$ P, S1 A exit;
0 r j% c V/ d/ r+ y, ?& Z8 t/ {& A }
9 Z `( [4 T+ K+ W# `: u" R; n7 c- V }
# d8 o8 [% t: E' G+ s( A0 H3 V9 g6 o( e Echo "
你上传了文件:";
5 @; x: }# Z- B9 c/ ^ echo $_FILES['upload_file']['name'];
7 g0 s: }3 }# X1 H echo "
";
3 Y" m7 q: ^2 L //客户端机器文件的原名称。 8 L2 p5 a% e: {! l4 D- H4 s
3 R9 ? S$ I+ m9 u( Z- h Echo "文件的 MIME 类型为:";
( ~: J+ q* x8 L x echo $_FILES['upload_file']['type'];
3 L) L* T5 g u //文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。 ( `" F2 F( U5 s: w$ f
echo "
";
: |5 N6 S- i) v5 v' [8 P! H( l9 a2 q
Echo "上传文件大小:";
: `4 G R+ p& ^+ {, f5 p echo $_FILES['upload_file']['size'];5 a7 V8 F; K0 H y( V
//已上传文件的大小,单位为字节。 * V" e4 L1 M) a. L; p, B* G
echo "
";7 o8 S6 q: s- G
. B( T3 ^) m( _$ t: ~8 j Echo "文件上传后被临时储存为:";
* p9 T k3 [6 n& R5 X echo $_FILES['upload_file']['tmp_name'];0 q. t( `' s" @7 }% r
//文件被上传后在服务端储存的临时文件名。
% Q1 ~' U9 s* K, W echo "
";" J. q* s. D1 M
$ a. ?. C4 n$ x: r- q T
5 q! }1 k( P0 {" l0 Z3 Z4 `; B/ D
$Erroe=$_FILES['upload_file']['error'];
$ w! q( }8 D1 X1 K; /% [ switch($Erroe){
( v3 q% c( d/ X5 O/ n1 S( l% W case 0:' R- F5 z1 ]6 K! ?* P
Echo "上传成功"; break;
( w$ E9 r% D- a! l0 @2 q: Q; m. n case 1:
6 M1 x* J' e4 W. o$ l" ? Echo "上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值."; break;
7 B' }) ` m" m case 2:
) _8 e( W+ T3 U4 ` Echo "上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。"; break;
, m; ?( T& P. ~$ ` case 3:
" P y5 L1 g/ k1 k7 /( W( o7 Y3 I! / Echo "文件只有部分被上传";break;0 i2 R. G+ m1 ^: r2 K# b0 n( R
case 4:
4 r. /3 f+ x, x. W Echo "没有文件被上传";break;. q6 ?/ T) f5 U @' Z5 Z0 A! `* J$ z
}
7 h' N& ~/ }8 e: |0 / ?>
0 B9 y- V: o7 p! N
" M' ?* @$ I3 r- Y2 ]8 ^0 @5 _
( { E( J: E# V# a3 G 14:如何配置GD库) j9 L; V: R% |7 ]
: F+ H, l1 W3 ]3 G
下面是我的配置过程
, J- B& P9 [1 Z) D5 E! S 1:用dos命令(也可以手动操作,拷贝dlls文件夹里所有dll文件到system32目录下) copy c:/php/dlls/*.dll c:/windows/system32/ - _5 C/ V& /, J; p0 s, G
2:打开php.ini( d( n) ]# o8 P$ e8 F/ /, M9 e
设置extension_dir = "c:/php/extensions/";
8 B' K2 |, R, Q* i% |' /$ O# a0 /' S, k 3:
% Y* G3 p1 f; _3 F$ M( ^ extension=php_gd2.dll;把extension前面的逗号去掉,如果没有php_gd2.dll,php_gd.dll也一样,保证确实存在这一文件c:/php/extensions/php_gd2.dll1 M& u& M2 K9 `/ B
4:运行下面程序进行测试
% O' p6 E+ R2 q: B8 F0 p
' L3 C6 /7 F- e' O+ C9 e PHP代码:
5 q0 Z4 v6 t. w/ J$ p
. ^7 G$ k5 G' }4 i0 K8 A # ]; W, @- R' y+ m: }( P8 t$ {) J
Ob_end_flush();5 X4 n1 T$ n5 M) F( X% N/ X3 B
//注意,在此之前不能向浏览器输出任何信息,要注意是否设置了 auto_prepend_file.
* g/ T/ j1 v. _9 s" J' | header ("Content-type: image/png");" ?5 F" u% ^' C/ m$ T
$im = @imagecreate (200, 100)# e: X0 e- {# c- @* y, d
or die ("无法创建图像");
* a( }$ I+ Z8 d& J $background_color = imagecolorallocate ($im, 0,0, 0);
" @" d/ _. ?2 u L2 c p! k3 `- h $text_color = imagecolorallocate ($im, 230, 140, 150);# m5 C6 b4 I+ v. s
imagestring ($im, 3, 30, 50, "A Simple Text String", $text_color);( m1 G1 D' s/ c7 ]" /7 X
imagepng ($im);
2 P/ F7 _! C) p' p ?>2 T0 d0 f m5 V; W {8 n9 R
* _# q2 z# L+ J1 G 点击这里查看结果! e; W9 k4 W7 x
! B7 I& C: h, o3 L3 H0 e! b# O' C: ]+ g! W) u( s
15:什么是UBB代码2 G9 |- Y0 U! b G, R
4 a+ K0 ^" n | UBB代码是HTML的一个变种,是Ultimate Bulletin Board (国外一个BBS程序,国内也有不少地方使用这个程序)采用的一种特殊的TAG.! E4 |' G5 ~0 _
即使禁止使用 HTML,你也可以用 UBBCode? 来实现.也许你更希望使用 UBBCode? 而不是 HTML, 即使论坛允许使用 HTML, 因为使用起来代码较少也更安全.* F8 /*
16:我想修改MySQL的用户,密码 首先要声明一点,大部分情况下,修改MySQL是需要有mysql里的root权限的, 所以一般用户无法更改密码,除非请求管理员. 方法一 使用phpmyadmin,这是最简单的了,修改mysql库的user表, 不过别忘了使用PASSWORD函数。 方法二 使用mysqladmin,这是前面声明的一个特例。 mysqladmin -u root -p password mypasswd 输入这个命令后,需要输入root的原密码,然后root的密码将改为mypasswd。 把命令里的root改为你的用户名,你就可以改你自己的密码了。 当然如果你的mysqladmin连接不上mysql server,或者你没有办法执行mysqladmin, 那么这种方法就是无效的。 而且mysqladmin无法把密码清空。 下面的方法都在mysql提示符下使用,且必须有mysql的root权限: 方法三 mysql> INSERT INTO mysql.user (Host,User,Password) VALUES('%','jeffrey',PASSWORD('biscuit')); mysql> FLUSH PRIVILEGES 确切地说这是在增加一个用户,用户名为jeffrey,密码为biscuit。 在《mysql中文参考手册》里有这个例子,所以我也就写出来了。 注意要使用PASSWORD函数,然后还要使用FLUSH PRIVILEGES。 ! {& s4 I9 i9 B# P1 d( e
方法四 5 {. `; i4 ^" o2 [; s/ W
+ w8 g3 H5 [/ A+ ?+ f. b* p 和方法三一样,只是使用了REPLACE语句 , s6 o$ R1 [+ |4 _4 ]) A) c: @
9 L& d0 F$ /4 i7 A
mysql> REPLACE INTO mysql.user (Host,User,Password) : W- L3 n9 l3 M6 r2 W- |4 q: g3 z
% w3 C) q9 [% S( I) b
VALUES('%','jeffrey',PASSWORD('biscuit'));
) q9 H: ?2 g) y. q9 I
# } W# X: J5 T* Z4 t# L mysql> FLUSH PRIVILEGES9 {% }$ N. D6 g& V6 `2 D( K/ V
方法五 |, w: X' Q$ H% Y# l
) E& a& T0 I. r4 ?9 P 使用SET PASSWORD语句,
, W1 T, C/ R& T5 ^, D) K, W& k; v, ?8 a# E3 D1 F' U$ N
mysql> SET PASSWORD FOR jeffrey@"%" = PASSWORD('biscuit'); ; B: L" V3 Y N, M" z6 F) G
* U5 Z" f O: {; A0 Y 你也必须使用PASSWORD()函数, : p# Q# x/ n9 V8 y
L' k0 g0 w' m 但是不需要使用FLUSH PRIVILEGES。
2 [" [, _9 s+ p, B% K6 x, G 方法六 ! N7 r: l* Y: t" J
4 H7 s6 `* _! G3 m* e 使用GRANT ... IDENTIFIED BY语句
# ]9 r, e5 i0 I, q6 K K2 J- Z& /3 D* q/ P
mysql> GRANT USAGE ON *.* TO jeffrey@"%" IDENTIFIED BY 'biscuit'; + N7 H+ C" T3 P3 T9 Z
8 `9 T9 y: m* k
2 K8 [% g* x: T8 L+ S7 Q 这里PASSWORD()函数是不必要的,也不需要使用FLUSH PRIVILEGES。 8 t& g- u! Q# ?5 A' o- b! k
注意: PASSWORD() [不是]以在Unix口令加密的同样方法施行口令加密。 " y2 S$ |$ Y- S3 A6 Z
0 s/ Y Y8 ]; J; e- G }' t' }- /6 e7 ?! t$ {1 y" @! X6 w. K
17:我想知道他是通过哪个网站连接到本页" i# U: K; o& H" S
PHP代码:4 |: I d5 B5 E3 ?: n" w
7 l l1 ~# {# b% O R3 q$ L# K I' w" v$ r0 m
! E+ D6 C. E( [8 F6 @7 U //必须通过超级连接进入才有输出3 U/ W' T$ Q5 ]' D
) o9 ?6 `+ ?' d. u) K Echo $_SERVER['HTTP_REFERER'];( y+ E& X% _9 u, q" F. C9 B
: r& B2 i; M$ |4 J( _, l
?>
% E9 F* a" o1 E* e! t! I! m18:数据放入数据库和取出来显示在页面需要注意什么
* s3 B B9 d- E1 P# z 入库时
* |& f2 g# c/ i* D" P7 X" ~! Q( n; e- n( ], g) _; {
$str=addslashes($str);# m1 W. Q# @+ c- `
, K N) z' K" o) _
$sql="insert into `tab` (`content`) values('$str')";- ]. D/ t& Y- ?4 K* j( H
1 u) s2 /$ x. x
出库时
! j/ n/ H! Y3 s; ^. E# q
8 _0 ` U# F+ w" i3 ? $str=stripslashes($str);
& x6 {9 m: j# s9 |! n& u) M' l* S+ D
显示时
2 P6 y' /5 U) o& Y% u7 O3 |3 V
9 N1 g6 v! |3 /7 i* R3 ? $str=htmlspecialchars(nl2br($str)) ;
- O+ N$ v9 W- Z% l0 O ( q8 p+ c. t, z. [- H
' d' w) i1 f/ N0 M! ? //$content来自数据库# w% v# b8 |/ L2 b8 z1 S2 Q
# G5 _8 |% ~$ E9 m3 P4 ~, @
$content=nl2br(htmlspecialchars($content));- Z" l! P0 L& b7 L$ C7 N% a
; F: /1 w5 P! ]# S
$content=str_replace(" "," ",$content);+ Z% A, E1 a8 `+ ]% J! g+ [
' b! N) [3 H4 a, B $content=str_replace("/n","
/n",$content);
8 C( v* Q( [7 W" T/ R9 V5 q2 h7 A
9 t- J9 {$ g* T' a: ]5 e ?>
$ ]$ E* M) H2 W- X! z5 L3 X# G) f19:如何读取当前地址栏信息% f0 Y6 [$ T1 v6 k5 G# b( A
PHP代码:8 H$ V# N. [" i& W
* N( B7 p- o" J; } : E4 C }8 f9 i: @& ]) ?0 Q" @2 [5 L$ q. B1 g: o8 x1 E' X3 y8 o( E
$s="http://{$_SERVER['HTTP_HOST']}:{$_SERVER["SERVER_PORT"]}{$_SERVER['SCRIPT_NAME']}";
U3 g- b: ]% g8 E9 Y" { * {2 g9 e- E/ o" _- p0 R
$se='';
* M' z! d5 K/ H. ^+ { foreach ($_GET as $key => $value) { ! t6 q3 Q: r8 a+ X- U" A
$se.=$key."=".$value."&";
; N' [/ t, X9 `6 P3 w }
4 i {, m* i& h6 _( }8 [/ q $se=Preg_Replace("/(.*)&$/","$1",$se); # c4 j# t" Y: r: F& O
$se?$se="?".$se:"";$ N: A4 w: O% C F% _5 Q% ?
echo $s."?$se";
8 C9 K4 [+ i$ i5 M9 n" U, X* i ?>
- r2 E& Z7 ]8 C
) E. ^6 t) B1 N20:我点击后退按钮,为什么之前填写的东西不见
7 [0 [" a: D" k; D4 G% K* C 这是因为你使用了session.' u' @% i! v' E& V- i
1 N/ H% s/ P5 E% K# O7 h4 [( |! v
解决办法:! ?& v6 X& z6 G
PHP代码:
) ?7 A, A; t3 y . g3 ?" a6 h: K! @* E+ i S& [ .....................?>) D0 h& I$ M, q
21:怎么在图片里显示IP地址& Q6 g5 F2 X$ Q+ W) X4 L
PHP代码:
# @7 V" ?/ r9 B/ N: g& N( ^9 A8 g Header("Content-type: image/png");
; O# ?: q, x4 y# f7 x) @ $img = ImageCreate(180,50);
. /! ?3 e2 s3 k' V; F3 b5 z7 i $ip = $_SERVER['REMOTE_ADDR'];
9 q z, N0 A( q- f5 |7 X ImageColorTransparent($img,$bgcolor);
7 Y3 r2 m H! C! W v $bgColor = ImageColorAllocate($img, 0x2c,0x6D,0xAF); // 背景颜色1 Q* u3 /) c2 c( U' s, I0 @! b {
$shadow = ImageColorAllocate($img, 250,0,0); // 阴影颜色
8 `( c0 y' i6 Y- C! { $textColor = ImageColorAllocate($img, oxff,oxff,oxff); // 字体颜色
% x V% q% o6 i' U4 j* l1 D3 T ImageTTFText($img,10,0,78,30,$shadow,"d:/windows/fonts/Tahoma.ttf",$ip); 9 W, q1 E- }' ~8 l
//显示背景 " q4 ?9 d: |" [
ImageTTFText($img,10,0,25,28,$textColor,"d:/windows/fonts/Tahoma.ttf","your ip is".$ip);8 ?3 `7 @% X: M% O
// 显示IP ) f1 ?" e6 ? r9 a
ImagePng($img);
4 w: M* ~, E0 R imagecreatefrompng($img);
& F! ~+ t9 D$ t2 l$ l5 A ImageDestroy($img); + W7 F6 q4 V1 j$ p& H+ R8 Y9 T0 V
?>' a: t8 z$ z8 y- x+ G
22:如何取得用户的真实IP
! O. `: K) L' `4 M8 a9 ?4 B, L4 b$ {% o4 |9 b. ]
PHP代码:
" @: C$ D4 e* @ function iptype1 () {
9 ]+ v3 M. d" G- s if (getenv("HTTP_CLIENT_IP"))6 J0 S) j; d9 /- [7 K0 d4 v: J6 e
{
! o& f' ^8 q% u* C' S6 M, B8 V/ a return getenv("HTTP_CLIENT_IP"); 5 g: O, _( k& Q- H
}
- h# `9 v+ F5 c1 L' y3 w/ n, m% x else " d: J5 W* O H5 E+ h# ^4 G( Z( x
{ 7 ?+ G, M9 g3 a
return "none"; & b5 w/ U! Q' H8 c. p
} * j k( Q" v4 e$ ] k8 y
}
0 }# V3 ] d# V! h, j function iptype2 () {
9 y p1 }) x- O, [7 [ if (getenv("HTTP_X_FORWARDED_FOR")) 2 K, r* J# ^; O$ _) U" i) i2 a+ U8 M
{ 5 C% t0 i% g% I6 Q, Z
return ' x1 h6 r' x1 j0 h5 c- ?$ c- f! Z
getenv("HTTP_X_FORWARDED_FOR"); % l" U1 n7 K# /. K# d5 f
}
* l* p2 i5 p4 J0 d+ `% g+ Z' l else { . N6 C& R7 n2 /) `4 d: I
return "none"; ' |; |8 ]; g! }4 y2 G! ]( ~5 O
} $ O( a }" ~- /: T/ N
} 3 p; a" v/ q& f9 D/ }( /6 C% b
function iptype3 () { * F( c: P* o/ g0 J- /
if (getenv("REMOTE_ADDR")) 9 |0 O' r, x" g
{
3 o% x4 u+ N( [6 | return getenv("REMOTE_ADDR");
: |, q/ J5 ~& C ~4 v. C f/ K }
6 Z2 S; b5 m3 s* s0 f n: w; z else {
5 _" K" [4 g# P3 I return "none";" ~. }* a$ d4 D1 ~8 R, a
}# V+ W" J2 j; {# I% |
} # l$ l5 L6 k# s1 Z9 q
function ip() { % f% q- p; G: P
$ip1 = iptype1();$ b* s9 q9 O1 m; ^0 Z& N
$ip2 = iptype2(); 6 z9 t5 l7 q; _; t$ D
$ip3 = iptype3(); * f& ]( b# R" E2 w* s# [
if (isset($ip1) && $ip1 != "none" && $ip1 != "unknown") ( P4 Y0 g* r: e9 {9 s9 Y: b2 u
{ : Z& M, n; }( Q8 a
return $ip1;
, q& s9 s' b' |4 h' N2 S }
$ ]2 V, Z" C4 L7 X" f3 x+ I8 L elseif (isset($ip2) && $ip2 != "none" && $ip2 != "unknown")
1 Z: J2 N) q5 L$ K {
* F0 H* |$ m, P. o i8 Q! r return $ip2; 9 A! q$ Q+ l# |9 I9 ^
} $ F) E$ X! @# k1 Q( }5 s" R
elseif (isset($ip3) && $ip3 != "none" && $ip3 != "unknown")# e+ P* q% g6 s0 e' u5 Z* o
{
; D- ?9 }' b# ] return $ip3; # p5 k# G# [0 |' e% ]
}
( X* R* l L7 H: O1 G; X else 4 ?( a2 V$ J+ e4 I
{ return "none"; } ; `* Z( v2 F" F2 {4 J
}2 R/ u% b; g+ y( R: I3 T8 U8 R
Echo ip();
- {* @: s- a0 U: X D ?>
, l8 V4 V+ G# _# U/ J, N8 Y9 r W7 {# f) j& v" _* z
+ C9 `$ C, w9 s @" ?. s& I23:如何从数据库读取三天内的所有记录
7 V c+ h) {7 A$ U 首先表格里要有一个DATETIME字段记录时间,
3 H" A4 |! o, _* t$ G2 c
' U5 x2 l4 W; G' y( g$ z 格式为'2003-7-15 16:50:00'
$ o2 p% W6 C/ t" p8 R SELECT * FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) <= 3;
. V9 {' c+ Y l# p+ @3 s
* r8 j B0 r& J6 v
4 _/ n; N$ E! ?% D24:如何远程链接Mysql数据库. ?% v: R% U, M" [
/ W* _5 o: l5 ]9 G/ { 在增加用户的mysql表里有一个host字段,修改为"%",或者指定允许连接的ip地址,这样,你就可以远程调用了。
9 y6 [4 M6 ^+ |( d( E) Q: / $link=mysql_connect("192.168.1.80:3306","root","");
" j" d" x9 {' c8 Z5 G9 l5 m( N1 ]* `- w7 t3 l: X
' v9 a! h5 I, e+ ?1 Z" P# J, q25:正则到底怎么用' H) F, T" D6 o
点击这里
4 B u1 ~2 /, A7 J+ L6 ~正则表达式中的特殊字符
' p4 ]( G2 _+ b2 d' H7 n; a, w6 T1 p$ k
/ {2 y' K7 R. p7 K26:用Apache后,主页出现乱码 ( G b$ _/ k% Q# l
4 z( T( f) t5 e; c 方法一: 7 o$ j* ?: Z7 m& ~: f- Y; h
5 Q$ V* ^; Q& o9 V# Z2 d
AddDefaultCharset ISO-8859-1 改为 AddDefaultCharset off
+ {( l5 N: t: j 方法二:
% M/ G$ w' H2 n ^) [5 f; ^+ z* g1 {( [4 z# w4 D- ?
AddDefaultCharset GB23129 ]* N) j' {+ Y7 v0 d
* @% t) E1 a( y. [8 B
* J& D2 V. k, u, I5 j
27:为什么单引号,双引号在接受页面变成(/'/")
. q5 M B+ X6 T: q 解决方法:
" |& w2 l; D3 I% o" m7 U& j8 I2 l) b6 P) U3 u8 r
方法一:在php.ini中设置:magic_quotes_gpc = Off
7 e+ B! `0 R B) f' S
" x" s: T/ N* M6 v9 B4 ^ 方法二: $str=stripcslashes($str)/ Q7 ?! C% ^4 Y. z; N
. N, H8 K/ c; |& S2 b
2 r( D4 w3 d& r5 j# b4 q5 h28:怎么让程序一直运行下去,而不是超过30秒就停止
3 ?: s1 q* B, O2 ` Z& j2 M* e set_time_limit(60)//最长运行时间一分钟
" G. C3 {" I" i! V" e. I
2 /' v6 I/ /' @$ ^5 s1 b set_time_limit(0)//运行到程序自己结束,或手动停止9 O% @" ]/ d, ~: |
) u& _- e @. x5 j4 n( /2 ?* w
- [- }6 }7 i; a! {! C
29:计算当前在线人数5 k! f4 _0 f7 r* Q7 q" m: F7 Y
例子一:用文本实现
5 x, }! H$ S, R+ a; G9 C) N PHP代码:
' i0 e, p$ r2 j8 p
+ A' k9 T% j: k% F5 D! c " o' h6 S7 v- u! m7 N5 d
1 m& L3 D& /" U, I% Q! m //首先你要有读写文件的权限
% a D' A. S, s$ ^, L, g
4 L o' l3 t. I0 /, k //本程序可以直接运行,第一次报错,以后就可以8 q0 x" ? c5 `% N( }% r
7 /) B$ n$ u0 s+ b: K $online_log = "count.dat"; //保存人数的文件,
; h/ p( a5 Y* X1 L- d# i: T0 E- j+ o1 r/ v" K
$timeout = 30;//30秒内没动作者,认为掉线 * k# _- @: Q `/ X
) r/ n% _- b+ q6 @" `4 E $entries = file($online_log); 8 f) C- h5 s, n# P8 }: ~
$temp = array();
: ^' G* T F: r$ G$ B" |* n2 y! J, m; N5 I
for ($i=0;$i) b# d! N6 k! n7 x3 L; I4 g6 d9 t c; u$ |/ ]" X: J8 M0 [" `
$entry = explode(",",trim($entries[$i]));
- ^. m& E0 [: ^0 } {! Y' T; _' |, L
if (($entry[0] != getenv('REMOTE_ADDR')) && ($entry[1] > time())) : N" l$ y4 |- a; h
{ ' v% N+ F, @# e9 a
# O% A8 F/ U. q( v/ b
array_push($temp,$entry[0].",".$entry[1]."/n"); //取出其他浏览者的信息,并去掉超时者,保存进$temp
8 y( /; l( e, I$ T& R, L) X1 z- h6 i) W R
}
* q* p) D' /( B& D1 ?$ v- D' W
( p3 o% j+ j) X( v' n* m }
; V& P3 G! v/ V5 _+ X array_push($temp,getenv('REMOTE_ADDR').",".(time() + ($timeout))."/n");
& L) k3 r8 a3 g( ]! ~, S0 T Q//更新浏览者的时间
. w0 _* z5 V$ L% B9 D/ U% i5 H+ l& E6 ?. {3 |! O) Z% W& D" ]
$users_online = count($temp); //计算在线人数2 F2 g( f9 L/ J1 K. W6 n8 g
$entries = implode("",$temp); % j/ B4 B# k7 D8 {0 F, x
+ A. O s, E# W( f( z* `6 C0 @* ]: m //写入文件4 z) ^& c* O1 }% [# W" q$ {
$ B, K$ o% @' J3 Q) W $fp = fopen($online_log,"w"); 0 ~: i1 F% G5 n! m x m- p/ H
/ L1 i& i$ ~- p/ O6 U8 |
flock($fp,LOCK_EX); //flock() 不能在NFS以及其他的一些网络文件系统中正常工作
2 Y& G3 }, [, N8 h. z& U. L# q" z; X- J9 I
fputs($fp,$entries); v" Z1 M+ T) u2 e/ f$ Z E
4 `- j& y. l4 m/ K1 T
flock($fp,LOCK_UN);
) l4 t+ q. y- i/ V8 p: w: v
3 X7 X. ^! M% k1 Z fclose($fp); 7 [; v5 ?0 p% C9 F& z5 `8 l6 A- N. W
echo "当前有".$users_online."人在线"; % o" x+ t2 x' {: o6 V: O
?> 9 k/ A; ]; E* q$ L# v& A
D% V. W% S# B( K1 L1 o" e/ [8 B' C: X, u$ `9 [
30:什么是模板,怎么用
' M+ i7 J7 u; G+ P 我用的是phplib模板$ o% J: S# F4 e& G. j
0 Y7 U/ w% g) T( a" I# Q6 G
下面是其中几个函数的使用
P! i0 r6 g6 { $T->Set_File("随便定义","模板文件.tpl"); % z) k, @0 }2 m& Y5 z9 F) j" m* /
$T->Set_Block("在set_file中定义的","","随便定义");
$ q6 _0 J- z9 W3 J
1 k1 o7 z: z( I. O $T->Parse("在Set_Block中定义的","",true);
* N3 m- a9 n7 P5 M/ i! Q/ H; O2 H3 {9 }
$T->Parse("随便输出结果","在Set_File中定义的");
c2 m" r+ b# z# x8 @; /- A$ ` 设置循环格式为:7 D; l+ o u. V) D$ p
- u9 k; s9 G$ D 如何将模板生成静态网页/ N! ]+ F6 q# D4 Z& x
9 D5 E+ `- I4 ~+ F- z5 D8 X- T* A4 s0 Q! z
PHP代码:
+ L1 E) K# s) n4 @/ i
( G6 n' s# G# I# J0 S + Q; ~! E$ D4 e/ r, J' x2 k7 A" B0 Y2 ^* y4 e/ m3 Q
//这里使用phplib模板
2 z/ ?! Y% [9 z0 J8 e
' P3 Q. ?& n3 a* A2 q ............
: [2 _' n+ D( T: ]7 V6 a, B" U8 G1 T5 @/ j% |1 v* A, N' m& n
............7 L: Y7 x: N4 }3 {3 {
/ z7 I9 t E5 `9 z& G- y' i
$tpl->parse("output","html");
) W* }- I9 P4 l7 o- ~$ g7 I! K) B* N$ T: }1 T: M( q
$output = $tpl->get("output");// $output 为整个网页内容9 Q" R( J8 N+ C$ @# M! {6 _
4 V5 W2 X" c) i3 `& c* ^
% J4 /9 L" @/ |# g# Z function wfile($file,$content,$mode='w') {
; d* A; U4 o- H# Z' _
/ i0 b$ G7 Y2 U4 [" J* t- [6 e! Y $oldmask = umask(0); d* r0 _6 f9 Q0 K
% [+ ^ D& _, i" J/ X9 n. y7 A
$fp = fopen($file, $mode);* C7 h, N+ K+ |! m7 R$ I
: E r2 T1 d1 T( ~ if (!$fp) return false;
. S5 k# a# p( p
! K) C: l( z( x' {5 [ fwrite($fp,$content);; a8 ]! ` H& `6 l8 Q6 g: U" |
7 a0 Q8 T9 A( @9 d- B5 k w+ p
fclose($fp);. g7 K/ H, y; h. J
: }5 T8 u! A* p0 U9 f/ n5 Q
umask($oldmask);4 x" P1 f) a* d/ p% [
" /( v" O2 A4 Q4 i* r6 / return true;
3 d7 |# r3 ]' H) z" m& S( Y
9 T) m( x: G7 R, r. c }+ e J. Z) }5 ~$ a- W
1 _# }3 k- B3 /9 h: s6 w
// 写到文件里
?& h+ W6 o! ?, w9 _; `9 J4 Q3 e; _" P1 H# Q1 |3 u
Wfile($FILE,$output);" u' s- o$ `, i# l$ V$ [, [* ?
8 M+ C( S, T$ I8 A2 h9 O/ U header("location:$FILE");//重定向到生成的网页9 p2 e. y& J& a6 X q2 N
: [* t) v; W" X2 f4 }1 [! Z; I% O }
) X9 V3 P1 _* z% c% o+ _1 `$ @5 S- b+ N+ h) z6 [8 x
?>
. ^0 @: f3 B+ w+ } phplib下载地址 smarty下载地址
: d+ M0 E4 a% V; D( B& w, i1 G: G6 g, m" @
31:怎么用php解释字符
- J- `4 L3 V9 j+ b+ ` 比如:输入2+2*(1+2),自动输出8 可以用eval函数
9 }# E! L# h2 h0 i5 X, v
U: v2 /$ O. z4 g/ G PHP代码:
, l+ @0 ^3 @$ ?9 e9 ^. A B6 I. v0 G3 x# L. e2 @
3 U/ `# c) S7 V I5 g0 y+ C3 M/ B, j5 R% /& O$ K2 K/ H$ G. y
# w' h+ L+ @( I# P5 u
4 N. p& V8 D; b- h0 m
$str=$_POST['str'];" k7 w% k7 C; B6 D$ S
6 c- h% A6 r# Z7 I% K9 K2 L eval("/$o=$str;");/ L3 y, r. w; u7 p% d. i; o2 Y8 E+ J' [
& G) }0 x6 N% K- } Echo "$o";
4 Q- W, |# ^1 T* c5 a& `+ O+ ^; N
, ?$ i( V! w! d* `, r' p* P: E( s ?>$ p; s) q, a4 B4 A2 p# W' |
( E" S: X0 p3 z! r- {5 M 到此,php的问题解答就为大家介绍完毕,希望能对各位有所帮助。