过期域名预定抢注

 找回密碼
 免费注册

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

[複製鏈接]
發表於 2009-1-20 11:42:17 | 顯示全部樓層 |閱讀模式
【1】頁面之間無法傳遞變量 get,post,session在最新的php版本中自動全局變量是關閉的,所以要從上一頁面取得提交過來得變量要使用$_GET['foo'],$ _POST['foo'],$_SESSION['foo']來得到。當然也可以修改自動全局變量為開(php.ini改為 register_globals = On);考慮到兼容性,還是強迫自己熟悉新的寫法比較好。- S8 B' T. [4 O( |, }+ _$ X4 N

2 y) T' k( D& [* ?% V0 `. n【2】Win32下apache2 用get方法傳遞中文參數會出錯:
8 c  n* M; q% q( c7 J& k; l8 k
) h$ [" @( y0 K- \0 {  T, R4 m/ atest.php?a=你好&b=你也好
) i; D8 W( y3 `! Z3 z) H
: s* D6 e; L' @" ]) |傳遞參數是會導致一個內部錯誤
: |+ U+ J$ C' p2 v2 b5 I$ q2 d. b& ^
解決辦法:"test.php?a=".urlencode(你好)."&b=".urlencode(你也好)
7 N7 [2 H0 T0 y, T- V
6 s# E& a; U; I' Z- I.............  ]3 X# b: w. C9 X1 _

; p. u: E4 {$ [5 D! E1 {1 w8 M【3】win32下的session不能正常工作0 j" f& O* Y. I$ `3 @5 ^. h

" e. O3 |; ]# Lphp.ini默認的session.save_path = /tmp& ?' }3 w% P$ j
$ B# F7 |! k# c, Q( R' B4 J7 N
這顯然是linux下的配置,win32下php無法讀寫session文件導致session無法使用,把它改成一個絕對路徑就可以了,例如session.save_path = c:windows emp
1 [/ B  r4 M- Z$ z1 _* O) h- Z# s) O2 i# _: _7 ~6 w- m
【4】顯示錯誤信息$ s% _# _; {: i, _  d4 K* J

. L+ ]: f  a$ E" R  S當php.ini的display_errors = On並且error_reporting = E_ALL時,將顯示所有的錯誤和提示,調試的時候最好打開以便糾錯,如果你用以前php寫法錯誤信息多半是關於未定義變量的。變量在賦值以前調用會有提示,解決辦法是探測或者屏蔽。
8 Y2 e6 {7 y1 f3 {, W& A$ _* b; r0 u1 \7 s
例如顯示$foo,可以if(isset($foo)) echo $foo 或者echo @$foo
2 g; n9 w8 f' _: ]1 e: @
1 N! b6 r9 N) E7 Q( b5 d【5】Win32下mail()不能發送電子郵件
! Q: X" ~3 H8 z/ q5 ]# O( Q3 W8 R3 ^/ Q, b) }$ y( P- ?; c, m
在linux下配置好的sendmail可以發送,在win32下需要調用smtp服務器來發送電子郵件,修改php.ini的SMTP = ip //ip是不帶驗證功能的smtp服務器(網上很難找到)
+ |& O( D) K" y! q' s  A. Y  D, y/ p% x6 L! T
php發送郵件的最好解決方法是用socket直接發送到對方email服務器而不用轉發服務器。8 f  r$ a* R, o$ L6 U) `
5 V) J8 a" l5 u  y
【6】初裝的mysql如果沒有設置密碼,應該使用update mysql.user set password="yourpassword" where user="root" 修改密碼
% a0 `" R) b; F5 t" \: a2 T
4 R3 t2 f0 A# C( J" ?( A" s! ^【7】header already sent
% i: j$ X- e: J0 g1 a! L! n1 y
+ }/ E+ a0 `! o8 X/ G9 M這個錯誤通常會在你使用HEADER的時候出現,他可能是幾種原因:1,你在使用HEADER前PRING或者ECHO了2.你當前文件前面有空行3.你可能INCLUDE了一個文件,該文件尾部有空行或者輸出也會出現這種錯誤。!
' J. ]& H  v+ j; y8 d5 x
7 U8 m) a" C0 c% g1 w【8】更改php.ini後沒有變化8 V) o0 T+ q5 X- i0 t9 V

9 ~+ `) F, |) o0 I8 @+ a# @重新啟動web server,比如IIS,Apache等等,然後才會應用最新的設置。, W0 Q6 c% ?3 }
3 }8 _5 }# V! F. V; D# D* t: ~5 v; z
【9】php在2003上面安裝(ISAPI的安裝方法懇請高手指教)
: l, _- j: F$ S
4 T; B* h  w5 y' OPHP4的php4isapi.dll好像和2003有些衝突,只能用CGI模式安裝: X+ ^5 P- r$ ?. x) H
  Y: E- u( c3 \9 _: i+ l2 i
步驟一,先www.php.net 下在一個安裝程序,我是裝的是:php-4.2.3-installer.exe,你也可以去找最新的版本,在安裝php-4.2.3- installer.exe之前保證你的IIS6.0啟動了,並能夠訪問。安裝好以後,在默認網站-->應用程序配置。0 Z; V% {, R, }$ J+ m1 m" c
' f* u6 L8 W/ k
步驟二:點擊 web服務擴展 -->新建web服務擴展。# n0 V1 J# B, ]) n

. K9 v- c4 ~' W+ `! {步驟三: 擴展名-->php,然後添加% q5 y6 L& c6 l" Y. A

* B! S  c) h: {3 a; w步驟四:找到php.exe的路徑添加上去。
- {- O: J' E9 C3 q. p) l4 o3 }0 ~
步驟五: 確定就可以了!
: U- e, J. U6 P0 |# ?0 j, x$ @( R2 N9 J( W# x9 C
步驟六: 選擇php的服務擴展,然後點擊允許。( |5 ^9 F" P5 {+ N( z
$ H; O, D( X4 K8 S
【10】有時候sql語句不起作用,對數據庫操作失敗,最簡便的調試方法,echo那句sql,看看變量的值能得到不。
% U/ B2 R4 ~! d
; l) R  H) o- B0 X【11】include和require的區別
" h5 x- B1 v  m( F: P  b8 W2 W: C& G- S* |! q3 M2 A" y9 x) K0 {% E# \
兩者沒有太大的區別,如果要包含的文件不存在,include提示notice,然後繼續執行下面的語句,require提示致命錯誤並且退出。
4 w4 ?+ }6 w% Q7 n% |
$ r# t; T$ S# A) f( Z5 w) c2 e9 @, o據我測試,win32平台下它們都是先包含後執行,所以被包含文件裡最好不要再有include或require語句,這樣會造成目錄混亂。或許*nux下情況不同,暫時還沒測試。, r, U7 M0 V. G0 S, {8 e, Z: i
: l* |! ]! r' E
如果一個文件不想被包含多次可以使用include_once或require_once## 讀取,寫入文檔數據。
2 c& x; R* d( S; z* K/ k/ S% g+ K% K# S  e
PHP 代碼:
6 m5 s: i- c" b7 K0 bfunction r($file_name) {# `. I" s; F' M& V; p/ Z
  $filenum=@fopen($file_name,"r");
* n, G- u3 ]/ k. {/ B4 l" \  @flock($filenum,LOCK_SH);# x5 q- Y0 G8 X' T0 i
  $file_data=@fread($filenum,filesize($file_name));( s+ v+ S! J& R: |4 M
  @fclose($filenum);) W1 N2 N6 G: m! k: u
  return $file_data;
% v/ a% V' o/ Q$ B/ c6 P6 ]}
7 W3 v' G2 F- ]/ e3 Z9 F2 wfunction w($file_name,$data,$method="w"){$ D$ }) Z0 M' V( W$ |
  $filenum=@fopen($file_name,$method);
  d6 _7 V, l( Y, c/ U0 C) N' c7 Q  flock($filenum,LOCK_EX);
. L: A' D9 h8 P1 G9 D  $file_data=fwrite($filenum,$data);* n0 v7 C% q2 ~( c
  fclose($filenum);
( t5 b6 X6 d2 _5 V/ i  return $file_data;
! Z( t  _* i/ d& f9 V8 x5 d}  1 s( h3 Y! W9 `6 E& k+ }- L6 J

4 Q. F2 d$ h6 k% M6 w5 f0 \【12】isset()和empty()的區別
/ b# _6 g+ Z. L( X
9 h4 F: d2 Z8 ^* ^# I. m' K兩者都是測試變量用的,但是isset()是測試變量是否被賦值,而empty()是測試一個已經被賦值的變量是否為空。) B3 V  C* C! p$ p
& R. y4 z3 D" c3 `! r. Y: @8 I
如果一個變量沒被賦值就引用在php裡是被允許的,但會有notice提示,如果一個變量被賦空值,$foo=""或者$foo=0或者 $foo=false,那麼empty($foo)返回真,isset($foo)也返回真,就是說賦空值不會註銷一個變量。$ ^9 M: \4 {, \" P4 i

" d0 r  I9 X9 v% r3 {' E% F要註銷一個變量,可以用 unset($foo)或者$foo=NULL- E) g2 m* p, B6 V% f& }

1 U+ I4 }& L$ Y2 u3 t5 W【13】mysql查詢語句包含有關鍵字
0 s+ K9 K8 j5 H. g" F! ~
' M& U3 i! a, E$ Q& L8 [" Ophp查詢mysql的時候,有時候mysql表名或者列名會有關鍵字,這時候查詢會有錯誤。例如表名是order,查詢時候會出錯,簡單的辦法是sql語句裡表名或者列名加上`[tab鍵上面]來加以區別,例如select * from `order`
& j* k2 L5 d+ s. r; O7 u3 @4 O- _4 ^4 W9 _  \
【14】通過HTTP協議一次上傳多個文件的方法1 \; ]- b& a0 F5 s4 }( r
% K7 T: e' W6 @  z
有兩個思路,是同一個方法的兩種實現。具體程序還需自己去設計。
0 Y/ X0 d9 q1 M! \3 z; s# z' z9 \' Z4 [0 m: Z9 c9 ^
1、在form中設置多個文件輸入框,用數組命名他們的名字,如下:4 N* ?9 A- W- p# O1 H9 [/ R
+ k8 O4 g; K) t
PHP 代碼:
8 U/ G/ g: R" x% d+ Y<form action="" method=post>
% ~+ X! B7 W  t1 ^% w7 V% S- r<input type=file name=usefile[]>
; @6 l( L% W& X4 b/ y<input type=file name=usefile[]>! o( Y- A1 Z1 r/ v+ t# }
<input type=file name=usefile[]>; }6 n2 b8 a% q  h2 \3 x- v4 `
</form>  
8 @5 T0 l% k% ]4 S, I/ B2 r: ^: @1 X
這樣,在服務器端做以下測試:  [9 @, v7 a5 Y: k
% R4 X! C+ J; t# n5 C" h
PHP 代碼:
5 ^4 U+ Q* t# W& l9 T' p* b, E/ Recho "<pre>";
7 ]  M2 }0 }$ Vprint_r($_FILES);/ |$ A' D" t3 L& B4 P* a, [( r
echo "</pre>";  
2 y" q+ |) z- O7 U2 t
+ ~( I) _) {+ ~3 _# o, q$ I2、在form中設置多個文件輸入框,但名字不同,如下:
) u6 {9 r! J% F4 I: L. m& Y/ i' U: b4 v+ q0 j2 @  s
PHP 代碼:2 H6 z& W/ A. E- l3 f- L2 N, t$ }% c
<form action="" method=post>* N" \$ r& T8 ~, H. |  z. b& w
<input type=file name=usefile_a>1 ^2 b# l, D3 M6 H+ c
<input type=file name=usefile_b>2 y! x4 v! ^( ?  |2 T0 V
<input type=file name=usefile_c>
( V4 \- W0 q/ h) p: ?& c( x</form>  , J; |" D/ e  P4 I- g* x
4 m0 t$ c8 a, S6 U$ R1 F
在服務器端做同樣測試:
( M7 T: [: {. @) P+ v- `8 t. U. a  W/ s0 H# _% L1 _: }- H
PHP 代碼:
* b; R& c8 \# y; }7 k3 secho "<pre>";0 f6 I* ~' [) Q
print_r($_FILES);
* J0 Z/ P) u' kecho "</pre>";

評分

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

查看全部評分

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

本版積分規則

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

GMT+8, 2025-7-6 07:42

By DZ X3.5

小黑屋

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