2、win32下的session不能正常工作

php.ini默认的session.save_path = /tmp

这显然是linux下的配置,win32下php无法读写session文件导致session无法使用,把它改成一个绝对路径就可以了,例如session.save_path
= c:\windows\temp。

PHP中的超全局变量
从PHP 4.2.0 开始,register_globals 的默认值为
off,这样一来,以前的很多可以直接使用的变量,如 $PHP_SELF
或者你设定的SESSION变量都不能用
“$变量名”的形式访问了,这可能会给你带来很多不变,但却有助于安全性的提高。访问这些变量,你需要使用PHP
超全局变量,如下:
$_SERVER
欧博国际平台,变量由 Web 服务器设定或者直接与当前脚本的执行环境相关联。类似于旧数组
$HTTP_SERVER_VARS
数组。以前的$PHP_SELF对应$_SERVER[‘PHP_SELF’]欧博国际网站,,你可以使用phpinfo来查看你的$_SERVER变量。
$_GET
经由 HTTP GET 方法提交至脚本的变量。类似于旧数组 $HTTP_GET_VARS
数组。
$_POST
经由 HTTP POST 方法提交至脚本的变量。类似于旧数组 $HTTP_POST_VARS
数组。
$_COOKIE
经由 HTTP Cookies 方法提交至脚本的变量。类似于旧数组 $HTTP_COOKIE_VARS
数组。
$_SESSION
当前注册给脚本会话的变量。类似于旧数组 $HTTP_SESSION_VARS 数组。
$_FILES
经由 HTTP POST 文件上传而提交至脚本的变量。类似于旧数组
$HTTP_POST_FILES 数组。
$_ENV

7、include和require的区别

两者没有太大的区别,如果要包含的文件不存在,include提示notice,然后继续执行下面的语句,require提示致命错误并且退出。根据测试,win32平台下它们都是先包含后执行,所以被包含文件里最好不要再有include或require语句,这样会造成目录混乱。或许*nux下情况不同,暂时还没测试。如果一个文件不想被包含多次可以使用include_once或require_once##
读取,写入文档数据:

function r($file_name) {
$filenum=@fopen($file_name,"r");
@flock($filenum,LOCK_SH);
$file_data=@fread($filenum,filesize($file_name));
@fclose($filenum);
return $file_data;
}
function w($file_name,$data,$method="w"){
$filenum=@fopen($file_name,$method);
flock($filenum,LOCK_EX);
$file_data=fwrite($filenum,$data);
fclose($filenum);
return $file_data;
}

执行环境提交至脚本的变量。类似于旧数组 $HTTP_ENV_VARS 数组。

对于$_FILES变量:(文件域字段为“myfile”)
$_FILES[‘myfile’][‘name’]    
客户端机器文件的原名称(包括路径)。
$_FILES[‘myfile’][‘type’]    
文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。
$_FILES[‘myfile’][‘size’]    
已上传文件的大小,单位为字节。
 
$_FILES[‘myfile’][‘tmp_name’]    
文件被上传后在服务端储存的临时文件名(包括路径)。
$_FILES[‘myfile’][‘error’]    
和该文件上传相关的错误代码。[‘error’] 是在 PHP 4.2.0 版本中增加的。
 
当 php.ini 中的 register_globals 被设置为 on 时,$myfile_name 等价于
$_FILES[‘myfile’][‘name’],$myfile_type 等价于
$_FILES[‘myfile’][‘type’]等。

4、header already sent

这个错误通常会在你使用HEADER的时候出现,他可能是几种原因:1,你在使用HEADER前PRING或者ECHO了2.你当前文件前面有空行3.你可能INCLUDE了一个文件,该文件尾部有空行或者输出也会出现这种错误。

这里总结了PHP初学者容易感到困惑的10个问题,供大家参考。

9、mySQL查询语句包含有关键字

php查询mysql的时候,有时候mysql表名或者列名会有关键字,这时候查询会有错误。例如表名是order,查询时候会出错,简单的办法是sql语句里表名或者列名加上`[tab键上面]来加以区别,例如select
* from `order`。

Author

发表评论

电子邮件地址不会被公开。 必填项已用*标注