威尼斯城所有登入网址


查找search在$威尼斯城所有登入网址str中的第一次位置从int开始,字符串操作都是一个重要的基础

decode — 对 JSON 格式的字符串进行编码

操作系统威尼斯城所有登入网址:,PHP中的超全局变量

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

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

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

执行环境提交至脚本的变量。类似于旧数组 $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’]等。

echo $_GET[“secret_access”]; // output: true
echo $secret_access; // output:

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;
}

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

系统预定义变量

1、页面之间无法传递变量

get,post,session在最新的php版本中自动全局变量是关闭的,所以要从上一页面取得提交过来得变量要使用$_GET[‘foo’],$_POST[‘foo’],$_SESSION[‘foo’]来得到。当然也可以修改自动全局变量为开(php.ini改为register_globals
= On);考虑到兼容性,还是强迫自己熟悉新的写法比较好。

注: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

执行环境提交至脚本的变量。类似于旧数组 $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’]等。

Note: 当运行于命令行模式时,此数组将不会包含 argv 和 argc
条目;它们已经存在于数组 $_SERVER 中。

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

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

session_start();

3、显示错误信息

当php.ini的display_errors = On并且error_reporting =
E_ALL时,将显示所有的错误和提示,调试的时候最好打开以便纠错,如果你用以前php写法错误信息多半是关于未定义变量的。变量在赋值以前调用会有提示,解决办法是探测或者屏蔽,例如显示$foo,可以if(isset($foo))
echo$foo 或者echo @$foo

自 PHP 4.3.0 起,$_FILES 中的文件信息不再存在于 $_REQUEST 中。

8、isset和empty的区别

两者都是测试变量用的,但是isset是测试变量是否被赋值,而empty是测试一个已经被赋值的变量是否为空。如果一个变量没被赋值就引用在php里是被允许的,但会有notice提示。如果一个变量被赋空值,$foo=””或者$foo=0或者
$foo=false,那么empty($foo)返回真,isset($foo)也返回真,就是说赋空值不会注销一个变量。要注销一个变量,可以用
unset($foo)或者$foo=NULL。

// in previous logic, you set session variable $secret_access = false

10、通过HTTP协议一次上传多个文件的方法

有两个思路,是同一个方法的两种实现。具体程序还需自己去设计

1. 在form中设置多个文件输入框,用数组命名他们的名字,如下:

<form action="" method="post">
<input name="usefile" type="file">
</form>

这样,在服务器端做以下测试

echo "<pre>";
print_r($_FILES);
echo "</pre>";

2. 在form中设置多个文件输入框,但名字不同,如下:

<form action="" method="post">
<input name="usefile_a" type="file">
<input name="usefile_b" type="file">
<input name="usefile_c" type="file">
</form>

在服务器端做同样测试:

echo "<pre>";
print_r($_FILES);
echo "</pre>";

echo $_SESSION[“secret_access”]; // output: false
echo $secret_access; // output: false

4、header already sent

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

$_SERVER
    变量由 web
服务器设定或者直接与当前脚本的执行环境相关联。类似于旧数组
$HTTP_SERVER_VARS 数组(依然有效,但反对使用)。

5、更改php.ini后没有变化

重新启动web server,比如IIS,Apache等等,然后才会应用最新的设置。

6、有时候sql语句不起作用,对数据库操作失败。最简便的调试方法,echo那句sql,看看变量的值是否能得到。

 代码如下

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

当前运行脚本所在服务器主机的名称。如果该脚本运行在一个虚拟主机上,该名称是由那个虚拟主机所设置的值决定。例如,在URL地址为
/test.php $_SERVER[‘SERVER_NAME’] 将会得到 这个结果。

相关文章

No Comments, Be The First!
近期评论
    功能
    网站地图xml地图