您的位置:首页 > 编程语言 > PHP开发

Php部分常见问题总结

2004-07-30 00:26 1386 查看
本文转载自http://blog.csdn.net/decolee/archive/2004/07/25/51288.aspx
Php部分常见问题总结
若有出错地方或者你有更好的想法,欢迎跟贴.

在提问题前请先仔细查阅PHP手册,MYSQL手册以及PHPINFO里面的设置
另外希望你读一下
PHP编程标准

PHP手册下载地址

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,其内容如下:
"
;

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

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

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

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

然后在php.ini中设置:include_path="c:/php",并将debug.php放在此文件夹,
以后就可以在每个网页里包含此文件,查看得到的变量名和值.

3:如何使用session

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

为session付值很简单,如:



在php4.2之后,可以为session直接付值:

取消session可以这样:


取消某个session变量在php4.2以上还有BUG.

注意:

1:在调用Session_Start()之前不能有任何输出.例如下面是错误的.

==========================================
1行
2行<?PHP
3行Session_Start();//之前在第一行已经有输出
4行.....
5行?>
==========================================

提示1:

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

提示2:

如果你的Session_Start()放在循环语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:
1行<?PHPOb_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:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失



receive.php的内容:
"
;
Echo   $_GET["Name"];
Echo"
";
?>

正确的方法是:


在接收页面你不需要使用Urldecode(),变量会自动编码.

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

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



6:规范你的SQL语句


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

例如
$Sql="INSERTINTO`xltxlm`(`author`,`title`,`id`,`content`,`date`)VALUES('xltxlm','use`',1,'criterionyoursqlstring','2003-07-1100:00:00')"

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


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

PHP

";
Echo"被解释过的:".$str."
经过
4000
处理的:";
Echo   htmlentities(nl2br($str));
?>




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




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

"
;
Echo   "这里显示系统所支持的所有函数,和自定以函数php/n";
print_r($arr);
echo   "
";
?>

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



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


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

对于Parseerror错误
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中找到:
AutomaticallyaddfilesbeforeorafteranyPHPdocument.
auto_prepend_file=auto_prepend_file.php;依附在头部
auto_append_file=auto_append_file.php;依附在尾部

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



13:如何利用PHP上传文件


请选择文件:


<?
$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   "
你上传了文件:"

;
echo  $_FILES['upload_file']['name'];
echo"
";
//客户端机器文件的原名称。

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

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

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

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



14:如何配置GD库


下面是我的配置过程
1:用dos命令(也可以手动操作,拷贝dlls文件夹里所有dll文件到system32目录下)copyc:/php/dlls/*.dllc:/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:运行下面程序进行测试


点击这里查看结果


15:什么是UBB代码


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

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


16:我想修改MySQL的用户,密码

首先要声明一点,大部分情况下,修改MySQL是需要有mysql里的root权限的,
所以一般用户无法更改密码,除非请求管理员.

方法一
  使用phpmyadmin,这是最简单的了,修改mysql库的user表,
  不过别忘了使用PASSWORD函数。

方法二
  使用mysqladmin,这是前面声明的一个特例。
  mysqladmin-uroot-ppasswordmypasswd
  输入这个命令后,需要输入root的原密码,然后root的密码将改为mypasswd。
  把命令里的root改为你的用户名,你就可以改你自己的密码了。
  当然如果你的mysqladmin连接不上mysqlserver,或者你没有办法执行mysqladmin,
  那么这种方法就是无效的。
  而且mysqladmin无法把密码清空。

下面的方法都在mysql提示符下使用,且必须有mysql的root权限:
  方法三
  mysql>INSERTINTOmysql.user(Host,User,Password)
  VALUES('%','jeffrey',PASSWORD('biscuit'));
  mysql>FLUSHPRIVILEGES
  确切地说这是在增加一个用户,用户名为jeffrey,密码为biscuit。
  在《mysql中文参考手册》里有这个例子,所以我也就写出来了。
  注意要使用PASSWORD函数,然后还要使用FLUSHPRIVILEGES。

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

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

方法六
  使用GRANT...IDENTIFIEDBY语句
  mysql>GRANTUSAGEON*.*TOjeffrey@"%"IDENTIFIEDBY'biscuit';
  这里PASSWORD()函数是不必要的,也不需要使用FLUSHPRIVILEGES。

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


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





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

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


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





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

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



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




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




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


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

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


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


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

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


25:正则到底怎么用

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


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


方法一:
AddDefaultCharsetISO-8859-1改为AddDefaultCharsetoff

方法二:
AddDefaultCharsetGB2312发表于2004年07月25日2:36PM
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  php session path mysql 编程 c