Php部分常见问题总结

| |
[2007/03/20 12:39 | 分类: PHP | by 特蓝克斯 ]
1:为什么我得不到变量

我在一网页向另一网页POST数据name,为什么输出$name时却得不到任何值?

在PHP4.2以后的版本中register_global默认为off
若想取得从另一页面提交的变量:

方法一:在PHP.ini中找到register_global,并把它设置为on.
方法二:在接收网页最前面放上这个extract($_POST);extract($_GET);(注意extract($_SESSION)前必须要有Session_Start()).
方法三:一个一个读取变量$a=$_GET["a"];$b=$_POST["b"]等,这种方法虽然麻烦,但比较安全.

2:调试你的程序

在运行时必须知道某个变量为何值。我是这样做的,建立一文件debug.php,其内容如下:


CODE:[Copy to clipboard]
<?PHP
Ob_Start
();
Session_Start
();
Echo
"<pre>"
;

Echo
"本页得到的_GET变量有:"
;
Print_R($_GET
);

Echo
"本页得到的_POST变量有:"
;
Print_R($_POST
);

Echo
"本页得到的_COOKIE变量有:"
;
Print_R($_COOKIE
);

Echo
"本页得到的_SESSION变量有:"
;
Print_R($_SESSION
);
Echo
"</pre>"
;
?>
然后在php.ini中设置:include_path = "c:/php",并将debug.php放在此文件夹,
以后就可以在每个网页里包含此文件,查看得到的变量名和值.

3:如何使用session

凡是与session有关的,之前必须调用函数session_start();

为session付值很简单,如:


CODE:[Copy to clipboard]
<?php
Session_start
();
$Name = "这是一个Session例子"
;
Session_Register("Name");
//注意,不要写成:Session_Register("$Name");
Echo $_SESSION["Name"
];
//之后$_SESSION["Name"]为"这是一个Session例子"
?>
在php4.2之后,可以为session直接付值:


CODE:[Copy to clipboard]
<?PHP
Session_Start
();
$_SESSION["name"]="value"
;
?>
取消session可以这样:


CODE:[Copy to clipboard]
<?php
session_start
();
session_unset
();
session_destroy
();
?>
取消某个session变量在php4.2以上还有BUG.



注意:

1:在调用Session_Start()之前不能有任何输出.例如下面是错误的.
==========================================
1行
2行
<?PHP
3行 Session_Start
();
//之前在第一行已经有输出
4行
.....
5行 ?>
==========================================


提示1:

凡是出现"........headers already sent..........",就是Session_Start()之前向浏览器输出信息.
去掉输出就正常,(COOKIE也会出现这种错误,错误原因一样)

提示2:

如果你的Session_Start()放在循环语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:
1行 <?PHP Ob_Start();
?>
........这里是你的程序......



2:这是什么错误

Warning: session_start(): open(/tmp\sess_7d190aa36b4c5ec13a5c1649cc2da23f, O_RDWR) failed:....
因为你没有指定session文件的存放路径.

解决方法:
(1)在c盘建立文件夹tmp
(2)打开php.ini,找到session.save_path,修改为session.save_path= "c:/tmp"



4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失


CODE:[Copy to clipboard]
<?php
$Var
="hello php";
//修改为$Var=" hello php";试试得到什么结果
$post= "receive.php?Name=".$Var
;
header("location:$post"
);
?>
receive.php的内容:


CODE:[Copy to clipboard]
<?PHP
Echo "<pre>"
;
Echo
$_GET["Name"
];
Echo
"</pre>"
;
?>
正确的方法是:


CODE:[Copy to clipboard]
<?php
$Var
="hello php"
;
$post= "receive.php?Name=".urlencode($Var
);
header("location:$post"
);
?>
在接收页面你不需要使用Urldecode(),变量会自动编码.


5:如何截取指定长度汉字而不会出现以"?>"结尾,超出部分以"..."代替


一般来说,要截取的变量来自Mysql,首先要保证那个字段长度要足够长,一般为char(200),可以保持100个汉字,包括标点.


CODE:[Copy to clipboard]
<?php
<?
PHP
$str
="这个字符好长呀,^_^"
;
$Short_Str=showShort($str,4);
//截取前面4个汉字,结果为:这个字符...
Echo "$Short_Str"
;
Function
csubstr($str,$start,$len
)
{
$strlen=strlen($str
);
$clen=0
;
for(
$i=0;$i<$strlen;$i++,$clen
++)
{
if (
$clen>=$start+$len
)
break;
if(
ord(substr($str,$i,1))>0xa0
)
{
if (
$clen>=$start
)
$tmpstr.=substr($str,$i,2
);
$i
++;
}
else
{
if (
$clen>=$start
)
$tmpstr.=substr($str,$i,1
);
}
}

return
$tmpstr
;
}
Function
showShort($str,$len
)
{
$tempstr = csubstr($str,0,$len
);
if (
$str<>$tempstr
)
$tempstr .= "...";
//要以什么结尾,修改这里就可以.

return $tempstr
;
}
?>

6:规范你的SQL语句


在表格,字段前面加上"`",这样就不会因为误用关键字而出现错误,
当然我并不推荐你使用关键字.

例如
$Sql="INSERT INTO`xltxlm`(`author`,`title`,`id`,`content`,`date`) VALUES ('xltxlm', 'use`', 1, 'criterion your sql string ', '2003-07-11 00:00:00')"

"`"怎么输入? 在TAB键上面.


7:如何使Html/PHP格式的字符串不被解释,而是照原样显示



CODE:[Copy to clipboard]
<?PHP
$str
="<h1>PHP</h1>"
;
Echo
"被解释过的: ".$str."<br>经过处理的:"
;
Echo
htmlentities(nl2br($str
));
?>

8:怎么在函数里取得函数外的变量值



CODE:[Copy to clipboard]
<?PHP
$a
="PHP"
;
foo
();
Function
foo
()
{
global
$a;
//删除这里看看是什么结果
Echo "$a"
;
}
?>

9:我怎么知道系统默认支持什么函数



CODE:[Copy to clipboard]
<?php
$arr
= get_defined_functions
();
Function
php
() {
}
echo
"<pre>"
;
Echo
"这里显示系统所支持的所有函数,和自定以函数phpn"
;
print_r($arr
);
echo
"</pre>"
;
?>

10:如何比较两个日期相差几天



CODE:[Copy to clipboard]
<?PHP
$Date_1
="2003-7-15";
//也可以是:$Date_1="2003-6-25 23:29:14";
$Date_2="1982-10-1"
;
$Date_List_1=explode("-",$Date_1
);
$Date_List_2=explode("-",$Date_2
);
$d1=mktime(0,0,0,$Date_List_1[1],$Date_List_1[2],$Date_List_1[0
]);
$d2=mktime(0,0,0,$Date_List_2[1],$Date_List_2[2],$Date_List_2[0
]);
$Days=round(($d1-$d2)/3600/24
);
Echo
"偶已经奋斗了 $Days 天^_^"
;
?>

11:为什么我升级PHP后,原来的程序出现满屏的 Notice: Undefined variable:


这是警告的意思,由于变量未定义引起的.
打开php.ini,找到最下面的error_reporting,修改为error_reporting = E_ALL & ~E_NOTICE

对于Parse error错误
error_reporting(0)无法关闭.
如果你想关闭任何错误提示,打开php.ini,找到display_errors,设置为display_errors = Off.以后任何错误都不会提示.

那什么是error_reporting?



12:我想在每个文件最前,最后面都加上一文件.但一个一个添加很麻烦

1:打开php.ini文件
设置 include_path= "c:"

2:写两个文件
auto_prepend_file.php 和 auto_append_file.php 保存在c盘,他们将自动依附在每个php文件的头部和尾部.

3:在php.ini中找到:
Automatically add files before or after any PHP document.
auto_prepend_file = auto_prepend_file.php;依附在头部
auto_append_file = auto_append_file.php;依附在尾部

以后你每个php文件就相当于


CODE:[Copy to clipboard]
<?php
Include "auto_prepend_file.php"
;

.......
//这里是你的程序


Include "auto_append_file.php"
;
?>

13:如何利用PHP上传文件



CODE:[Copy to clipboard]<html><head>
<title>上载文件表单</title></head>
<body>
<form enctype="multipart/form-data" action="" method="post">
请选择文件: <br>
<input name="upload_file" type="file"><br>
<input type="submit" value="上传文件">
</form>
</body>
</html>

<?
$upload_file
=$_FILES['upload_file']['tmp_name'
];
$upload_file_name=$_FILES['upload_file']['name'
];

if(
$upload_file
){
$file_size_max = 1000*1000;
// 1M限制文件上传最大容量(bytes)
$store_dir = "d:/";
// 上传文件的储存位置
$accept_overwrite = 1;
//是否允许覆盖相同文件
// 检查文件大小
if ($upload_file_size > $file_size_max
) {
echo
"对不起,你的文件容量大于规定"
;
exit;
}

// 检查读写文件
if (file_exists($store_dir . $upload_file_name) && !$accept_overwrite
) {
Echo
"存在相同文件名的文件"
;
exit;
}

//复制文件到指定目录
if (!move_uploaded_file($upload_file,$store_dir.$upload_file_name
)) {
echo
"复制文件失败"
;
exit;
}

}

Echo
"<p>你上传了文件:"
;
echo
$_FILES['upload_file']['name'
];
echo
"<br>"
;
//客户端机器文件的原名称。

Echo "文件的 MIME 类型为:"
;
echo
$_FILES['upload_file']['type'
];
//文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。
echo "<br>"
;

Echo
"上传文件大小:"
;
echo
$_FILES['upload_file']['size'
];
//已上传文件的大小,单位为字节。
echo "<br>"
;

Echo
"文件上传后被临时储存为:"
;
echo
$_FILES['upload_file']['tmp_name'
];
//文件被上传后在服务端储存的临时文件名。
echo "<br>"
;


$Erroe=$_FILES['upload_file']['error'
];
switch(
$Erroe
){
case
0
:
Echo
"上传成功"
; break;
case
1
:
Echo
"上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值."
; break;
case
2
:
Echo
"上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。"
; break;
case
3
:
Echo
"文件只有部分被上传"
;break;
case
4
:
Echo
"没有文件被上传"
;break;
}
?>

14:如何配置GD库


下面是我的配置过程
1:用dos命令(也可以手动操作,拷贝dlls文件夹里所有dll文件到system32目录下) copy c:\php\dlls\*.dll c:\windows\system32\
2:打开php.ini
设置extension_dir = "c:/php/extensions/";
3:
extension=php_gd2.dll;把extension前面的逗号去掉,如果没有php_gd2.dll,php_gd.dll也一样,保证确实存在这一文件c:/php/extensions/php_gd2.dll
4:运行下面程序进行测试


CODE:[Copy to clipboard]
<?php
Ob_end_flush
();
//注意,在此之前不能向浏览器输出任何信息,要注意是否设置了 auto_prepend_file.
header ("Content-type: image/png"
);
$im = @imagecreate (200, 100
)
or die (
"无法创建图像"
);
$background_color = imagecolorallocate ($im, 0,0, 0
);
$text_color = imagecolorallocate ($im, 230, 140, 150
);
imagestring ($im, 3, 30, 50, "A Simple Text String", $text_color
);
imagepng ($im
);
?>
点击这里查看结果



15:什么是UBB代码


UBB代码是HTML的一个变种,是Ultimate Bulletin Board (国外一个BBS程序,国内也有不少地方使用这个程序)采用的一种特殊的TAG.
即使禁止使用 HTML,你也可以用 UBBCode? 来实现.也许你更希望使用 UBBCode? 而不是 HTML, 即使论坛允许使用 HTML, 因为使用起来代码较少也更安全.

Q3boy的UBB里面付有例子,可以直接运行测试


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。

方法四
  和方法三一样,只是使用了REPLACE语句
  mysql> REPLACE INTO mysql.user (Host,User,Password)
  VALUES('%','jeffrey',PASSWORD('biscuit'));
  mysql> FLUSH PRIVILEGES

方法五
  使用SET PASSWORD语句,
  mysql> SET PASSWORD FOR jeffrey@"%" = PASSWORD('biscuit');
  你也必须使用PASSWORD()函数,
  但是不需要使用FLUSH PRIVILEGES。

方法六
  使用GRANT ... IDENTIFIED BY语句
  mysql> GRANT USAGE ON *.* TO jeffrey@"%" IDENTIFIED BY 'biscuit';
  这里PASSWORD()函数是不必要的,也不需要使用FLUSH PRIVILEGES。

注意: PASSWORD() [不是]以在Unix口令加密的同样方法施行口令加密。


17:我想知道他是通过哪个网站连接到本页



CODE:[Copy to clipboard]
<?php
//必须通过超级连接进入才有输出
Echo $_SERVER['HTTP_REFERER'
];
?>

18:数据放入数据库和取出来显示在页面需要注意什么

入库时
$str=addslashes($str);
$sql="insert into `tab` (`content`) values('$str')";
出库时
$str=stripslashes($str);
显示时
$str=htmlspecialchars(nl2br($str)) ;





19:如何读取当前地址栏信息



CODE:[Copy to clipboard]
<?php
$s
="http://{$_SERVER['HTTP_HOST']}:{$_SERVER["SERVER_PORT"]}{$_SERVER['scrīpt_NAME']}"
;
$se=''
;
foreach (
$_GET as $key => $value
) {
$se.=$key."=".$value."&"
;
}
$se=Preg_Replace("/(.*)&$/","$1",$se
);
$se?$se="?".$se:""
;
echo
$s."?$se"
;
?>

20:我点击后退按钮,为什么之前填写的东西不见

这是因为你使用了session.
解决办法:


CODE:[Copy to clipboard]
<?php
session_cache_limiter
('private, must-revalidate'
);
session_start
();
...........
..........
?>

21:怎么在图片里显示IP地址



CODE:[Copy to clipboard]
<?
Header
("Content-type: image/png"
);
$img = ImageCreate(180,50
);
$ip = $_SERVER['REMOTE_ADDR'
];
ImageColorTransparent($img,$bgcolor
);
$bgColor = ImageColorAllocate($img, 0x2c,0x6D,0xAF);
// 背景颜色
$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);
//显示背景
ImageTTFText($img,10,0,25,28,$textColor,"d:/windows/fonts/Tahoma.ttf","your ip is".$ip);
// 显示IP
ImagePng($img
);
imagecreatefrompng($img
);
ImageDestroy($img
);
?>

22:如何取得用户的真实IP



CODE:[Copy to clipboard]
<?
function iptype1
() {
if (
getenv("HTTP_CLIENT_IP"
)) {
return
getenv("HTTP_CLIENT_IP"
);
}
else {
return
"none"
;
}
}
function
iptype2
() {
if (
getenv("HTTP_X_FORWARDED_FOR"
)) {
return
getenv("HTTP_X_FORWARDED_FOR"
);
}
else {
return
"none"
;
}
}
function
iptype3
() {
if (
getenv("REMOTE_ADDR"
)) {
return
getenv("REMOTE_ADDR"
);
}
else {
return
"none"
;
}
}
function
ip
() {
$ip1 = iptype1
();
$ip2 = iptype2
();
$ip3 = iptype3
();
if (isset(
$ip1) && $ip1 != "none" && $ip1 != "unknown"
) {
return
$ip1
;
}
elseif (isset(
$ip2) && $ip2 != "none" && $ip2 != "unknown"
) {
return
$ip2
;
}
elseif (isset(
$ip3) && $ip3 != "none" && $ip3 != "unknown"
) {
return
$ip3
;
}
else {
return
"none"
;
}
}

Echo
ip
();
?>

23:如何从数据库读取三天内的所有记录

首先表格里要有一个DATETIME字段记录时间,
格式为'2003-7-15 16:50:00'

SELECT * FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) <= 3;


24:如何远程链接Mysql数据库


在增加用户的mysql表里有一个host字段,修改为"%",或者指定允许连接的ip地址,这样,你就可以远程调用了。

$link=mysql_connect("192.168.1.80:3306","root","");


25:正则到底怎么用

点击这里
正则表达式中的特殊字符


26:用Apache后,主页出现乱码


方法一:
AddDefaultCharset ISO-8859-1 改为 AddDefaultCharset off

方法二:
AddDefaultCharsetGB2312
========================================================
tip:
大家贴代码时GB2312会被解释成??????

改成这样就不会
GB2312

========================================================

暂时写到这里,由于贴子过于分散,不便于阅读,我集中了一下,没有对内容进行分类,希望对你有用.
以后还有问题我会跟贴,不再编辑此贴


评论(0) | 引用(0) | 阅读(165)
发表评论
昵称 [注册]
密码 游客无需密码
网址
电邮
打开HTML 打开UBB 打开表情 隐藏 记住我