Php--问题汇总解答 总会

 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
  <?PHP
. 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 "<pre>";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 "</pre>";/ 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 F

5 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' d
0 ?  }0 ~+ I" f0 o0 i$ Z5 T
  PHP代码:* q% d' k" f4 y# {
+ k3 X! [+ h, m: d$ E" }
  <?php
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 e

2 A  m  W2 s! q- W4 _& x  <?PHP% 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  l
PHP代码:) S0 G, B5 s/ U* Q) _9 _
+ B1 _$ T& z0 d- e8 d1 v# D1 Z. N
  <?php
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 S
7 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 E

6 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行 <?PHP Ob_Start(); ?>, 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 _! k
1 V& o: ]" l! S8 H- w
- j$ /1 K; K1 f) N' j  4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失5 r- h1 l7 V" ?. y

6 /- 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
  <?php2 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 H

6 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  <?PHP
  T( K, _5 |6 ?3 w! r7 b  Echo "<pre>";4 e, ]7 [) A% ?7 B
  Echo   $_GET["Name"];: p' J/ L! @  c+ p5 F" r/ M
  Echo "</pre>";# v) i# r1 U! K4 U
  ?>
% R. l& E& P$ D# j' H
9 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# m
1 d+ E0 ^* D+ }1 R8 E$ r
  <?php' 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 U
9 c5 U; ]. n- g  W5 V
  <?PHP
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( k

4 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" t

9 [, 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: r
5 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  <?PHP% T+ Y9 P3 o  H
  $str="<h1>;PHP</h1>";* {) t& S9 S$ s. I+ /
  Echo "被解释过的: ".$str."<br>经过处理的:";
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: e

2 R) x/ /- P, h  E# {9 Z  PHP代码:) n7 a& C$ V( ~7 B
2 t2 Q& E6 A) v& v3 |! /6 @& ^
  <?PHP
( 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  <?php
' 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   "<pre>"; - 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   "</pre>";
* _2 u7 l! C. B$ n/ h5 b# P  ?>  + p+ G, e; R$ N2 `, a
6 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  <?PHP; 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$ a
2 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" Q
5 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- L

1 `  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$ s
9 w7 t3 I1 i& y$ H+ j- j* V  <?php / 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/ A
3 Y6 r; y3 _# r; [6 i* @  PHP代码:0 T: U: e+ T" S7 b2 a* [$ z

" m# |7 U1 C" C/ e( P1 l  <html><head># H3 i( e9 X. l( ~6 G- C3 M& A
  <title>上载文件表单</title></head> & Q9 f/ E  A. Z: `' b
  <body>
: g0 w* A3 ]( L  <form enctype="multipart/form-data" action="" method="post"> , K: Y: T4 ]4 Q8 I9 R
  请选择文件: <br>
; v$ c9 U1 A( m9 B  <input name="upload_file" type="file"><br>) n2 E( s" z7 ~+ R
  <input type="submit" value="上传文件">
" w8 `- X. A6 k' X  </form>
0 z+ d" E  r1 p) P( W  </body>$ X3 F! a5 Y8 p- {4 s
  </html> 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( A
0 H3 V9 g6 o( e  Echo   "<p>你上传了文件:";
5 @; x: }# Z- B9 c/ ^  echo  $_FILES['upload_file']['name'];
7 g0 s: }3 }# X1 H  echo "<br>";
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 "<br>";
: |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 "<br>";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 "<br>";" 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  <?php# ]; 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  <?php
  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  <?php( 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","<br>/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; }  <?php
: 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  <?php session_cache_limiter('private, must-revalidate');session_start();
. 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  <?php
" 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<count($entries);$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
  <!--(多于一个空格) BEGIN $handle(多于一个空格)-->
- 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  <?php
+ 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 @
  <form method=post action="">
: o, V* t0 C6 s0 n8 _- W: n* Q/ }2 D- [" [0 m
  <input type="text" name="str"><input type="submit">& n! l( O# G% X# h

# D; {$ v% /  [4 |  </form>
3 U/ `# c) S7 V  I5 g0 y+ C3 M/ B, j5 R% /& O$ K2 K/ H$ G. y
  <?php# 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的问题解答就为大家介绍完毕,希望能对各位有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值