变量虚拟主机问题之用PHP 4.2书写安全的脚本

php虚拟主机  时间:2020-12-28  阅读:()

虚拟主机问题之用PHP4.2书写安全的脚本

虚拟主机问题之用PHP4.2书写安全的脚本

在很长一段时间内 PHP作为服务

在很长一段时间内 PHP作为服务器端脚本语言的最大卖点之一就是会为从表单提交的值自动建立一个全局变量。在PHP4.1中 PHP 的制作者们推荐了一个访问提交数据的替代手段。在PHP4.2中他们取消了那种老的做法正如我将在这篇文章中解释的那样作出这样的变化的目的是出于安全性的考虑。我们将研究PHP在处理表单提交及其它数据时的新的做法并说明为什么这样做会提高代码的安全性。

这里有什么错误

看看下面的这段PHP脚本它用来在输入的用户名及口令正确时授权访问一个Web页面 <?php

//检查用户名及口令if($username==‘kevin’and$password==’secret’)

$authorized=true;

?>

<?phpif( !$authorized):?>

< ! –未授权的用户将在这里给予提示–>

<p>Pleaseenteryourusernameandpassword:</p>

<formaction=”<?=$PHP_SELF?>”method=”POST”>———————————————————————————————————————————————

<p>Username:<inputtype=”text”name=”username”/><br/>

Password:<inputtype=”password”name=”password”/><br/>

<inputtype=”submit”/></p>

</form>

<?phpelse:?>

< ! –有安全要求的HTML内容–>

<?phpendif;?>

OK我相信大约半数的读者会不屑的说“太愚蠢了–我不会犯这样的错误的”但是我保证有很多的读者会想“嗨没什么问题啊我也会这么写的”当然还会有少数人会对这个问题感到困惑( “什么是PHP ” ) 。 PHP被设计为一个“好的而且容易的”脚本语言初学者可以在很短的时间内学会使用它它也应该能够避免初学者犯上面的错误。

再回到刚才的问题上面的代码中存在的问题是你可以很容易地获得访问的权力而不需要提供正确的用户名和口令。只在要你的浏览器的地址栏的最后添加?authorized=1。因为PHP会自动地为每一个提交的值创建一个变量—不论是来自动一个提交的表单、 URL查询字符串还是一个cookie—这会将$authorized设置为1这样一个未授权的用户也可以突破安全限制。

———————————————————————————————————————————————

那么怎么简单地解决这个问题呢只要在程序的开头将$authorized默认设置为false。这个问题就不存在了 $authorized是一个完全在程序代码中创建的变量但是为什么开发者得为每一个恶意的用户提交的变量担心呢

PHP4.2作了什么改变

在PHP4.2中新安装的PHP中的register_globals选项默认为关闭因此EGPCS值(EGPCS是Environment、Get、 Post、 Cookies、 Server 的缩写—这是PHP中外部变量来源的全部范围)不会被作为全局变量来创建。当然这个选项还可以通过手工来开启但是PHP的开发者推荐你将其关闭。要贯彻他们的意图你需要使用其它的方法来获取这些值。从PH P4.1开始 EGPCS值就可以从一组指定的数组中获得

$_ENV—包含系统环境变量

$_G ET—包含查询字符串中的变量 以及提交方法为G ET的表单中的变量

$_POST—包含提交方式为POST的表单中的变量

$_COOKIE—包含所有cookie变量

$_SERVER—包含服务器变量例如HTTP_USER_AGENT

$_REQUEST—包含$_GET、 $_POST和$_COOKI E的全部内容

$_SESSION—包含所有已注册的session变量

在PHP4.1之前 当开发者关闭register_globals选项(这也被考虑为提高PHP性能的一种方法)后必须使用诸如$HTTP_GET_VARS这样的令人讨厌的名字来获取这些变量。这些新的变量名不仅仅短而且———————————————————————————————————————————————

它们还有其他优点。

首先让我们在PHP4.2中(也就是说关闭register_globals选项)重写上面提到的代码 <?php

$username=$_REQUEST['username'];

$password=$_REQUEST['password'];

//检查用户名和口令if($username==‘kevin’and$password==’secret’)

$authorized=true;

?>

<?phpif( !$authorized):?>

< ! –未授权的用户将在这里给予提示–>

<p>Pleaseenteryourusernameandpassword:</p>

<formaction=”<?=$PHP_SELF?>”method=”POST”><p>Username:<inputtype=”text”name=”username”/><br/>

Password:<inputtype=”password”name=”password”/><br/>

<inputtype=”submit”/></p>

</form>

<?phpelse:?>

< ! –有安全要求的HTML内容–>

———————————————————————————————————————————————

<?phpendif;?>

正如你看到的我所需要做的只是在代码的开始增加下面两行

$username=$_REQUEST['username'];

$password=$_REQUEST['password'];

因为我们希望用户名和密码是由用户提交的所以我们从$_REQUEST数组中获取这些值。使用这个数组使得用户可以自由选择传递方式通过URL查询字符串(例如允许用户创建书签时自动输入他们的证书)、通过一个提交的表单或者是通过一个cookie。如果你想要限制只能通过表单提交证书(更精确地说是通过HTTP POST请求)你可以使用$_PO ST数组

$username=$_POST['username'];

$password=$_POST['password'] ;

除了“引入”这两个变量以外程序代码没有任何改变。简单地关闭register_globals选项促使开发者更进一步了解哪些数据是来自外部的(不可信任的)资源。

请注意这里还有一个小问题 PHP中默认的error_reporting设置仍然是E_ALL&~E_NOTICE因此如果“username”和“password”这两个值没有被提交试图从$_REQUEST数组或$_POST数组中获得这两个值并不会招致任何错误信息。如晨不你的PHP程序需要

严格的错误检查你还需要增加一些代码以首先检查这些变量。

但是这是不是意味着更多的输入

是的在象上面这样的简单程序中使用PHP4.2常常会增加输———————————————————————————————————————————————

入量。但是还是看看光明的一面吧—你的程序终究是更安全了

不过认真的说 PHP的设计者并没有完全忽视你的痛苦。在这些新数组中有一个特殊的其它所PHP变量都不具备的特征它们是完全的全局变量。这对你有什么帮助呢让我们先对我们的示例进行一下扩充。

为了使得站点中的多个页面可以使用用户名/口令论证我们将我们用户认证程序写到一个include文件(protectme.php)中

<?php/*protectme.php*/functionauthorize_user($authuser,$authpass)

{

$username=$_POST['username'];

$password=$_POST['password'];

//检查用户名和口令if($username!=$authuseror$password!=$authpass):

?>

< ! –未授权的用户将在这里给予提示–>

<p>Pleaseenteryourusernameandpassword:</p>

<formaction=”<?=$PHP_SELF?>”method=”POST”><p>Username:<inputtype=”text”name=”username”/><br/>

———————————————————————————————————————————————

Password:<inputtype=”password”name=”password”/><br/>

<inputtype=”submit”/></p>

</form>

<?php exit();endif;

}

?>

现在我们刚才的页面看上去将是这样的

<?php require(’protectme.php’);authorize_user(’kevin’,’secret’);

?>

< ! –有安全要求的HTML内容–>

很简单很清晰明了对不对现在是考验你的眼力和经验的时候了—在authorize_user函数中少了什么

在函数中没有申明$_POST是一个全局变量在ph p4.0中当register_globals开启时你需要增加一行代码以在函数中获取$username和$password变量functionauthorize_user($authuser,$authpass)

{global$username,$password;

———————————————————————————————————————————————

在PHP中和其它具有类似语法的语言不同函数外的变量在函数中不能自动获得你需

要象上面所说明的那样增加一行以指定其来自global范围。

在PHP4.0中 当关闭register_globals以提供安全性时你可以使用$HTTP_POST_VARS数组以获得你的表单提交的值但是你还是需要从全局范围导入这个数组functionauthorize_user($authuser,$authpass)

{global$HTTP_POST_VARS;

$username=$HTTP_POST_VARS['username'];

$password=$HTTP_POST_VARS['password'];

但是在PH P4.1及以后的版本中特殊的$_POST变量(以及上面提到的其它变量)可以在所有范围内使用。这就是不需要在函数中申明$_POST变量是一个全局变量的原因functionauthorize_user($authuser,$authpass)

{

$username=$_POST['username'];

$password=$_POST['password'];

这对session有什么影响

特殊的$_SESSION数组的引入实际上有助于简化session代码。你不需要将sess ion变量申明为全局变量然后再去留意哪些变量被注———————————————————————————————————————————————

册了你现在可以简单地从$_SESSION['varname']中引用你所有的session变量。

现在让我们来看看另一个用户认证的例子。这一次我们使用sessions以标志一个在你的网站继续逗留的用户已经经过了用户认证。首先我们来看看PHP4.0版本(开启register_globals) 

<?php session_start();if($username==‘kevin’and$password==’secret’)

{

$authorized=true;session_register(’authorized’);

}

?>

<?phpif( !$authorized):?>

< ! –显示HTML表单以提示用户登录–>

<?phpelse:?>

< ! –有安全要求的HTML内容–>

<?phpendif;?>

和刚开始的程序一样这个程序也存在安全漏洞在URL的最后加上?authorized=1可以绕过安全措施直接访问页面内容。开发者可以将$authorized视为一个session变量而忽视了可以很容易地通过用户输入设置同样的变量。

———————————————————————————————————————————————

Ceranetworks顶级合作伙伴 香港E3 16G 299元 香港E5 32G 650元 美国E3 16G 650元

提速啦(www.tisula.com)是赣州王成璟网络科技有限公司旗下云服务器品牌,目前拥有在籍员工40人左右,社保在籍员工30人+,是正规的国内拥有IDC ICP ISP CDN 云牌照资质商家,2018-2021年连续4年获得CTG机房顶级金牌代理商荣誉 2021年赣州市于都县创业大赛三等奖,2020年于都电子商务示范企业,2021年于都县电子商务融合推广大使。资源优势介绍:Ceranetwo...

HostKvm:香港国际/韩国KVM夏季7折,2G内存套餐月付5.95美元起

HostKvm是一家成立于2013年的国外主机服务商,主要提供基于KVM架构的VPS主机,可选数据中心包括日本、新加坡、韩国、美国、中国香港等多个地区机房,均为国内直连或优化线路,延迟较低,适合建站或者远程办公等。目前商家发布了夏季特别促销活动,针对香港国际/韩国机房VPS主机提供7折优惠码,其他机房全场8折,优惠后2GB内存套餐月付5.95美元起。下面分别列出几款主机套餐配置信息。套餐:韩国KR...

IMIDC日本多IP服务器$88/月起,E3-123x/16GB/512G SSD/30M带宽

IMIDC是一家香港本土运营商,商家名为彩虹数据(Rainbow Cloud),全线产品自营,自有IP网络资源等,提供的产品包括VPS主机、独立服务器、站群独立服务器等,数据中心区域包括香港、日本、台湾、美国和南非等地机房,CN2网络直连到中国大陆。目前主机商针对日本独立服务器做促销活动,而且提供/28 IPv4,国内直连带宽优惠后每月仅88美元起。JP Multiple IP Customize...

php虚拟主机为你推荐
美国虚拟主机求最优质美国虚拟主机推荐?有没有权威国外虚拟主机评测?国际域名国内域名和国际域名的区别全能虚拟主机时代互联的全能云虚拟主机怎么样,稳不稳定,速度怎么样的?全能虚拟主机免费的虚拟主机不可以修改网站?me域名me域名怎么样?jsp虚拟空间请问如何卖掉JSP虚拟主机美国网站空间美国,韩国,香港网站空间重庆网站空间重庆建网站的公司 我司准备建一个好点的网站,求推荐香港虚拟主机虚拟主机大陆的还是香港的好?上海虚拟主机帮忙推荐一下哪里的虚拟主机比较好?
美国虚拟主机 上海虚拟主机 主机域名 双线服务器租用 域名解析文件 ftp空间 主机测评网 linode代购 vmsnap3 2017年万圣节 圣诞节促销 免费全能空间 网站cdn加速 世界测速 网站加速软件 畅行云 镇江高防 网页加速 云服务是什么意思 重庆服务器 更多