php常见问题和解决方法.doc_第1页
php常见问题和解决方法.doc_第2页
php常见问题和解决方法.doc_第3页
php常见问题和解决方法.doc_第4页
php常见问题和解决方法.doc_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1:为什么我得不到变量我在一网页向另一网页POST数据name,为什么输出$name时却得不到任何值?在PHP4.2以后的版本中register_global默认为off若想取得从另一页面提交的变量:方法一:在PHP.ini中找到register_global,并把它设置为on.方法二:在接收网页最前面放上这个extract($_POST);extract($_GET);(注意extract($_SESSION)前必须要有Session_Start().方法三:一个一个读取变量$a=$_GETa;$b=$_POSTb等,这种方法虽然麻烦,但比较安全.2:调试你的程序在运行时必须知道某个变量为何值。我是这样做的,建立一文件debug.php,其内容如下:PHP代码:-?PHPOb_Start();Session_Start();Echo;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付值很简单,如:PHP代码:-在php4.2之后,可以为session直接付值:PHP代码:-取消session可以这样:PHP代码:-取消某个session变量在php4.2以上还有BUG.注意:1:在调用Session_Start()之前不能有任何输出.例如下面是错误的.=1行2行=提示1:凡是出现.headersalreadysent.,就是Session_Start()之前向浏览器输出信息.去掉输出就正常,(COOKIE也会出现这种错误,错误原因一样)提示2:如果你的Session_Start()放在循环语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:1行.这里是你的程序.2:这是什么错误Warning:session_start():open(/tmpsess_7d190aa36b4c5ec13a5c1649cc2da23f,O_RDWR)failed:.因为你没有指定session文件的存放路径.解决方法:(1)在c盘建立文件夹tmp(2)打开php.ini,找到session.save_path,修改为session.save_path=c:/tmp4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失PHP代码:-receive.php的内容:PHP代码:-?PHPEcho;Echo$_GETName;Echo;?-正确的方法是:PHP代码:-在接收页面你不需要使用Urldecode(),变量会自动编码.5:如何截取指定长度汉字而不会出现以?结尾,超出部分以.代替一般来说,要截取的变量来自Mysql,首先要保证那个字段长度要足够长,一般为char(200),可以保持100个汉字,包括标点.PHP代码:-?PHP$str=这个字符好长呀,_;$Short_Str=showShort($str,4);/截取前面4个汉字,结果为:这个字符.Echo$Short_Str;Functioncsubstr($str,$start,$len)$strlen=strlen($str);$clen=0;for($i=0;$i=$start+$len)break;if(ord(substr($str,$i,1)0xa0)if($clen=$start)$tmpstr.=substr($str,$i,2);$i+;elseif($clen=$start)$tmpstr.=substr($str,$i,1);return$tmpstr;FunctionshowShort($str,$len)$tempstr=csubstr($str,0,$len);if($str$tempstr)$tempstr.=.;/要以什么结尾,修改这里就可以.return$tempstr;-6:规范你的SQL语句在表格,字段前面加上,这样就不会因为误用关键字而出现错误,当然我并不推荐你使用关键字.例如$Sql=INSERTINTOxltxlm(author,title,id,content,date)VALUES(xltxlm,use,1,criterionyoursqlstring,2003-07-1100:00:00)怎么输入?在TAB键上面.7:如何使Html/PHP格式的字符串不被解释,而是照原样显示PHP代码:-?PHP$str=PHP;Echo被解释过的:.$str.经过处理的:;Echohtmlentities(nl2br($str);?-8:怎么在函数里取得函数外的变量值PHP代码:-9:我怎么知道系统默认支持什么函数PHP代码:-?php$arr=get_defined_functions();Functionphp()echo;Echo这里显示系统所支持的所有函数,和自定以函数phpn;print_r($arr);echo;?-10:如何比较两个日期相差几天PHP代码:-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文件就相当于PHP代码:-13:如何利用PHP上传文件PHP代码:-上载文件表单请选择文件:$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$_FILESupload_filename;echo;/客户端机器文件的原名称。Echo文件的MIME类型为:;echo$_FILESupload_filetype;/文件的MIME类型,需要浏览器提供该信息的支持,例如“image/gif”。echo;Echo上传文件大小:;echo$_FILESupload_filesize;/已上传文件的大小,单位为字节。echo;Echo文件上传后被临时储存为:;echo$_FILESupload_filetmp_name;/文件被上传后在服务端储存的临时文件名。echo;$Erroe=$_FILESupload_fileerror;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:phpdlls*.dllc:windowssystem322:打开php.ini设置extension_dir=c:/php/extensions/;3:extension=php_gd2.dll;把extension前面的逗号去掉,如果没有php_gd2.dll,php_gd.dll也一样,保证确实存在这一文件c:/php/extensions/php_gd2.dll4:运行下面程序进行测试PHP代码:-点击这里查看结果 0 我要推荐 作者:5ibc专家分:150会员信息发短消息所属博客发表时间:2006-10-14 14:22:00 回复引用 1楼 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权限:方法三mysqlINSERTINTOmysql.user(Host,User,Password)VALUES(%,jeffrey,PASSWORD(biscuit);mysqlFLUSHPRIVILEGES确切地说这是在增加一个用户,用户名为jeffrey,密码为biscuit。在mysql中文参考手册里有这个例子,所以我也就写出来了。注意要使用PASSWORD函数,然后还要使用FLUSHPRIVILEGES。方法四和方法三一样,只是使用了REPLACE语句mysqlREPLACEINTOmysql.user(Host,User,Password)VALUES(%,jeffrey,PASSWORD(biscuit);mysqlFLUSHPRIVILEGES方法五使用SETPASSWORD语句,mysqlSETPASSWORDFORjeffrey%=PASSWORD(biscuit);你也必须使用PASSWORD()函数,但是不需要使用FLUSHPRIVILEGES。方法六使用GRANT.IDENTIFIEDBY语句mysqlGRANTUSAGEON*.*TOjeffrey%IDENTIFIEDBYbiscuit;这里PASSWORD()函数是不必要的,也不需要使用FLUSHPRIVILEGES。注意:PASSWORD()不是以在Unix口令加密的同样方法施行口令加密。17:我想知道他是通过哪个网站连接到本页PHP代码:-18:数据放入数据库和取出来显示在页面需要注意什么入库时$str=addslashes($str);$sql=insertintotab(content)values($str);出库时$str=stripslashes($str);显示时$str=htmlspecialchars(nl2br($str);19:如何读取当前地址栏信息PHP代码:-$value)$se.=$key.=.$value.&;$se=Preg_Replace(/(.*)&$/,$1,$se);$se?$se=?.$se:;echo$s.?$se;?-20:我点击后退按钮,为什么之前填写的东西不见这是因为你使用了session.解决办法:PHP代码:-21:怎么在图片里显示IP地址PHP代码:- 作者:5ibc专家分:150会员信息发短消息所属博客发表时间:2006-10-14 14:23:00 回复引用 2楼 22:如何取得用户的真实IPPHP代码:-23:如何从数据库读取三天内的所有记录首先表格里要有一个DATETIME字段记录时间,格式为2003-7-1516

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论