过期域名预定抢注

 找回密碼
 免费注册

令PHP初學者們最頭疼的幾個問題及解決辦法 --轉

[複製鏈接]
發表於 2009-1-20 11:42:17 | 顯示全部樓層 |閱讀模式
【1】頁面之間無法傳遞變量 get,post,session在最新的php版本中自動全局變量是關閉的,所以要從上一頁面取得提交過來得變量要使用$_GET['foo'],$ _POST['foo'],$_SESSION['foo']來得到。當然也可以修改自動全局變量為開(php.ini改為 register_globals = On);考慮到兼容性,還是強迫自己熟悉新的寫法比較好。% @( j1 x0 h+ K
- @0 y9 _% n; ^8 Z3 y3 K; m# l, c
【2】Win32下apache2 用get方法傳遞中文參數會出錯:/ ]  j& D9 C" F

: J/ S3 Z$ O& S# z4 Ytest.php?a=你好&b=你也好
6 L9 d9 ?$ y% C$ b8 F$ H2 `$ W  F3 [, h/ V1 q
傳遞參數是會導致一個內部錯誤9 [1 n% F6 U8 F" \5 F- s
+ o( U0 f/ m1 m8 U" `" [
解決辦法:"test.php?a=".urlencode(你好)."&b=".urlencode(你也好)3 M4 i1 B9 g! W" U1 `2 }

6 e$ X$ H& C( m4 `/ a2 Q8 `.............% Y" \6 j* `' ^7 j: p9 j
! o' g5 s# s3 y! x" S( D. x. \
【3】win32下的session不能正常工作
- k$ T" P. Z1 K/ Q( u4 V
4 s& g8 O% b5 t2 }4 N" h* \php.ini默認的session.save_path = /tmp
3 ~# j& D% D4 Y6 K4 u3 g& V! W6 p9 ~
這顯然是linux下的配置,win32下php無法讀寫session文件導致session無法使用,把它改成一個絕對路徑就可以了,例如session.save_path = c:windows emp8 f1 `6 O: l* m& [% X! t, J: K9 E
7 A1 {+ c) T# C' `$ M* q8 b$ t
【4】顯示錯誤信息# h) w# N& I1 @1 O0 N
9 F* }& ~; d2 L4 d& l" N
當php.ini的display_errors = On並且error_reporting = E_ALL時,將顯示所有的錯誤和提示,調試的時候最好打開以便糾錯,如果你用以前php寫法錯誤信息多半是關於未定義變量的。變量在賦值以前調用會有提示,解決辦法是探測或者屏蔽。8 }9 `* _; H5 X/ K% \. m
2 e" a2 z7 g0 \+ z! ?2 N$ l8 q
例如顯示$foo,可以if(isset($foo)) echo $foo 或者echo @$foo1 z: i/ g  @) c
+ Z5 m( M4 k( G8 ?
【5】Win32下mail()不能發送電子郵件8 f) X8 c- w1 Z2 a6 i. w2 j/ h

' `/ g! J, g: }: e8 z在linux下配置好的sendmail可以發送,在win32下需要調用smtp服務器來發送電子郵件,修改php.ini的SMTP = ip //ip是不帶驗證功能的smtp服務器(網上很難找到)
, f% I& C8 u8 `/ Q3 ]& C8 k4 R- R5 y1 J/ Q, s
php發送郵件的最好解決方法是用socket直接發送到對方email服務器而不用轉發服務器。- S; ~% S8 }* K/ D
5 H  |7 p3 F; X4 [
【6】初裝的mysql如果沒有設置密碼,應該使用update mysql.user set password="yourpassword" where user="root" 修改密碼+ w4 B8 E! H/ p' M% X5 Q0 c' D
" W( c- g% L( ]
【7】header already sent9 b; ?, B9 ]# L7 L
% o. U+ ~( Z3 w- p
這個錯誤通常會在你使用HEADER的時候出現,他可能是幾種原因:1,你在使用HEADER前PRING或者ECHO了2.你當前文件前面有空行3.你可能INCLUDE了一個文件,該文件尾部有空行或者輸出也會出現這種錯誤。!. ?& E+ H3 n7 O! x  O" r

' _$ ?4 g9 \3 [/ a【8】更改php.ini後沒有變化; u* I3 ^" [1 l0 ?% s
- X/ R# J8 I  \- o# t4 N
重新啟動web server,比如IIS,Apache等等,然後才會應用最新的設置。
. x% i9 ]" x0 Q1 M8 O2 E+ w, B4 [3 D* |* P7 t; p4 P% {4 e
【9】php在2003上面安裝(ISAPI的安裝方法懇請高手指教)
6 J3 C8 S' \9 y( P4 U: x  v/ n; n  U$ G' Y9 l
PHP4的php4isapi.dll好像和2003有些衝突,只能用CGI模式安裝2 ]( C3 j. x  w' S

# E4 }2 M: c' n, R步驟一,先www.php.net 下在一個安裝程序,我是裝的是:php-4.2.3-installer.exe,你也可以去找最新的版本,在安裝php-4.2.3- installer.exe之前保證你的IIS6.0啟動了,並能夠訪問。安裝好以後,在默認網站-->應用程序配置。
3 _! K2 M1 f8 c- g1 v/ U7 d' [  }9 `( }1 R$ w, u+ Y/ m7 h3 b
步驟二:點擊 web服務擴展 -->新建web服務擴展。
) R* C- B/ G5 Y3 {9 _2 [
9 c3 x9 `# D$ t8 C步驟三: 擴展名-->php,然後添加
: i! `: X7 Z0 b
% A* p( i' M( A; `步驟四:找到php.exe的路徑添加上去。
0 ?0 v1 k4 u3 w1 m# e) {' y* R% T
9 i$ _" {  I9 g步驟五: 確定就可以了!: b. `" E' \  e3 I

6 J8 @9 {, r6 a" b; u6 j: m步驟六: 選擇php的服務擴展,然後點擊允許。
0 i8 o3 d2 p$ q8 s
9 ?7 h. s/ I0 ]* M8 A  r# x( A【10】有時候sql語句不起作用,對數據庫操作失敗,最簡便的調試方法,echo那句sql,看看變量的值能得到不。
; D. _/ M% i2 K, G6 m4 Q. E$ v, Y9 @+ g1 m1 |
【11】include和require的區別
/ q* z1 t1 x! Y/ W  r+ ^
8 k8 d2 P* Z" h% S5 y" \/ _2 K兩者沒有太大的區別,如果要包含的文件不存在,include提示notice,然後繼續執行下面的語句,require提示致命錯誤並且退出。% K( v! n% Z$ K) k/ u9 A  \- z
, s0 \+ N1 V0 x& Y- Q
據我測試,win32平台下它們都是先包含後執行,所以被包含文件裡最好不要再有include或require語句,這樣會造成目錄混亂。或許*nux下情況不同,暫時還沒測試。
! I+ B! k9 R* Q: T( q3 h  V/ Q6 H  Z7 T: p6 ~" L
如果一個文件不想被包含多次可以使用include_once或require_once## 讀取,寫入文檔數據。
( b& V3 J$ X  ]2 }
! ^( r! M2 w  a; K  R* n" w0 T& LPHP 代碼:
3 }% C+ E' g2 N' `( Kfunction r($file_name) {
& ]1 f/ R) Q# ^% {. {- @1 X  $filenum=@fopen($file_name,"r");1 k5 m( u, \  m4 K7 D( x0 N5 n" e1 V
  @flock($filenum,LOCK_SH);
- o: u7 O+ [3 i8 S  $file_data=@fread($filenum,filesize($file_name));' k# D, j; u) O% c4 x5 n
  @fclose($filenum);
6 l7 g( ^  A, e  q9 O- Z4 S& |  return $file_data;
) N7 ^1 q# }0 W+ ?* I7 a}
8 b) j9 K- E1 q7 bfunction w($file_name,$data,$method="w"){1 {- B8 t( K( [9 \* Z* R6 u
  $filenum=@fopen($file_name,$method);+ }4 |3 l1 D% v/ ^3 Q
  flock($filenum,LOCK_EX);
; U6 P; Z. Z9 e1 `' R" }8 F% e  $file_data=fwrite($filenum,$data);: b1 c" Q' l1 ?- f; g- _
  fclose($filenum);% J2 v" ]" k5 b! @8 o& y9 J/ r
  return $file_data;
5 ]# t8 v( T) C$ @}  
4 g7 S+ u& [5 O, @7 S2 R! e: Z# A+ ?* H/ N' y
【12】isset()和empty()的區別  _! i& r- A9 v& q
# k& R4 o) i+ b& i% e9 I
兩者都是測試變量用的,但是isset()是測試變量是否被賦值,而empty()是測試一個已經被賦值的變量是否為空。
  j9 |% a* o' q. t$ `$ n& p3 y
" j" j5 O: V6 @如果一個變量沒被賦值就引用在php裡是被允許的,但會有notice提示,如果一個變量被賦空值,$foo=""或者$foo=0或者 $foo=false,那麼empty($foo)返回真,isset($foo)也返回真,就是說賦空值不會註銷一個變量。
+ {# M# W1 u9 U7 U; ]' {: `0 @, _
) I/ v. i  q7 X: [9 B要註銷一個變量,可以用 unset($foo)或者$foo=NULL5 N9 m6 ?# N& i: X$ E) u- a

6 o( H; O9 j' Z, n8 f  }+ n【13】mysql查詢語句包含有關鍵字
+ |$ v8 p" |7 |/ H% H! F, G' e; y8 s: T8 N' E# U; }2 q
php查詢mysql的時候,有時候mysql表名或者列名會有關鍵字,這時候查詢會有錯誤。例如表名是order,查詢時候會出錯,簡單的辦法是sql語句裡表名或者列名加上`[tab鍵上面]來加以區別,例如select * from `order`
, G( M" u( d% v1 d
* t+ X! T8 z, f& S  T) ^【14】通過HTTP協議一次上傳多個文件的方法
) H7 i/ s7 h+ h& R: y7 M. X( T) R  k. _
有兩個思路,是同一個方法的兩種實現。具體程序還需自己去設計。
7 f3 S# h' S9 U/ O0 E& g, s4 v, O2 M+ o5 O9 V* d; C
1、在form中設置多個文件輸入框,用數組命名他們的名字,如下:  d- M) M! _* W
4 K  w0 @; a: D% t! H
PHP 代碼:
$ v/ ?! f0 K/ v' t# G<form action="" method=post>5 R: L* h) a8 c
<input type=file name=usefile[]>0 s' C. b0 y  [3 J) b: K
<input type=file name=usefile[]>3 e$ ~" _8 u7 _5 R
<input type=file name=usefile[]>
; d3 z7 V7 Q7 {3 q</form>  % Y6 [7 {. K2 {

6 T7 I4 L4 f+ \3 |, I- h% O2 @這樣,在服務器端做以下測試:9 h% e$ m7 G' ?
5 L* v# D# h6 i1 K0 K! f
PHP 代碼:0 O% r& z& L% u3 d- b" k% d2 a
echo "<pre>";
4 p/ J5 @0 q7 P4 G' y: Uprint_r($_FILES);
. w. c7 T- U! X5 a6 @1 B( Necho "</pre>";  8 R- x; }1 ]$ G
* K4 _9 Z! b* w4 m8 Y6 |
2、在form中設置多個文件輸入框,但名字不同,如下:
% L" O6 W2 [2 Q1 x3 O/ R+ r# b8 j5 a6 L5 J5 L3 y
PHP 代碼:
, M$ v5 z# [8 P, l: T3 ~<form action="" method=post>
' W9 B& W# l8 U; T- x8 z) A<input type=file name=usefile_a>
7 y5 W* F4 h# T! m- u& G<input type=file name=usefile_b>
% A9 t" _/ M" v9 M6 S& O  V. Q<input type=file name=usefile_c>
# E! e: J- z0 a* O' C* \</form>  9 \4 |' h: @) c; S

- z& R# ^- o7 P! Z: _9 l' v在服務器端做同樣測試:
0 G% T, K* i& o5 p; r, I% ~: U4 z7 R
PHP 代碼:2 t7 c: U, k4 J
echo "<pre>";
0 r0 T' f8 C% w" T- n" r5 A* f/ ?1 p3 Dprint_r($_FILES);+ P* }# t# I$ |" R
echo "</pre>";

評分

參與人數 1 +10 收起 理由
回忆月光 + 10

查看全部評分

您需要登錄後才可以回帖 登錄 | 免费注册

本版積分規則

點基跨境 數位編輯創業論壇

GMT+8, 2025-2-20 15:11

By DZ X3.5

小黑屋

快速回復 返回頂部 返回列表