如何寫出好的 PHP 代碼?

来源:http://www.cnblogs.com/androidshouce/archive/2016/06/14/5582734.html
-Advertisement-
Play Games

編寫良好的代碼是一種藝術。如果一個程式員遵循一些良好的編程習慣,那麼他就可以成為一個優秀的程式員。實際上,相對於你寫代碼的時間,你很可能會花更多的時間在代碼維護上;更不用說整個應用程式的維護。建立良好的編碼習慣,能夠提高像模塊化這樣的設計因素,你的代碼也將更容易理解,因此,維護起來更容易、成本更低。 ...


編寫良好的代碼是一種藝術。如果一個程式員遵循一些良好的編程習慣,那麼他就可以成為一個優秀的程式員。實際上,相對於你寫代碼的時間,你很可能會花更多的時間在代碼維護上;更不用說整個應用程式的維護。建立良好的編碼習慣,能夠提高像模塊化這樣的設計因素,你的代碼也將更容易理解,因此,維護起來更容易、成本更低。而不良的編碼習慣會在代碼中存在缺陷,並可能導致代碼很難維護。 

在本文中,我們將探討一些良好的編程習慣,這將幫助你避免代碼中的缺陷。 

1- 編寫模塊化代碼 

良好的PHP代碼應該是模塊化代碼。PHP的面向對象的編程功能是一些特別強大的工具,可以把你的應用程式分解成函數或方法。你應該儘可能多的從你的應用程式的伺服器端分開前端的HTML/CSS/JavaScript代碼。你也可以在任何PHP框架上遵循MVC(模型-視圖-控制器)模式。 

2- 代碼編寫規範 

良好的PHP代碼應該有一套完整的代碼編寫規範。通過對變數和函數的命名,統一的方法訪問資料庫和對錯誤的處理,以及同樣的代碼縮進方式等來達到編程規範,這樣可以使你的代碼更具可讀性。 

3- 編寫可移植代碼 

良好的PHP代碼應該是可移植的。你可以使用php的現有功能,如魔術引號和短標簽。試著瞭解你的需求,然後通過適應PHP特性來編寫代碼讓代碼獨立、可移植。 

4- 編寫安全代碼 

良好的PHP代碼應該是安全的。PHP5提供了出色的性能和靈活性。但是安全問題完全在於開發人員。對於一個專業的PHP開發人員來說,深入理解重大安全漏洞是至關重要的,如:跨站點腳本(XSS)、跨站請求偽造(CSRF)、代碼註入漏洞、字元編碼漏洞。通過使用PHP的特殊功能和函數,如:mysql_real_escape_string等等,你可以編寫出安全的代碼。 

5- 代碼註釋 

代碼註釋是代碼的重要組成部分。通過代碼註釋可以知道該變數或函數是做什麼的,這將在今後的代碼維護中十分有用。 

6- 避免短標簽 

把所有用到短標簽的替換成完整的PHP標簽。 

7- 使用單引號代替雙引號 

字元串始終使用單引號代替雙引號,以避免PHP搜索字元串內的變數導致的性能下降。 

8- 轉義字元串輸出 

使用ENT_QUOTES作參數傳遞給htmlspecialchars函數,以確保單引號(')也轉換成HTML實體,這是一個好習慣。 

9- 使用逗號分隔字元串輸出 

通過echo語句輸出使用逗號(,)分隔的字元串,要比使用字元串連接操作符(.)的性能更好。 

10- 輸出前檢查傳來的值 

輸出前檢查傳過來的值$_GET['query']。使用isset或empty函數,可以用來檢查變數是否為null值。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • CLR規範要求重載操作符重載方法必須是public和static方法 C#要求操作符重載方法至少有一個參數的類型與當前定義的這個方法類型相同 為了減少運行時開銷,編譯器會直接針對基元類型執行運算,並直接生成操作這些類型的實例的中間代碼(IL)指令,所以在Framework標準庫中沒有定義基元類型的操 ...
  • Asp.net MVC 和web api 的action 在獲取從前臺傳入的數據是有很大不同 前臺使用ajax的方式向後臺發起post的請求 Content-Type:application/json 使用以下json對象 在mvc中可以使用這兩種格式的json均能獲取到的user的username ...
  • 1.以管理員身份運行CMD; 2.在CMD里輸入F:\>vs_enterprise.exe /uninstall /force ...
  • 1 引言 在應用程式的設計中,經常需要讀取Excel數據或將Excel數據導入轉換到其他數據載體中,例如將Excel數據通過應用程式導入SQL Sever等資料庫中以備使用。筆者在開發“汽車產業鏈ASP協同商務平臺”中遇到了類似需求。某汽車整車生產企業需要將其車輛發車信息發佈到汽車產業鏈平臺上去,其 ...
  • 紅色字體是現階段比較火的 奇虎360 https://github.com/Qihoo360 1.MySQL中間層 Atlas Atlas是由 Qihoo 360, Web平臺部基礎架構團隊開發維護的一個基於MySQL協議的數據中間層項目。它在MySQL官方推出的MySQL-Proxy 0.8.2版 ...
  • 本文是Linux Shell系列教程的第(十一)篇,更多Linux Shell教程請看:Linux Shell系列教程 在上一篇Linux Shell系列教程之(十)Shell for迴圈中,我們已經對Shell 迴圈語句的for迴圈進行了介紹,本篇給大家介紹下Shell 中另一種迴圈語句:Shel ...
  • 一、版本信息 Firefox 最新版本V46.0.1 Fiddler 最新版本V4.6.2.3 二、錯誤信息 開啟fiddlers的https協議捕獲的方法,百度上可以查到不再贅述,直接放張圖(Tools - Fiddlers Options……)。 開啟https協議捕獲之後,用firefox訪問 ...
  • 1. 建立Python的開發環境 2.第一個Python程式,還是從Hello World開始 3. debug一下python程式 <1>. 建立Python的開發環境; 這裡使用的Python的開發環境是eclipse + pydev插件來配置python的開發環境,如果想要在命令行下使用pyt ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...