1:为什么我得不到变量, r3 T8 L" N5 d9 I3 A. s
- D% K3 Q5 X# h; y! {5 q4 D
我在一网页向另一网页POST数据name,为什么输出$name时却得不到任何值?
. Y; @6 H) U5 y( g
在PHP4.2以后的版本中register_global默认为off5 }( T Y; ? h2 T
若想取得从另一页面提交的变量:
方法一:在PHP.ini中找到register_global,并把它设置为on.
方法二:在接收网页最前面放上这个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
2:调试你的程序
在运行时必须知道某个变量为何值。我是这样做的,建立一文件debug.php,其内容如下:; J+ K+ r6 y8 Y V* d
PHP代码:5 X/ r8 b% k4 {
. i# ~! E$ u) J( p) A: l5 L
<?PHP
Ob_Start();
Session_Start();/ X. f: `+ E" m% {
Echo "<pre>";7 T- |$ G" M! /7 C9 _6 Q7 k: f. n
Echo "本页得到的_GET变量有:";9 t" Y: `( ]& H4 x& k
Print_R($_GET);
Echo "本页得到的_POST变量有:";/ t4 w% x, p+ j% O( r
Print_R($_POST);' n4 a, ~ @* Z: R$ _# v
Echo "本页得到的_COOKIE变量有:";
Print_R($_COOKIE);+ @3 b8 U' s# K0 H& s' ]
: r( ~+ }( Y' W& |( O) V
Echo "本页得到的_SESSION变量有:";
Print_R($_SESSION);9 |, c# |7 ]# Z8 x
; H8 h/ @0 o( w- f
Echo "</pre>";/ R( M8 j/ h$ r) R i- P
?>
. 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
3:如何使用session, }, }" Q, q7 y% V7 C6 F
凡是与session有关的,之前必须调用函数session_start();
为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
Session_start();
$Name = "这是一个Session例子";( ]* E( A; [- o& d) ]% n3 Z- h
Session_Register("Name");//注意,不要写成:Session_Register("$Name");
Echo $_SESSION["Name"];
//之后$_SESSION["Name"]为"这是一个Session例子"& ]" N/ p: j/ g# s+ Z6 N6 A" E
?>, b$ b* ?, i* ?
$ r3 r. W% f9 Z* L
在php4.2之后,可以为session直接付值:
PHP代码:) W9 N8 J& F6 Q4 d) ~5 K/ d2 e
<?PHP% H( b) Q" Z) N8 o! Q
Session_Start();
$_SESSION["name"]="value";
?>
, 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
session_start();
session_unset();
session_destroy();
?>& ~3 {7 U& C% w8 S
7 e3 }& g1 ~; B9 J/ d# Q
取消某个session变量在php4.2以上还有BUG.& _/ S" x2 Q/ x- L' W
注意:8 l" Q) l Q A3 R) ~1 u
- B. l5 Z) E+ F
1:在调用Session_Start()之前不能有任何输出.例如下面是错误的.4 j3 G* U7 n/ e3 p
==========================================
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
提示1:9 ^( ?0 [; K5 D2 e j5 T
, K# t3 A1 g& ]& c6 h' n
凡是出现" ........headers already sent.......... ",就是Session_Start()之前向浏览器输出信息.去掉输出就正常,(COOKIE也会出现这种错误,错误原因一样)
H% W/ b; n) Z( t* J$ _
提示2:/ O2 B- a" j1 g) j! i, M
如果你的Session_Start()放在循环语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:
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:....
因为你没有指定session文件的存放路径.. T# e4 @/ m; d
: V w8 E7 s; k% O) h! /+ D
解决方法:( J2 Z: T! Z% M! l: A
(1)在c盘建立文件夹tmp
(2)打开php.ini,找到session.save_path,修改为session.save_path= "c:/tmp"
4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失5 r- h1 l7 V" ?. y
PHP代码:
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
receive.php的内容:& n, }& n1 s: A
PHP代码:
<?PHP
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
?>
正确的方法是:
2 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";
$post= "receive.php?Name=".urlencode($Var);9 B5 b. B! F7 N" /* m/ @
header("location:$post");
?>
在接收页面你不需要使用Urldecode(),变量会自动编码.
5:如何截取指定长度汉字而不会出现以"?>"结尾,超出部分以"..."代替
一般来说,要截取的变量来自Mysql,首先要保证那个字段长度要足够长,一般为char(200),可以保持100个汉字,包括标点.
PHP代码:1 ^; M3 h( E/ {* F" g. h9 U
9 c5 U; ]. n- g W5 V
<?PHP
$str="这个字符好长呀,^_^";
$Short_Str=showShort($str,4);//截取前面4个汉字,结果为:这个字符...
Echo "$Short_Str";. p; ~2 S7 _% y8 e7 G) c
Function csubstr($str,$start,$len) 2 G* w7 g+ J" p2 j5 m
{
$strlen=strlen($str);
$clen=0;
for($i=0;$i<$strlen;$i++,$clen++)
{ 4 o# F+ m3 I" C4 H
if ($clen>=$start+$len)
break;
if(ord(substr($str,$i,1))>0xa0) * R: [. [# u$ T; Q- ^
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,2); : k0 B8 V2 H* T# B0 v1 f; l
$i++;
}
else + `; /7 h' h1 r
{
if ($clen>=$start) % Z. v+ a5 /$ E6 Y' V$ W# F: c" }
$tmpstr.=substr($str,$i,1);
} 1 ]6 J; E4 d1 N
}
; 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)
$tempstr .= "..."; //要以什么结尾,修改这里就可以.2 }6 ]: m2 a" z( I( k
return $tempstr;
}1 B& E n# E) w( n! J" t
6:规范你的SQL语句
/ X$ `6 u8 e& o* l4 C# R( L4 }
在表格,字段前面加上"`",这样就不会因为误用关键字而出现错误,当然我并不推荐你使用关键字.
例如% ?& 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')"
1 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格式的字符串不被解释,而是照原样显示
' m6 w! Q4 /+ [
PHP代码:
<?PHP% T+ Y9 P3 o H
$str="<h1>;PHP</h1>";* {) t& S9 S$ s. I+ /
Echo "被解释过的: ".$str."<br>经过处理的:";
Echo htmlentities(nl2br($str));
?>
# E2 y5 z; t6 g* A* ~
8:怎么在函数里取得函数外的变量值2 @% c5 x# f) P4 y: e
PHP代码:) n7 a& C$ V( ~7 B
2 t2 Q& E6 A) v& v3 |! /6 @& ^
<?PHP
$a=";PHP";
foo();
Function foo()9 w r$ O4 a. i. _' ^
{
global $a;//删除这里看看是什么结果
Echo "$a";& `+ E0 z6 u4 O/ {) Q* v$ E8 ]
}
?>* i6 h/ j' m, g. N$ I7 y, x
9:我怎么知道系统默认支持什么函数
x8 c( r/ C0 O) I' d1 `) p6 N& p
PHP代码:
<?php
$arr = get_defined_functions();
Function php() {
}. 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>";
?> + 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
PHP代码:: w+ E2 ?" ^/ ]! q, |
<?PHP; A4 ]' |3 R3 U3 |6 O, e
$Date_1="2003-7-15";//也可以是:$Date_1="2003-7-15 23:29:14";
$Date_2="1982-10-1";
$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);
Echo "偶已经奋斗了 $Days 天^_^";+ B$ h+ z4 `) W- I* s
?>
11:为什么我升级PHP后,原来的程序出现满屏的 Notice: Undefined variable:" ^( C1 @9 { g
这是警告的意思,由于变量未定义引起的.
打开php.ini,找到最下面的error_reporting,修改为error_reporting = E_ALL & ~E_NOTICE
对于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
那什么是error_reporting?
7 b! k! R' l/ x! s
12:我想在每个文件最前,最后面都加上一文件.但一个一个添加很麻烦
7 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
2:写两个文件
auto_prepend_file.php 和 auto_append_file.php 保存在c盘,他们将自动依附在每个php文件的头部和尾部.
' ?& S( p7 W2 {( ~; w& X( I1 J
3:在php.ini中找到:
Automatically add files before or after any PHP document.
auto_prepend_file = auto_prepend_file.php;依附在头部, J" E" ]4 Q" H4 l" |2 `% B
auto_append_file = auto_append_file.php;依附在尾部
~( R1 n! z& y& b
以后你每个php文件就相当于
PHP代码:
<?php / V4 [- U: o- k/ E
Include "auto_prepend_file.php" ;
.......//这里是你的程序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
?>
* b% P' J' v# V" a; R) p( v7 x: J
13:如何利用PHP上传文件
PHP代码:0 T: U: e+ T" S7 b2 a* [$ z
<html><head># H3 i( e9 X. l( ~6 G- C3 M& A
<title>上载文件表单</title></head> & Q9 f/ E A. Z: `' b
<body>
<form enctype="multipart/form-data" action="" method="post"> , K: Y: T4 ]4 Q8 I9 R
请选择文件: <br>
<input name="upload_file" type="file"><br>) n2 E( s" z7 ~+ R
<input type="submit" value="上传文件">
</form>
</body>$ X3 F! a5 Y8 p- {4 s
</html> 7 k8 K7 w0 t9 |$ r9 X* R" K
<?
$upload_file=$_FILES['upload_file']['tmp_name'];
$upload_file_name=$_FILES['upload_file']['name'];
9 w$ k; f: L% R; d( ?, x
if($upload_file){
$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) {
echo "对不起,你的文件容量大于规定";, S p# q) J$ t& ~) Y4 R
exit;
}) F& |9 H4 B& K: j9 p
// 检查读写文件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 "存在相同文件名的文件";
exit;
}
//复制文件到指定目录
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;
}9 Z `( [4 T+ K+ W
}
Echo "<p>你上传了文件:";
echo $_FILES['upload_file']['name'];
echo "<br>";
//客户端机器文件的原名称。 8 L2 p5 a% e: {! l4 D- H4 s
Echo "文件的 MIME 类型为:";
echo $_FILES['upload_file']['type'];
//文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。 ( `" F2 F( U5 s: w$ f
echo "<br>";
8 P! H( l9 a2 q
Echo "上传文件大小:";
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
Echo "文件上传后被临时储存为:";
echo $_FILES['upload_file']['tmp_name'];0 q. t( `' s" @7 }% r
//文件被上传后在服务端储存的临时文件名。
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'];
switch($Erroe){
case 0:' R- F5 z1 ]6 K! ?* P
Echo "上传成功"; break;
case 1:
Echo "上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值."; break;
case 2:
Echo "上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。"; break;
case 3:
Echo "文件只有部分被上传";break;0 i2 R. G+ m1 ^: r2 K# b0 n( R
case 4:
Echo "没有文件被上传";break;. q6 ?/ T) f5 U @' Z5 Z0 A! `* J$ z
}
?>
14:如何配置GD库) j9 L; V: R% |7 ]
: F+ H, l1 W3 ]3 G
下面是我的配置过程
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/";
3:
extension=php_gd2.dll;把extension前面的逗号去掉,如果没有php_gd2.dll,php_gd.dll也一样,保证确实存在这一文件c:/php/extensions/php_gd2.dll1 M& u& M2 K9 `/ B
4:运行下面程序进行测试
PHP代码:
<?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.
header ("Content-type: image/png");" ?5 F" u% ^' C/ m$ T
$im = @imagecreate (200, 100)# e: X0 e- {# c- @* y, d
or die ("无法创建图像");
$background_color = imagecolorallocate ($im, 0,0, 0);
$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 T0 d0 f m5 V; W {8 n9 R
点击这里查看结果! e; W9 k4 W7 x
' C: ]+ g! W) u( s
15:什么是UBB代码2 G9 |- Y0 U! b G, R
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
和方法三一样,只是使用了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'));
mysql> FLUSH PRIVILEGES9 {% }$ N. D6 g& V6 `2 D( K/ V
方法五 |, w: X' Q$ H% Y# l
使用SET PASSWORD语句,
8 a# E3 D1 F' U$ N
mysql> SET PASSWORD FOR jeffrey@"%" = PASSWORD('biscuit'); ; B: L" V3 Y N, M" z6 F) G
你也必须使用PASSWORD()函数, : p# Q# x/ n9 V8 y
但是不需要使用FLUSH PRIVILEGES。
方法六 ! N7 r: l* Y: t" J
使用GRANT ... IDENTIFIED BY语句
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
这里PASSWORD()函数是不必要的,也不需要使用FLUSH PRIVILEGES。 8 t& g- u! Q# ?5 A' o- b! k
注意: PASSWORD() [不是]以在Unix口令加密的同样方法施行口令加密。 " y2 S$ |$ Y- S3 A6 Z
- /6 e7 ?! t$ {1 y" @! X6 w. K
17:我想知道他是通过哪个网站连接到本页" i# U: K; o& H" S
PHP代码:4 |: I d5 B5 E3 ?: n" w
<?php
//必须通过超级连接进入才有输出3 U/ W' T$ Q5 ]' D
Echo $_SERVER['HTTP_REFERER'];( y+ E& X% _9 u, q" F. C9 B
: r& B2 i; M$ |4 J( _, l
?>
18:数据放入数据库和取出来显示在页面需要注意什么
入库时
; 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
出库时
$str=stripslashes($str);
! n& u) M' l* S+ D
显示时
$str=htmlspecialchars(nl2br($str)) ;
<?php( q8 p+ c. t, z. [- H
//$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+ [
$content=str_replace("/n","<br>/n",$content);
?>
19:如何读取当前地址栏信息% f0 Y6 [$ T1 v6 k5 G# b( A
PHP代码:8 H$ V# N. [" i& W
<?php
2 [5 L$ q. B1 g: o8 x1 E' X3 y8 o( E
$s="http://{$_SERVER['HTTP_HOST']}:{$_SERVER["SERVER_PORT"]}{$_SERVER['SCRIPT_NAME']}";
* {2 g9 e- E/ o" _- p0 R
$se='';
foreach ($_GET as $key => $value) { ! t6 q3 Q: r8 a+ X- U" A
$se.=$key."=".$value."&";
}
$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";
?>
20:我点击后退按钮,为什么之前填写的东西不见
这是因为你使用了session.' u' @% i! v' E& V- i
1 N/ H% s/ P5 E% K# O7 h4 [( |! v
解决办法:! ?& v6 X& z6 G
PHP代码:
<?php session_cache_limiter('private, must-revalidate');session_start();
.....................?>) D0 h& I$ M, q
21:怎么在图片里显示IP地址& Q6 g5 F2 X$ Q+ W) X4 L
PHP代码:
<? Header("Content-type: image/png");
$img = ImageCreate(180,50);
$ip = $_SERVER['REMOTE_ADDR'];
ImageColorTransparent($img,$bgcolor);
$bgColor = ImageColorAllocate($img, 0x2c,0x6D,0xAF); // 背景颜色1 Q* u3 /) c2 c( U' s, I0 @! b {
$shadow = ImageColorAllocate($img, 250,0,0); // 阴影颜色
$textColor = ImageColorAllocate($img, oxff,oxff,oxff); // 字体颜色
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);
imagecreatefrompng($img);
ImageDestroy($img); + W7 F6 q4 V1 j$ p& H+ R8 Y9 T0 V
?>' a: t8 z$ z8 y- x+ G
22:如何取得用户的真实IP
9 ?4 B, L4 b$ {% o4 |9 b. ]
PHP代码:
<? function iptype1 () {
if (getenv("HTTP_CLIENT_IP"))6 J0 S) j; d9 /- [7 K0 d4 v: J6 e
{
return getenv("HTTP_CLIENT_IP"); 5 g: O, _( k& Q- H
}
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
}
function iptype2 () {
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
}
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
{
return getenv("REMOTE_ADDR");
}
else {
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;
}
elseif (isset($ip2) && $ip2 != "none" && $ip2 != "unknown")
{
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
{
return $ip3; # p5 k# G# [0 |' e% ]
}
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();
?>
8 Y9 r W7 {# f) j& v" _* z
23:如何从数据库读取三天内的所有记录
首先表格里要有一个DATETIME字段记录时间,
格式为'2003-7-15 16:50:00'
SELECT * FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) <= 3;
24:如何远程链接Mysql数据库. ?% v: R% U, M" [
在增加用户的mysql表里有一个host字段,修改为"%",或者指定允许连接的ip地址,这样,你就可以远程调用了。
$link=mysql_connect("192.168.1.80:3306","root","");
5 G9 l5 m( N1 ]* `- w7 t3 l: X
25:正则到底怎么用' H) F, T" D6 o
点击这里
正则表达式中的特殊字符
26:用Apache后,主页出现乱码 ( G b$ _/ k% Q# l
方法一: 7 o$ j* ?: Z7 m& ~: f- Y; h
5 Q$ V* ^; Q& o9 V# Z2 d
AddDefaultCharset ISO-8859-1 改为 AddDefaultCharset off
方法二:
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:为什么单引号,双引号在接受页面变成(/'/")
解决方法:
7 U& j8 I2 l) b6 P) U3 u8 r
方法一:在php.ini中设置:magic_quotes_gpc = Off
方法二: $str=stripcslashes($str)/ Q7 ?! C% ^4 Y. z; N
. N, H8 K/ c; |& S2 b
28:怎么让程序一直运行下去,而不是超过30秒就停止
set_time_limit(60)//最长运行时间一分钟
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
例子一:用文本实现
PHP代码:
<?php
//首先你要有读写文件的权限
//本程序可以直接运行,第一次报错,以后就可以8 q0 x" ? c5 `% N( }% r
$online_log = "count.dat"; //保存人数的文件,
- d# i: T0 E- j+ o1 r/ v" K
$timeout = 30;//30秒内没动作者,认为掉线 * k# _- @: Q `/ X
$entries = file($online_log); 8 f) C- h5 s, n# P8 }: ~
$temp = array();
* n2 y! J, m; N5 I
for ($i=0;$i<count($entries);$i++) {
4 g6 d9 t c; u$ |/ ]" X: J8 M0 [" `
$entry = explode(",",trim($entries[$i]));
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
& R, L) X1 z- h6 i) W R
}
}
array_push($temp,getenv('REMOTE_ADDR').",".(time() + ($timeout))."/n");
//更新浏览者的时间
& 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
//写入文件4 z) ^& c* O1 }% [# W" q$ {
$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以及其他的一些网络文件系统中正常工作
. 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);
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
1 o" e/ [8 B' C: X, u$ `9 [
30:什么是模板,怎么用
我用的是phplib模板$ o% J: S# F4 e& G. j
0 Y7 U/ w% g) T( a" I# Q6 G
下面是其中几个函数的使用
$T->Set_File("随便定义","模板文件.tpl"); % z) k, @0 }2 m& Y5 z9 F) j" m* /
$T->Set_Block("在set_file中定义的","<!-- 来自模板 -->","随便定义");
$T->Parse("在Set_Block中定义的","<!-- 来自模板 -->",true);
/ H; O2 H3 {9 }
$T->Parse("随便输出结果","在Set_File中定义的");
设置循环格式为:7 D; l+ o u. V) D$ p
<!--(多于一个空格) BEGIN $handle(多于一个空格)-->
如何将模板生成静态网页/ N! ]+ F6 q# D4 Z& x
- T* A4 s0 Q! z
PHP代码:
<?php
7 A" B0 Y2 ^* y4 e/ m3 Q
//这里使用phplib模板
............
, 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");
7 o- ~$ g7 I! K) B* N$ T: }1 T: M( q
$output = $tpl->get("output");// $output 为整个网页内容9 Q" R( J8 N+ C$ @# M! {6 _
function wfile($file,$content,$mode='w') {
$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
if (!$fp) return false;
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% [
return true;
}+ e J. Z) }5 ~$ a- W
1 _# }3 k- B3 /9 h: s6 w
// 写到文件里
9 J4 Q3 e; _" P1 H# Q1 |3 u
Wfile($FILE,$output);" u' s- o$ `, i# l$ V$ [, [* ?
header("location:$FILE");//重定向到生成的网页9 p2 e. y& J& a6 X q2 N
}
+ _1 `$ @5 S- b+ N+ h) z6 [8 x
?>
phplib下载地址 smarty下载地址
1 G: G6 g, m" @
31:怎么用php解释字符
比如:输入2+2*(1+2),自动输出8 可以用eval函数
PHP代码:
. A B6 I. v0 G3 x# L. e2 @
<form method=post action="">
- W: n* Q/ }2 D- [" [0 m
<input type="text" name="str"><input type="submit">& n! l( O# G% X# h
</form>
, 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
eval("/$o=$str;");/ L3 y, r. w; u7 p% d. i; o2 Y8 E+ J' [
Echo "$o";
?>$ p; s) q, a4 B4 A2 p# W' |
到此,php的问题解答就为大家介绍完毕,希望能对各位有所帮助。