亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術(shù)文章
文章詳情頁

PHP安全之使用 Register Globals

瀏覽:3日期:2022-09-15 11:46:02

本特性已自 PHP 5.3.0 起廢棄并將自 PHP 5.4.0 起移除。

可能 PHP 中最具爭議的變化就是從 PHP 4.2.0 版開始配置文件中 PHP 指令 register_globals 的默認(rèn)值從 on 改為 off 了。對此選項(xiàng)的依賴是如此普遍以至于很多人根本不知道它的存在而以為 PHP 本來就是這么工作的。本節(jié)會解釋用這個指令如何寫出不安全的代碼,但要知道這個指令本身沒有不安全的地方,誤用才會。

當(dāng) register_globals 打開以后,各種變量都被注入代碼,例如來自 HTML 表單的請求變量。再加上 PHP 在使用變量之前是無需進(jìn)行初始化的,這就使得更容易寫出不安全的代碼。這是個很艱難的抉擇,但 PHP 社區(qū)還是決定默認(rèn)關(guān)閉此選項(xiàng)。當(dāng)打開時,人們使用變量時確實(shí)不知道變量是哪里來的,只能想當(dāng)然。但是 register_globals 的關(guān)閉改變了這種代碼內(nèi)部變量和客戶端發(fā)送的變量混雜在一起的糟糕情況。下面舉一個錯誤使用 register_globals 的例子:

Example #1 錯誤使用 register_globals = on 的例子

<?php // 當(dāng)用戶合法的時候,賦值 $authorized = true if (authenticated_user()) {$authorized = true; } // 由于并沒有事先把 $authorized 初始化為 false, // 當(dāng) register_globals 打開時,可能通過GET auth.php?authorized=1 來定義該變量值 // 所以任何人都可以繞過身份驗(yàn)證 if ($authorized) {include '/highly/sensitive/data.php'; }?>

當(dāng) register_globals = on 的時候,上面的代碼就會有危險了。如果是 off,$authorized 就不能通過如 URL 請求等方式來改變,這樣就好多了,盡管初始化變量是一個良好的編程習(xí)慣。比如說,如果在上面的代碼執(zhí)行之前加入 $authorized = false 的話,無論 register_globals 是 on 還是 off 都可以,因?yàn)橛脩魻顟B(tài)被初始化為未經(jīng)認(rèn)證。

另一個例子是關(guān)于會話的。當(dāng) register_globals = on 的時候,$username 也可以用在下面的代碼中,但要意識到 $username 也可能會從其它途徑進(jìn)來,比如說通過 URL 的 GET。

Example #2 使用會話時同時兼容 register_globals on 和 off 的例子

<?php // 我們不知道 $username 的來源,但很清楚 $_SESSION 是來源于會話數(shù)據(jù) if (isset($_SESSION[’username’])) {echo 'Hello <b>{$_SESSION[’username’]}</b>'; } else {echo 'Hello <b>Guest</b><br />';echo 'Would you like to login?'; }?>

采取相應(yīng)的預(yù)防措施以便在偽造變量輸入的時候給予警告是完全有可能的。如果事先確切知道變量是哪里來的,就可以檢查所提交的數(shù)據(jù)是否是從不正當(dāng)?shù)谋韱翁峤欢鴣怼2贿^這不能保證變量未被偽造,這需要攻擊者去猜測應(yīng)該怎樣去偽造。如果不在乎請求數(shù)據(jù)來源的話,可以使用 $_REQUEST 數(shù)組,它包括了 GET、POST 和 COOKIE 的所有數(shù)據(jù)。

Example #3 探測有害變量

<?php if (isset($_COOKIE[’MAGIC_COOKIE’])) {// MAGIC_COOKIE 來自 cookie// 這樣做是確保是來自 cookie 的數(shù)據(jù) } elseif (isset($_GET[’MAGIC_COOKIE’]) || isset($_POST[’MAGIC_COOKIE’])) {mail('admin@example.com', 'Possible breakin attempt', $_SERVER[’REMOTE_ADDR’]);echo 'Security violation, admin has been alerted.';exit; } else {// 這一次請求中并沒有設(shè)置 MAGIC_COOKIE 變量 }?>

當(dāng)然,單純地關(guān)閉 register_globals 并不代表所有的代碼都安全了。對于每一段提交上來的數(shù)據(jù),都要對其進(jìn)行具體的檢查。永遠(yuǎn)要驗(yàn)證用戶數(shù)據(jù)和對變量進(jìn)行初始化!把error_reporting() 設(shè)為 E_NOTICE 級別可以檢查未初始化的變量。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 亚洲美女黄视频 | 欧美aaa视频 | 欧美一区二区三区精品 | 日韩欧美亚洲综合久久99e | 国产一区二区三区精品视频 | 国产精品一久久香蕉国产线看 | 最新亚洲精品国自产在线 | 日韩欧美一级毛片视频免费 | 日韩毛片欧美一级国产毛片 | 成人手机视频在线观看 | 日韩一级片在线观看 | 爱呦视频在线播放网址 | 成人国产一区二区三区精品 | 免费人成在线观看播放国产 | 日韩专区亚洲精品欧美专区 | 久久香蕉国产观看猫咪3atv | 午夜日韩精品 | 一及黄色毛片 | 久久久久久国产精品免费 | 最新亚洲人成网站在线影院 | 91香焦国产线观看看免费 | 精品无码久久久久久国产 | 国产三级在线免费观看 | 久久久久久久岛国免费观看 | 日韩免费观看一级毛片看看 | 国产在线观看免费 | 久久观看午夜精品 | 国产三级做爰高清视频a | 久久久久久久免费视频 | 欧美日韩专区国产精品 | 国产成人精品一区二三区 | 兔费看全黄三级 | 欧美一级毛片欧美毛片视频 | 日韩一级伦理片 | 精品国产自在在线在线观看 | 免费一级欧美毛片 | 一级做a爰全过程免费视频毛片 | 国产精品久久久久久久久久久威 | 青青操网站 | 国内精品久久久久久久久 | 香蕉成人国产精品免费看网站 |