請注意PHP程序里的敏感信息

發表于:2013-10-14來源:IT博客大學習作者:王點擊數: 標簽:php
何為敏感信息?簡單點來說就是你不想讓別人知道的信息,比如說數據庫的地址,用戶名,密碼等等,此類信息往往知道的人越少越好。 通常,PHP程序里的配置文件大致如下所示:

  何為敏感信息?簡單點來說就是你不想讓別人知道的信息,比如說數據庫的地址,用戶名,密碼等等,此類信息往往知道的人越少越好。

  通常,PHP程序里的配置文件大致如下所示:

  

  return array(

  'database' => array(

  'host' => '192.168.0.1',

  'user' => 'administrator',

  'password' => 'e1bfd762321e409cee4ac0b6e841963c',

  ),

  );

  ?>

  有時候出于某些原因,比如說代碼審查,亦或者合作開發等等,第三方需要獲取代碼版本倉庫的讀權限,一旦授權,數據庫的地址,用戶名,密碼等敏感信息就暴露了。當然也可以不在代碼版本倉庫里保存配置文件,取而代之是撰寫文檔進行說明,但我不喜歡這樣的方法,因為如此一來,代碼本身是不完整的。

  如何解決此類問題呢?最直接的方法是把敏感信息從代碼中拿掉,換個地方保存。具體保存到哪里呢?有很多選擇,比如說通過nginx的fastcgi_param來設置:

  fastcgi_param DATABASE_HOST 192.168.0.1;

  fastcgi_param DATABASE_USER administrator;

  fastcgi_param DATABASE_PASSWORD e1bfd762321e409cee4ac0b6e841963c;

  經過這樣的映射后,我們的代碼就不會直接包含敏感信息了:

  

  return array(

  'database' => array(

  'host' => $_SERVER['DATABASE_HOST'],

  'user' => $_SERVER['DATABASE_USERNAME'],

  'password' => $_SERVER['DATABASE_PASSWORD'],

  ),

  );

  ?>

  此外,還可以通過php-fpm的env指令來設置:

  env[DATABASE_HOST] = 192.168.0.1

  env[DATABASE_USERNAME] = administrator

  env[DATABASE_PASSWORD] = e1bfd762321e409cee4ac0b6e841963c

  需要說明的一點是,這個設置必須放在主配置文件php-fpm.conf里,不能放到include指令設置的子配置文件里,否則會報錯:「Array are not allowed in the global section」;另外一點,雖然是通過env設置的,但結果還是在$_SERVER里,而不是$_ENV。

  …

  說明: @Laruence 提醒了我,如果配置信息通過nginx的fastcgi_param來設置的話,當nginx和php交互時,會帶來大量的數據傳輸(如此看來通過php-fpm的env來設置相對更有優勢),鳥哥建議使用獨立的擴展來搞定,比如「hidef」。

  …

  通過nginx和php-fpm配置文件來解決問題的話,有一個缺點,僅對Web有效,如果通過命令行來運行,那么無法在$_SERVER里獲取相關信息,不過這不算什么難事兒,只要寫個公共的腳本正則匹配一下nginx或者php-fpm的配置文件,就可以動態的把這些信息映射到命令行環境,具體怎么搞就留給大家自己操作吧。

  …

  代碼干凈了,剩下的工作就是如何確保nginx或php-fpm配置文件的安全了,不過和代碼比起來,nginx或php-fpm配置文件并不需要很多人有權限,所以相對更容易管理。

原文轉自:http://blogread.cn/it/article/6534

国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97