阿七
级别: 未验证会员
精华:
0
发帖: 909
威望: 0 点
金钱: 2161 RMB
贡献值: 0 点
在线时间:512(小时)
注册时间:2006-03-29
最后登录:2008-08-07
|
另PHP初学者们最头疼的几个问题及解决办法。
另PHP初学者们最头疼的几个问题及解决办法。 !,\9,lc 出处 /IV:JVT N M~e 【1】页面之间无法传递变量 get,post,session在最新的php版本中自动全局变量是关闭的,所以要从上一页面取得提交过来得变量要使用$_GET['foo'],$_POST['foo'],$_SESSION['foo']来得到。当然也可以修改自动全局变量为开(php.ini改为register_globals = On);考虑到兼容性,还是强迫自己熟悉新的写法比较好。 ? *I9 %v~j10e 【2】Win32下apache2 用get方法传递中文参数会出错: r?/>t1Z fBd +gT\S test.php?a=你好&b=你也好 6nGDoW# web&M!- 传递参数是会导致一个内部错误 =AcbX_[ sQih
yq6U; 解决办法:"test.php?a=".urlencode(你好)."&b=".urlencode(你也好) JG}U,{7( <JH0 & ............. @1Zf&'/6 XcfTE
m 【3】win32下的session不能正常工作 nVyb B~.= `8'T*KU php.ini默认的session.save_path = /tmp l3iL.?&Pa H#Og0gEE}5 这显然是linux下的配置,win32下php无法读写session文件导致session无法使用,把它改成一个绝对路径就可以了,例如session.save_path = c:windows emp dqKTF_+VhA p Y>yJ) 【4】显示错误信息 J$WIF&*0@ b$
Uwj<v 当php.ini的display_errors = On并且error_reporting = E_ALL时,将显示所有的错误和提示,调试的时候最好打开以便纠错,如果你用以前php写法错误信息多半是关于未定义变量的。变量在赋值以前调用会有提示,解决办法是探测或者屏蔽。 <
m9O0 vCpi|a_eCu 例如显示$foo,可以if(isset($foo)) echo $foo 或者echo @$foo nM0nQ{6 10}Zoq|)n 【5】Win32下mail()不能发送电子邮件 g:o\ r
( }lxvXVc{I
在linux下配置好的sendmail可以发送,在win32下需要调用smtp服务器来发送电子邮件,修改php.ini的SMTP = ip //ip是不带验证功能的smtp服务器(网上很难找到) H`Z4a
N IYCKF/2o php发送邮件的最好解决方法是用socket直接发送到对方email服务器而不用转发服务器。 RD_;us@&&* `
jZX(H 【6】初装的mysql如果没有设置密码,应该使用update mysql.user set password="yourpassword" where user="root" 修改密码 *UyV@ $&e(V6A@ 【7】header already sent uRL3v01?H0 U/iAP W4U 这个错误通常会在你使用HEADER的时候出现,他可能是几种原因:1,你在使用HEADER前PRING或者ECHO了2.你当前文件前面有空行3.你可能INCLUDE了一个文件,该文件尾部有空行或者输出也会出现这种错误。! Uv+pdRXn l.34
h 【8】更改php.ini后没有变化 U|Jo[4A n]$vCP 重新启动web server,比如IIS,Apache等等,然后才会应用最新的设置。 |@@mq!>- ~F(+uJbO 【9】php在2003上面安装(ISAPI的安装方法恳请高手指教) R/Y/#X^b Ov<3?)ok PHP4的php4isapi.dll好像和2003有些冲突,只能用CGI模式安装 *xl7;s iP!Y4F 步骤一,先www.php.net 下在一个安装程序,我是装的是:php-4.2.3-installer.exe,你也可以去找最新的版本,在安装php-4.2.3-installer.exe之前保证你的IIS6.0启动了,并能够访问。安装好以后,在默认网站-->应用程序配置。 ^6LFho4 -E500F*b 步骤二:点击 web服务扩展 -->新建web服务扩展。 1tr>D:c\ n47=eKd70 步骤三: 扩展名-->php,然后添加 JyqFFZ
& aW6+Up+G* 步骤四:找到php.exe的路径添加上去。 1`}fbX;"m) QhG-1P3# 步骤五: 确定就可以了! bMUIe\/v[ 5"gRz9Ta` 步骤六: 选择php的服务扩展,然后点击允许。 R`**!ku :1lE98= 【10】有时候sql语句不起作用,对数据库操作失败,最简便的调试方法,echo那句sql,看看变量的值能得到不。 R|CY4G
j kr*c?^b 【11】include和require的区别
{''|iwLr YT5>pM-% 两者没有太大的区别,如果要包含的文件不存在,include提示notice,然后继续执行下面的语句,require提示致命错误并且退出。 eTF8B<? Uo @
NK 据我测试,win32平台下它们都是先包含后执行,所以被包含文件里最好不要再有include或require语句,这样会造成目录混乱。或许*nux下情况不同,暂时还没测试。 v2n0[b0 !1RV[b.8 如果一个文件不想被包含多次可以使用include_once或require_once## 读取,写入文档数据。 g&"(- : ZmULy;{<) function r($file_name) { &1p8#i $filenum=@fopen($file_name,"r"); Vf?#W,5>= @flock($filenum,LOCK_SH); Lmwh`oOl $file_data=@fread($filenum,filesize($file_name)); YSV,q@I&1 @fclose($filenum); }x.)gW return $file_data; &5.~XM; } VDTY<= Q function w($file_name,$data,$method="w"){ )zXyV]xe $filenum=@fopen($file_name,$method); k,7+=.6 flock($filenum,LOCK_EX); "k-ov9yK $file_data=fwrite($filenum,$data); '%EZoc/U fclose($filenum); m IzBK]@^ return $file_data; w`}9/s;$ } -L9R&r#_e DLYZsWA, 【12】isset()和empty()的区别 @LKG\zYBu jAK{<7v4U 两者都是测试变量用的,但是isset()是测试变量是否被赋值,而empty()是测试一个已经被赋值的变量是否为空。 A'(7V
J &ZE\
@Vc 如果一个变量没被赋值就引用在php里是被允许的,但会有notice提示,如果一个变量被赋空值,$foo=""或者$foo=0或者 $foo=false,那么empty($foo)返回真,isset($foo)也返回真,就是说赋空值不会注销一个变量。 EB>B,# hRr1#'& 要注销一个变量,可以用 unset($foo)或者$foo=NULL b!]0mXU (a} 【13】mysql查询语句包含有关键字 QP%kL
*=8 (kC} ,} php查询mysql的时候,有时候mysql表名或者列名会有关键字,这时候查询会有错误。例如表名是order,查询时候会出错,简单的办法是sql语句里表名或者列名加上`[tab键上面]来加以区别,例如select * from `order` ~g1, !Wl 5ttMua <G? 【14】通过HTTP协议一次上传多个文件的方法 "W@XP+POAY 8*y
o7q& 有两个思路,是同一个方法的两种实现。具体程序还需自己去设计。 wm=RD9
8 xb>n&ym? 1、在form中设置多个文件输入框,用数组命名他们的名字,如下: i~)NQmH< y?#9>S >:\ <form action="" method=post> rer|k<k;]G <input type=file name=usefile[]> -+}5ma <input type=file name=usefile[]> i
u1KRuaF[ <input type=file name=usefile[]> 8PBU~mr </form> -2\ZzK0tM lRDxIuTK 这样,在服务器端做以下测试: B:-U`CHHQ mP pvZ
echo "<pre>"; :)p)=c8% print_r($_FILES); ,;.B4 echo "</pre>"; )'5<6Q.] 7qg<[ 2、在form中设置多个文件输入框,但名字不同,如下: W|d
pFh` k&)K( <form action="" method=post> 8/3u/ <input type=file name=usefile_a> H&X:!xa5 <input type=file name=usefile_b> aDL)|>"Q <input type=file name=usefile_c> tAqA^f*{ </form> j z~[5m}J o]Wz6L 在服务器端做同样测试: r C_d$Jv TD
lZ!$g( echo "<pre>"; 74K)aA print_r($_FILES); ^qxdmMp)l echo "</pre>";
|
|
|
|
[楼 主]
|
Posted: 2006-04-03 14:03 |
| |