PHP温习之二
Posted NICE哥哥
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP温习之二相关的知识,希望对你有一定的参考价值。
1.php包含的超全局变量
(1)$GLOBALS超全局变量组,在php脚本所有的作用域均可以访问到。
<?php $x = 23; $y = 17; function addAction(){
$x = 10; $GLOBALS[‘z‘] = $GLOBALS[‘x‘] + $GLOBALS[‘y‘]; } addAction();
echo $GLOBALS[‘z‘]; //输出:40
echo $GLOBALS[‘x‘]; //输出:23
(2)$_SERVER是与网络有关的全局变量
function getServer(){ echo ‘$_SERVER[\‘GATEWAY_INTERFACE\‘]服务器使用的 CGI 规范的版本:‘.$_SERVER[‘GATEWAY_INTERFACE‘].‘<br/>‘; echo ‘$_SERVER[\‘SERVER_ADDR\‘]当前运行脚本所在的服务器的 IP 地址:‘.$_SERVER[‘SERVER_ADDR‘].‘<br/>‘; echo ‘$_SERVER[\‘SERVER_NAME\‘]当前运行脚本所在的服务器的主机名:‘.$_SERVER[‘SERVER_NAME‘].‘<br/>‘; echo ‘$_SERVER[\‘HTTP_HOST\‘]当前请求头中 Host: 项的内容:‘.$_SERVER[‘HTTP_HOST‘].‘<br/>‘; echo ‘$_SERVER[\‘REMOTE_ADDR\‘]浏览当前页面的用户的 IP 地址:‘.$_SERVER[‘REMOTE_ADDR‘].‘<br/>‘; echo ‘$_SERVER[\‘REMOTE_HOST\‘]浏览当前页面的用户的主机名:‘.$_SERVER[‘REMOTE_HOST‘].‘<br/>‘; echo ‘$_SERVER[\‘REMOTE_PORT\‘]用户机器上连接到 Web 服务器所使用的端口号:‘.$_SERVER[‘REMOTE_PORT‘].‘<br/>‘; echo ‘$_SERVER[\‘SCRIPT_FILENAME\‘]当前执行脚本的绝对路径:‘.$_SERVER[‘SCRIPT_FILENAME‘].‘<br/>‘; } getServer();
输出:
$_SERVER[‘GATEWAY_INTERFACE‘]服务器使用的 CGI 规范的版本:CGI/1.1
$_SERVER[‘SERVER_ADDR‘]当前运行脚本所在的服务器的 IP 地址:127.0.0.2
$_SERVER[‘SERVER_NAME‘]当前运行脚本所在的服务器的主机名:deve.com
$_SERVER[‘HTTP_HOST‘]当前请求头中 Host: 项的内容:deve.com
$_SERVER[‘REMOTE_ADDR‘]浏览当前页面的用户的 IP 地址:127.0.0.1
Notice: Undefined index: REMOTE_HOST in D:\deve\index.php on line 20 $_SERVER[‘REMOTE_HOST‘]浏览当前页面的用户的主机名:
$_SERVER[‘REMOTE_PORT‘]用户机器上连接到 Web 服务器所使用的端口号:60783
$_SERVER[‘SCRIPT_FILENAME‘]当前执行脚本的绝对路径:D:/deve/index.php
(2)$_POST
(3)$_GET
(4)$_REQUEST
(5)$_COOKIE
(6)$_SESSION
(7)$_FILE
$_FILES[‘myFile‘][‘name‘] 客户端文件的原名称 $_FILES[‘myFile‘][‘type‘] 文件的 MIME类型,需要浏览器提供该信息的支持,例如"image/gif" $_FILES[‘myFile‘][‘size‘] 已上传文件的大小,单位为字节 $_FILES[‘myFile‘][‘tmp_name‘] 文件被上传后在服务端储存的临时文件名,一般是系统默认,可以在php.ini的upload_tmp_dir指定,但用 putenv() 函数设置是不起作用的 $_FILES[‘myFile‘][‘error‘] 和该文件上传相关的错误代码,[‘error‘] 是在 PHP 4.2.0版本中增加的,下面是它的说明:
(8)$_ENV保存环境变量的。
2.AJAX优缺点
(1)AJAX的工作原理
Ajax的工作原理相当于在用户和服务器之间加了—个中间层(AJAX引擎),使用户操作与服务器响应异步化。并不是所有的用户请求都提交给服务器,像—些数据验证和数据处理等都交给Ajax引擎自己来做, 只有确定需要从服务器读取新数据时再由Ajax引擎代为向服务器提交请求。
(2)AJAX的优点
<1>.无刷新更新数据。
AJAX最大优点就是能在不刷新整个页面的前提下与服务器通信维护数据。这使得Web应用程序更为迅捷地响应用户交互,并避免了在网络上发送那些没有改变的信息,减少用户等待时间,带来非常好的用户体验。
<2>.异步与服务器通信。
AJAX使用异步方式与服务器通信,不需要打断用户的操作,具有更加迅速的响应能力。优化了Browser和Server之间的沟通,减少不必要的数据传输、时间及降低网络上数据流量。
<3>.前端和后端负载平衡。
AJAX可以把以前一些服务器负担的工作转嫁到客户端,利用客户端闲置的能力来处理,减轻服务器和带宽的负担,节约空间和宽带租用成本。并且减轻服务器的负担,AJAX的原则是“按需取数据”,可以最大程度的减少冗余请求和响应对服务器造成的负担,提升站点性能。
<4>.基于标准被广泛支持。
AJAX基于标准化的并被广泛支持的技术,不需要下载浏览器插件或者小程序,但需要客户允许javascript在浏览器上执行。随着Ajax的成熟,一些简化Ajax使用方法的程序库也相继问世。同样,也出现了另一种辅助程序设计的技术,为那些不支持JavaScript的用户提供替代功能。
<5>.界面与应用分离。
Ajax使WEB中的界面与应用分离(也可以说是数据与呈现分离),有利于分工合作、减少非技术人员对页面的修改造成的WEB应用程序错误、提高效率、也更加适用于现在的发布系统。
(3)AJAX的缺点
<1>.AJAX干掉了Back和History功能,即对浏览器机制的破坏。
<2>.AJAX的安全问题。
AJAX技术给用户带来很好的用户体验的同时也对IT企业带来了新的安全威胁,Ajax技术就如同对企业数据建立了一个直接通道。这使得开发者在不经意间会暴露比以前更多的数据和服务器逻辑。Ajax的逻辑可以对客户端的安全扫描技术隐藏起来,允许黑客从远端服务器上建立新的攻击。还有Ajax也难以避免一些已知的安全弱点,诸如跨站点脚步攻击、SQL注入攻击和基于Credentials的安全漏洞等等。
<3>.对搜索引擎支持较弱。
对搜索引擎的支持比较弱。如果使用不当,AJAX会增大网络数据的流量,从而降低整个系统的性能。
<4>.破坏程序的异常处理机制。
至少从目前看来,像Ajax.dll,Ajaxpro.dll这些Ajax框架是会破坏程序的异常机制的。关于这个问题,曾在开发过程中遇到过,但是查了一下网上几乎没有相关的介绍。后来做了一次试验,分别采用Ajax和传统的form提交的模式来删除一条数据……给我们的调试带来了很大的困难。
<5>.违背URL和资源定位的初衷。
例如,我给你一个URL地址,如果采用了Ajax技术,也许你在该URL地址下面看到的和我在这个URL地址下看到的内容是不同的。这个和资源定位的初衷是相背离的。
<6>.AJAX不能很好支持移动设备。
一些手持设备(如手机、PDA等)现在还不能很好的支持Ajax,比如说我们在手机的浏览器上打开采用Ajax技术的网站时,它目前是不支持的。
<7>.客户端过肥,太多客户端代码造成开发上的成本。
编写复杂、容易出错
;冗余代码比较多(层层包含js文件是AJAX的通病,再加上以往的很多服务端代码现在放到了客户端);破坏了Web的原有标准。
(3)AJAX的适合场景
<1>.表单驱动的交互
<2>.深层次的树的导航
<3>.快速的用户与用户间的交流响应
<4>.类似投票、yes/no等无关痛痒的场景
<5>.对数据进行过滤和操纵相关数据的场景
<6>.普通的文本输入提示和自动完成的场景
(4)AJAX不适用的场景
<1>.部分简单的表单
<2>.搜索
<3>.基本的导航
<4>.替换大量的文本
<5>.对呈现的操纵
以上是关于PHP温习之二的主要内容,如果未能解决你的问题,请参考以下文章