核心理念
DRY 強調系統中的每一條知識都應該有一個單一的、明確的表示。
違反 DRY 的程式碼範例
範例 1:驗證邏輯
// WET (Write Everything Twice) Code class User { public function validateUsername($username) { if (strlen($username) 20) { throw new Exception("Username must be between 3 and 20 characters"); } if (!preg_match('/^[a-zA-Z0-9_]+$/', $username)) { throw new Exception("Username can only contain letters, numbers and underscore"); } } public function updateUsername($username) { // Same validation repeated if (strlen($username) 20) { throw new Exception("Username must be between 3 and 20 characters"); } if (!preg_match('/^[a-zA-Z0-9_]+$/', $username)) { throw new Exception("Username can only contain letters, numbers and underscore"); } // Update logic } }
乾燥溶液
class User { private function validateUsername($username) { if (strlen($username) 20) { throw new Exception("Username must be between 3 and 20 characters"); } if (!preg_match('/^[a-zA-Z0-9_]+$/', $username)) { throw new Exception("Username can only contain letters, numbers and underscore"); } } public function createUser($username) { $this->validateUsername($username); // Creation logic } public function updateUsername($username) { $this->validateUsername($username); // Update logic } }
透過繼承實現 DRY
abstract class BaseController { protected function jsonResponse($data, $status = 200) { header('Content-Type: application/json'); http_response_code($status); echo json_encode($data); } } class UserController extends BaseController { public function show($id) { $user = User::find($id); return $this->jsonResponse($user); } } class ProductController extends BaseController { public function show($id) { $product = Product::find($id); return $this->jsonResponse($product); } }
使用 DRY 特徵
trait Loggable { private function log($message) { $timestamp = date('Y-m-d H:i:s'); file_put_contents('log.txt', "[$timestamp] $message\n", FILE_APPEND); } } class UserService { use Loggable; public function createUser($data) { $this->log("Creating new user"); // User creation logic } } class PaymentService { use Loggable; public function processPayment($amount) { $this->log("Processing payment: $amount"); // Payment processing logic } }
使用常量
class Config { const DEFAULT_ITEMS_PER_PAGE = 10; const MAX_UPLOAD_SIZE = 5242880; // 5MB const ALLOWED_FILE_TYPES = ['jpg', 'png', 'pdf']; } class FileUploadService { public function validateFile($file) { if ($file['size'] > Config::MAX_UPLOAD_SIZE) { throw new Exception("File too large"); } $extension = pathinfo($file['name'], PATHINFO_EXTENSION); if (!in_array($extension, Config::ALLOWED_FILE_TYPES)) { throw new Exception("Invalid file type"); } } } class MediaController { public function index() { return $this->paginate(Config::DEFAULT_ITEMS_PER_PAGE); } }
這些範例示範如何透過各種 PHP 功能(如繼承、特徵、常數和正確的方法提取)應用 DRY。目標是為程式碼庫中的任何給定功能維護單一事實來源。
以上是DRY(不要重複自己)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

phpIdentifiesauser'ssessionSessionSessionCookiesAndSessionId.1)whiwsession_start()被稱為,phpgeneratesainiquesesesessionIdStoredInacookInAcookInAcienamedInAcienamedphpsessIdontheuser'sbrowser'sbrowser.2)thisIdallowSphptpptpptpptpptpptpptpptoretoreteretrieetrieetrieetrieetrieetrieetreetrieetrieetrieetrieetremthafromtheserver。

PHP會話的安全可以通過以下措施實現:1.使用session_regenerate_id()在用戶登錄或重要操作時重新生成會話ID。 2.通過HTTPS協議加密傳輸會話ID。 3.使用session_save_path()指定安全目錄存儲會話數據,並正確設置權限。

phpsessionFilesArestoredIntheDirectorySpecifiedBysession.save_path,通常是/tmponunix-likesystemsorc:\ windows \ windows \ temponwindows.tocustomizethis:tocustomizEthis:1)useession_save_save_save_path_path()

ToretrievedatafromaPHPsession,startthesessionwithsession_start()andaccessvariablesinthe$_SESSIONarray.Forexample:1)Startthesession:session_start().2)Retrievedata:$username=$_SESSION['username'];echo"Welcome,".$username;.Sessionsareserver-si

利用會話構建高效購物車系統的步驟包括:1)理解會話的定義與作用,會話是服務器端的存儲機制,用於跨請求維護用戶狀態;2)實現基本的會話管理,如添加商品到購物車;3)擴展到高級用法,支持商品數量管理和刪除;4)優化性能和安全性,通過持久化會話數據和使用安全的會話標識符。

本文討論了PHP中的crypt()和password_hash()的差異,以進行密碼哈希,重點介紹其實施,安全性和對現代Web應用程序的適用性。

文章討論了通過輸入驗證,輸出編碼以及使用OWASP ESAPI和HTML淨化器之類的工具來防止PHP中的跨站點腳本(XSS)。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3漢化版
中文版,非常好用

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。