国产综合精品-久久久久久成人毛片免费看-69久久夜色精品国产69-美国十次啦怡红院

Web前端知識(shí)

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

你知道PHP中的防御性編程是怎么一回事么?

來源:北京匯仁智杰科技有限公司   時(shí)間:2016-04-09   點(diǎn)擊:

  大家會(huì)問,防御性編程是什么意思???今天呢,匯仁智杰小編就和大家說說防御性編程。簡單的說,就是在編程的時(shí)候有目的地預(yù)測可能的故障點(diǎn)。目的是在那些可能發(fā)生的問題發(fā)生前解決它們。你看見了問題,對(duì)吧?預(yù)測意料之外的事情本來就有內(nèi)在的難度,當(dāng)你想要預(yù)測意料之外的事情并且解決它就更是難上了好幾倍。
  下面我們看幾個(gè)實(shí)際的例子。
  1.條件語句
  這是最容易進(jìn)行防御性編程的地方之一,也是最容易滿足的地方。在用PHP編程的許多情況下你不會(huì)需要“else”。
  假設(shè),你在寫一個(gè)函數(shù)并且需要一個(gè)條件語句。在這里,你只需要為你特定的變量使用三個(gè)條件語句如下:
  if($var == a){ }
  else if($var == b){ }
  else if($var == c){ }
  沒有其他可能性了,你說,并且繼續(xù)碼代碼。但是,讓我們?cè)谶@里停一下。我知道你知道這里沒有其他可能性了。并且我相信你。但有時(shí)候(不可預(yù)測的)情況會(huì)發(fā)生。我們忘掉了一些情況。我們檢查錯(cuò)誤。我們最終重用了一些代碼,超出了原本的預(yù)定范圍。突然我們有了泄露錯(cuò)誤或者有時(shí)候是靜默的錯(cuò)誤狀態(tài),因?yàn)槲覀儧]有使用catch。使用else代碼塊。在使用switch時(shí)要使用default。用它們來返回或者記錄錯(cuò)誤,這樣你才知道發(fā)生了什么(如果發(fā)生了的話)。雖然會(huì)多用兩行代碼,但當(dāng)一些你無法預(yù)測的事情發(fā)生時(shí),這是值得的。
  2.絕不相信用戶輸入
  你以前有沒有聽說過這個(gè)說法?大多數(shù)程序員聽過。這有一點(diǎn)含糊,通俗點(diǎn)講,理所當(dāng)然。但它是真理。你絕不應(yīng)該相信用戶輸入。這不是說你假設(shè)所有用戶是瘋狂的黑客,他們使用一些精心設(shè)計(jì)的命令來摧毀你的應(yīng)用。沒有必要妄想。但是,你應(yīng)該假設(shè)用戶不知道你的代碼,他們不知道你需要填寫什么參數(shù),或者參數(shù)應(yīng)該多長。他們不知道什么文件類型或者什么大小能上傳(即使應(yīng)用告訴了他們)。偶爾他們會(huì)是機(jī)器或者黑客并且他們希望在他們的輸入中運(yùn)行腳本,有時(shí)候甚至是在登陸后的輸入中。你怎么知道你能相信認(rèn)證或者驗(yàn)證碼能在用戶輸入之前提供一個(gè)安全的堡壘?
  答案:絕不。
  你絕不相信用戶輸入。如果你信任的用戶輸入,那么你永遠(yuǎn)不會(huì)有一個(gè)突破。明白了嗎?所以總是要評(píng)估你的輸入,一定要保證你在處理數(shù)據(jù)尤其是要存入數(shù)據(jù)庫或者要把它展示出來時(shí)使用了合適的技術(shù)。因此 – 絕不相信輸入,即使來自不是用戶的輸入的地方 – 輸入驗(yàn)證永遠(yuǎn)是你的朋友。
  3.對(duì)你的代碼的假設(shè)
  不要假設(shè)任何事情。如果前兩個(gè)主題教會(huì)我們一些事情的話,那就是我們不應(yīng)該做任何假設(shè)。作為程序員,尤其是致力于一個(gè)項(xiàng)目太久后,我們開始做很多假設(shè)。我們假設(shè)用戶知道一些我們知道的事情。不一定是技術(shù)細(xì)節(jié),也可以是程序的功能性細(xì)節(jié)。我們假設(shè)用戶知道文件能有多大因?yàn)?。。。我們已?jīng)知道?;蛘咚麄冎罏榱俗屶]件腳本。。。但事實(shí)不是,他們不知道以上任何東西。這好像更多的是前端的工作,但明顯的是你在后端仍然要處理用戶行為和用戶輸入,所以值得好好想想。
  另一個(gè)許多程序員都會(huì)做的驚人的假設(shè)是我們?cè)谌魏螘r(shí)候?qū)τ谖覀兊暮瘮?shù),類或者其它代碼段的明顯的功能屬性。一個(gè)具有防御性的程序員會(huì)仔細(xì)考慮的不僅僅是用一般的文檔來描述函數(shù)是干什么的——他們也將寫下他們對(duì)輸入,參數(shù),用例,或任何其他類似的東西做出的任何假設(shè)。因?yàn)槲覀兌际侨?,我們過一段時(shí)間會(huì)忘掉一些事。我們最后也很可能會(huì)面臨其他人維護(hù),擴(kuò)展或者替換我們的代碼。如果沒有別的,回想一下,編程是發(fā)生在一個(gè)充滿技術(shù)變革的世界里。如果你的應(yīng)用仍然能使用幾年,可能會(huì)升級(jí)PHP版本并且失去一些功能,或者一些你自己代碼里面具有交互的組件之間需要改變。預(yù)測這些是很困難的,所以好的注釋和文檔是非常重要的。
  4.視野狹窄
  另一件可以使我們忘記好的評(píng)論實(shí)踐以及標(biāo)準(zhǔn)的東西是視野狹窄。許多程序員都具有視野狹窄的毛病。你知道這種感覺 - 你解決問題,你處于最佳狀態(tài)。你覺得與你的音樂(或沒有)獨(dú)立于自己的小世界中,并且你就在編碼,突然兩小時(shí)過了,你意識(shí)到你已經(jīng)寫了無數(shù)行沒有注釋的代碼。我們所有人偶爾都會(huì)遇到這種事情,但重要的是在某處發(fā)現(xiàn)這個(gè)情況并且補(bǔ)上應(yīng)有的注釋。
  5.語法和命名的一致性
  一致性是一個(gè)灰色地帶 – 它更多的是關(guān)于編碼標(biāo)準(zhǔn)之類的,但它和防御性編程也有聯(lián)系。在PHP中,有標(biāo)準(zhǔn)規(guī)范你的代碼格式以便別人查看,或者你以后使用。但常常沒人讓你的代碼標(biāo)準(zhǔn)化。但是無論你是否按照標(biāo)準(zhǔn)編碼,你至少要保持一致性 – 這能讓你少犯錯(cuò)誤。這對(duì)于需要大量時(shí)間返回并且修復(fù)的小的語法錯(cuò)誤尤其適用。如果你總是使用相同的間隔,格式和語法,命名規(guī)格等等你就能更好的避免犯錯(cuò)以至于誤讀你自己的代碼。你更可能快速瀏覽代碼并且找到你需要的東西。
  總結(jié)
  總的來說,除去用戶行為和動(dòng)作,不要對(duì)你的程序做任何假設(shè)。假設(shè)是具有防御性編程習(xí)慣的程序員最大的敵人。不要假設(shè)你不需要 default 語句或者 else 代碼塊。盡量使用正確的用戶錯(cuò)誤信息,警告,日志或者任何其它你假設(shè)不會(huì)用到的代碼。你的假設(shè)通常是正確的 – 但我們不在乎。我們?cè)诤醯氖撬鼈兂鲥e(cuò)的時(shí)候。一定要計(jì)劃得好,準(zhǔn)備著你可能需要在幾小時(shí),幾周,幾個(gè)月甚至幾年后回顧你的代碼,或者其他人需要 – 相應(yīng)的就要好好寫文檔。別假設(shè)它永遠(yuǎn)不需要升級(jí),擴(kuò)展或者維護(hù)。那是無知的,在更多的情況下是疏忽。有時(shí)候保持一顆防御性編程的心能幫你更有效更安全地估計(jì),計(jì)劃和編程。

網(wǎng)絡(luò)營銷推廣?。”本﹨R仁智杰科技有限公司!

地址:北京市昌平區(qū)回龍觀龍冠大廈5層
咨詢:15201492965
業(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)
  • 致力于營銷型網(wǎng)站建設(shè)
  • 始終堅(jiān)持技術(shù)和服務(wù)同樣重要
查看PC版網(wǎng)站
備案號(hào):京ICP備15021091號(hào)-1 版權(quán)所有:匯仁智杰