成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

PHP安全之使用 Register Globals

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

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

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

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

Example #1 錯(cuò)誤使用 register_globals = on 的例子

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

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

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

Example #2 使用會(huì)話(huà)時(shí)同時(shí)兼容 register_globals on 和 off 的例子

<?php // 我們不知道 $username 的來(lái)源,但很清楚 $_SESSION 是來(lái)源于會(huì)話(huà)數(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í)候給予警告是完全有可能的。如果事先確切知道變量是哪里來(lái)的,就可以檢查所提交的數(shù)據(jù)是否是從不正當(dāng)?shù)谋韱翁峤欢鴣?lái)。不過(guò)這不能保證變量未被偽造,這需要攻擊者去猜測(cè)應(yīng)該怎樣去偽造。如果不在乎請(qǐng)求數(shù)據(jù)來(lái)源的話(huà),可以使用 $_REQUEST 數(shù)組,它包括了 GET、POST 和 COOKIE 的所有數(shù)據(jù)。

Example #3 探測(cè)有害變量

<?php if (isset($_COOKIE[’MAGIC_COOKIE’])) {// MAGIC_COOKIE 來(lái)自 cookie// 這樣做是確保是來(lái)自 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 {// 這一次請(qǐng)求中并沒(méi)有設(shè)置 MAGIC_COOKIE 變量 }?>

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

標(biāo)簽: PHP
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美私人免费视频| 91一区二区在线观看| 成人激情av网| 日韩欧美一区二区在线视频| 精品无人区卡一卡二卡三乱码免费卡 | 一区二区三区精品久久久| aaa国产一区| 日韩精品在线一区二区| 国产福利91精品一区二区三区| 欧美日韩国产一级二级| 激情文学综合插| 欧美日韩高清一区二区不卡| 精品一区在线看| 欧美精品久久天天躁| 国产精品一区二区无线| 91精品免费观看| 国产精品一区专区| 日韩欧美国产一区二区在线播放 | 亚洲一线二线三线视频| 亚洲国产精品123| 亚洲少妇中出一区| 国产精品乱看| 欧美一区二区三区播放老司机 | 老牛国产精品一区的观看方式| 日韩一区精品字幕| 日本丰满少妇一区二区三区| 日本不卡的三区四区五区| 欧美日韩亚洲不卡| 成熟亚洲日本毛茸茸凸凹| 久久色在线观看| 国精品一区二区三区| 亚洲啪啪综合av一区二区三区| 欧美巨大另类极品videosbest| 国产精品亚洲一区二区三区妖精| 精品国精品自拍自在线| 色综合咪咪久久| 亚洲丝袜另类动漫二区| 国产精品一区二区a| 蜜臀va亚洲va欧美va天堂| 在线不卡免费欧美| 欧美一区1区三区3区公司| 亚洲视频网在线直播| 欧美亚洲专区| 国内精品免费**视频| 久久嫩草精品久久久精品一| 亚洲视频日本| 欧美性猛交xxxxxxxx| 成人午夜又粗又硬又大| 国产精品嫩草久久久久| 亚洲一区高清| 国产一区二区免费视频| 国产视频一区二区三区在线观看| 亚洲无线一线二线三线区别av| 久久这里都是精品| 最新亚洲激情| 免费成人美女在线观看| 精品av久久707| 亚洲精品视频啊美女在线直播| 日本欧美在线观看| 日韩欧美123| 一区三区视频| 蜜臀精品久久久久久蜜臀| 欧美成人a在线| 一本色道久久综合亚洲精品不 | 久久成人亚洲| 国产又黄又大久久| 日本一区二区三区四区| 免费欧美在线| 成人性生交大片免费看中文网站| 中文字幕中文字幕一区| 欧美午夜免费电影| 欧美福利在线| 秋霞电影一区二区| 国产亚洲精品精华液| 国产精品区二区三区日本| 国产一区二区三区| 亚洲情趣在线观看| 欧美精品粉嫩高潮一区二区| 欧美日韩国产色综合一二三四| 日韩中文字幕av电影| 久久一区二区三区四区| 欧美一级一区| eeuss鲁一区二区三区| 性做久久久久久久免费看| 日韩欧美电影在线| 国产精品五区| 99久久国产综合精品女不卡| 亚洲专区一二三| 精品国产免费人成在线观看| 国产一区二区你懂的| 懂色av中文字幕一区二区三区| 一区二区三区蜜桃网| 日韩欧美国产三级电影视频| 午夜综合激情| 91在线丨porny丨国产| 日韩av电影免费观看高清完整版| 国产农村妇女精品| 欧美丝袜自拍制服另类| 在线日本成人| 成人免费观看av| 五月天欧美精品| 欧美激情资源网| 欧美男人的天堂一二区| 日韩视频二区| 国产成人亚洲精品狼色在线| 亚洲午夜私人影院| 久久尤物电影视频在线观看| 欧洲在线/亚洲| 伊人蜜桃色噜噜激情综合| 东方欧美亚洲色图在线| 日韩国产欧美视频| 亚洲天堂av老司机| 精品99999| 欧美日韩一区二区三区四区| 一区二区动漫| 91视视频在线观看入口直接观看www | 国产精品99久久久久久久女警| 中文字幕欧美一| 欧美成人在线直播| 欧亚洲嫩模精品一区三区| 亚洲精品美女| 99久久精品免费精品国产| 久久99精品久久久| 夜夜夜精品看看| 国产精品视频第一区| 色婷婷久久综合| 国产欧美短视频| 欧美日韩精品一本二本三本| 国产99久久久国产精品潘金| 日韩av不卡在线观看| 亚洲伊人色欲综合网| 最新国产成人在线观看| 久久亚洲欧美国产精品乐播| 欧美一区二区三区在线电影| 91久久奴性调教| 国产伦一区二区三区色一情| 激情成人亚洲| 欧美日本一区| 91一区一区三区| 成人黄色小视频| 国产成人一级电影| 久久精品国产色蜜蜜麻豆| 亚洲h在线观看| 亚洲欧美日韩综合aⅴ视频| 久久久午夜精品理论片中文字幕| 9191精品国产综合久久久久久| 在线视频亚洲一区| 久久美女性网| 亚洲欧美精品| 国产精品毛片在线| 99精品国产一区二区青青牛奶| 国内精品福利| 国产精品分类| 国产精品国产精品| 国产综合18久久久久久| 欧美人成在线| 欧美日本国产精品| 国产精品v欧美精品v日本精品动漫| 色综合一个色综合| 99久久久无码国产精品| k8久久久一区二区三区 | 国产精品理论在线观看| 久久久国产一区二区三区四区小说 | 亚洲一区二区三区国产| 亚洲免费视频中文字幕| 亚洲免费av观看| 亚洲欧美另类久久久精品| 亚洲色图制服丝袜| 综合亚洲深深色噜噜狠狠网站| 中文字幕日韩欧美一区二区三区| 国产精品无遮挡| ...中文天堂在线一区| 亚洲另类色综合网站| 亚洲精品免费电影| 一区二区三区国产精品| 亚洲激情av在线| 亚洲国产视频一区二区| 午夜欧美电影在线观看| 亚洲国产一区二区三区青草影视| 丝袜亚洲精品中文字幕一区| 日韩电影在线一区二区| 久久爱www久久做| 国产一区二区看久久| 国产精品主播直播| eeuss鲁一区二区三区| 欧美精品aa| 亚洲精品乱码久久久久久蜜桃麻豆 | 精品一区二区久久| 中文久久精品| 国产精品电影院| 国产精品传媒入口麻豆| 精品国产不卡一区二区三区| 色综合久久久久综合| 色哟哟在线观看一区二区三区| 91精品办公室少妇高潮对白| 欧美日韩免费不卡视频一区二区三区 | 成人综合在线观看| 91网站在线观看视频| 欧美视频导航| 国产亚洲精品久久飘花|