肉动漫无修3D在线观看-肉动漫无码无删减在线观看-肉动漫h黄动漫日本免费观看-肉动漫3D卡通无修在线播放-床上色APP下载免费版-床伴在线观看免费高清完整泰剧第四集

Web前端知識(shí)

首頁(yè) > 免費(fèi) > Web前端知識(shí) >

php編程中的安全規(guī)則

來(lái)源:未知   時(shí)間:2015-11-17   點(diǎn)擊:

  規(guī)則 1:絕不要信任外部數(shù)據(jù)或輸入

  關(guān)于 Web 應(yīng)用程序安全性,必須認(rèn)識(shí)到的第一件事是不應(yīng)該信任外部數(shù)據(jù)。外部數(shù)據(jù)(outside data) 包括不是由程序員在 PHP 代碼中直接輸入的任何數(shù)據(jù)。在采取措施確保安全之前,來(lái)自任何其他來(lái)源(比如 GET 變量、表單 POST、數(shù)據(jù)庫(kù)、配置文件、會(huì)話變量或 cookie)的任何數(shù)據(jù)都是不可信任的。

  例如,下面的數(shù)據(jù)元素可以被認(rèn)為是安全的,因?yàn)樗鼈兪窃?PHP 中設(shè)置的。

  清單 1. 安全無(wú)暇的代碼

  <?php
  $myUsername = 'tmyer';
  $arrayUsers = array('tmyer', 'tom', 'tommy');
  define("GREETING", 'hello there' . $myUsername);
  ?>

  但是,下面的數(shù)據(jù)元素都是有瑕疵的。

  清單 2. 不安全、有瑕疵的代碼

  <?php
  $myUsername = $_POST['username']; //tainted!
  $arrayUsers = array($myUsername, 'tom', 'tommy'); //tainted!
  define("GREETING", 'hello there' . $myUsername); //tainted!
  ?>

  為 什么第一個(gè)變量 $myUsername 是有瑕疵的?因?yàn)樗苯觼?lái)自表單 POST。用戶可以在這個(gè)輸入域中輸入任何字符串,包括用來(lái)清除文件或運(yùn)行以前上傳的文件的惡意命令。您可能會(huì)問(wèn),“難道不能使用只接受字母 A-Z 的客戶端(Javascrīpt)表單檢驗(yàn)?zāi)_本來(lái)避免這種危險(xiǎn)嗎?”是的,這總是一個(gè)有好處的步驟,但是正如在后面會(huì)看到的,任何人都可以將任何表單下載 到自己的機(jī)器上,修改它,然后重新提交他們需要的任何內(nèi)容。

  解決方案很簡(jiǎn)單:必須對(duì) $_POST['username'] 運(yùn)行清理代碼。如果不這么做,那么在使用 $myUsername 的任何其他時(shí)候(比如在數(shù)組或常量中),就可能污染這些對(duì)象。

  對(duì)用戶輸入進(jìn)行清理的一個(gè)簡(jiǎn)單方法是,使用正則表達(dá)式來(lái)處理它。在這個(gè)示例中,只希望接受字母。將字符串限制為特定數(shù)量的字符,或者要求所有字母都是小寫的,這可能也是個(gè)好主意。

  清單 3. 使用戶輸入變得安全

  <?php
  $myUsername = cleanInput($_POST['username']); //clean!
  $arrayUsers = array($myUsername, 'tom', 'tommy'); //clean!
  define("GREETING", 'hello there' . $myUsername); //clean!
  function cleanInput($input){
  $clean = strtolower($input);
  $clean = preg_replace("/[^a-z]/", "", $clean);
  $clean = substr($clean,0,12);
 return $clean;
  }
  ?>

  規(guī)則 2:禁用那些使安全性難以實(shí)施的 PHP 設(shè)置

  已經(jīng)知道了不能信任用戶輸入,還應(yīng)該知道不應(yīng)該信任機(jī)器上配置 PHP 的方式。例如,要確保禁用 register_globals。如果啟用了 register_globals,就可能做一些粗心的事情,比如使用 $variable 替換同名的 GET 或 POST 字符串。通過(guò)禁用這個(gè)設(shè)置,PHP 強(qiáng)迫您在正確的名稱空間中引用正確的變量。要使用來(lái)自表單 POST 的變量,應(yīng)該引用 $_POST['variable']。這樣就不會(huì)將這個(gè)特定變量誤會(huì)成 cookie、會(huì)話或 GET 變量。

  規(guī)則 3:如果不能理解它,就不能保護(hù)它

  一些開發(fā)人員使用奇怪的語(yǔ)法,或者將語(yǔ)句組織得很緊湊,形成簡(jiǎn)短但是含義模糊的代碼。這種方式可能效率高,但是如果您不理解代碼正在做什么,那么就無(wú)法決定如何保護(hù)它。

  例如,您喜歡下面兩段代碼中的哪一段?

  清單 4. 使代碼容易得到保護(hù)

  <?php
  //obfuscated code
  $input = (isset($_POST['username']) ? $_POST['username']:'');
  //unobfuscated code
  $input = '';
  if (isset($_POST['username'])){
  $input = $_POST['username'];
  }else{
  $input = ''; 
  }
  ?>

  在第二個(gè)比較清晰的代碼段中,很容易看出 $input 是有瑕疵的,需要進(jìn)行清理,然后才能安全地處理。

網(wǎng)絡(luò)營(yíng)銷推廣 . 北京匯仁智杰科技有限公司!

地址:北京市昌平區(qū)回龍觀龍冠大廈5層
咨詢:13370157521
業(yè)務(wù)QQ:373002979
E - mail:sales @ huirenzhijie.com
企業(yè)網(wǎng)站備案:京ICP備15021091號(hào)-1

匯仁智杰與眾不同

  • 有網(wǎng)絡(luò)推廣經(jīng)驗(yàn)
  • 有網(wǎng)站建站隊(duì)伍
  • 有大型網(wǎng)站建設(shè)經(jīng)驗(yàn)
  • 致力于營(yíng)銷型網(wǎng)站建設(shè)
  • 始終堅(jiān)持技術(shù)和服務(wù)同樣重要
查看PC版網(wǎng)站
備案號(hào):京ICP備15021091號(hào)-1 版權(quán)所有:匯仁智杰

主站蜘蛛池模板: 中文字幕一区久久久久 | 成人精品综合免费视频 | 久久国产精品永久网站 | 色情在线avav | 亚洲国产日韩欧美视频二区 | 日本aa大片| 雪恋电影完整版免费观看 | 久久久久婷婷国产综合青草 | 性一交一乱一色一视频 | 被肉日常np高h| 国产亚洲欧美在线中文BT天堂网 | 色情在线avav | 王晶经典三级 | 国产精品久久高潮呻吟无码 | 亚洲精品一区二区在线看片 | 欧美人与动交zOZ0 | 午夜福利不卡片在线播放免费 | 越南女 黑人 痛苦 大叫 | 国产亚洲精品久久久久苍井松 | 疯狂第一次国语 | 国产一区私人高清影院 | 免费毛片在线播放 | 老板吻我下身好爽到高潮 | 亚洲一区免费香蕉在线 | 中文国产乱码在线人妻一区二区 | 亚洲精品成人 | 国产高清在线观看视频 | 日本无码毛片久久久九色综合 | www在线小视频免费 www伊人网 | 秘密教学26我们在做一次吧免费 | 亚洲AV色香蕉一区二区9255 | 2021国产精品一卡2卡三卡4卡 | 亚洲va久久久久 | 最近日本字幕免费高清 | 久久亚洲精品中文字幕60分钟 | 武侠古典久久亚洲精品 | 神马伦理2019影院不卡片 | 久久精品中文騷妇女内射 | 亚洲日本香蕉视频观看视频 | 亚洲一二三产品区别在哪里 | 嘿嘿视频在线观看 成人 |