告別枯燥的SQL查詢!使用FluentPDO簡化數據庫操作
您是否也厭倦了編寫SQL查詢?尤其是在時間緊迫的情況下。如果您和我一樣,那麼今天我們將學習一個非常酷炫的工具:FluentPDO。如果您不熟悉“PDO”這個術語,也不用擔心。它是一個非常簡單的概念:在PHP世界中,PDO代表持久化數據對象(Persistent Data Object),它幫助您抽象化一些基本的數據庫操作(如插入、更新、刪除等)。它是您與數據庫之間的一層抽象層。
結果呢?不再需要編寫SQL查詢了!這可能不是您見到的第一個這樣的項目:市面上有很多類似的項目,每個項目都有其關鍵特性。 FluentPDO的關鍵特性在於其強大的JOIN查詢構建器。
關鍵要點
- FluentPDO是一個PHP SQL查詢構建器,它抽象化了基本的數據庫操作,無需再編寫SQL查詢。其關鍵特性是一個強大的JOIN查詢構建器。
- FluentPDO的安裝通過Composer完成,無需任何額外配置。通過將PDO對像作為參數傳遞給FluentPDO對象的構造函數來實例化它。
- FluentPDO為基本的SELECT操作提供了簡單易讀的語法,包括設置表、過濾結果和指定比較運算符的方法。它還允許選擇特定字段、設置LIMIT和OFFSET參數,以及使用“HAVING”、“GROUP BY”和“ORDER BY”指令。
- FluentPDO還支持使用INSERT、UPDATE和DELETE操作類進行數據操作。這些操作需要使用execute()方法來運行查詢並更改數據庫。
- FluentPDO的高級特性包括JOIN查詢構建器(簡化了JOIN查詢的代碼)和內置的調試器系統(用於測試和檢查查詢)。
我們的FluentPDO測試項目
首先,我們需要一個示例項目來進行操作。讓我們考慮一下……一個簡單的多用戶願望清單怎麼樣?
會有很多用戶,每個用戶都有自己喜歡的產品。對於每個用戶,我們將存儲其名字、姓氏和註冊日期。對於每個商品,我們將存儲其名稱、品牌、價格和相關的用戶ID。
我將使用一個簡單的MySQL數據庫。以下是我們的數據結構:
以下是SQL轉儲(包含一些虛擬數據):
CREATE TABLE IF NOT EXISTS items ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL, brand varchar(100) NOT NULL, price decimal(10,2) NOT NULL, user_id int(10) unsigned NOT NULL, PRIMARY KEY (id), KEY user_id (user_id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=5 ; INSERT INTO items (id, name, brand, price, user_id) VALUES (1, 'Last Awesome Phone', 'Awesome Brand', '550.00', 1), (2, 'Last Awesome TV', 'Awesome Brand', '1200.00', 1), (3, 'Fantastic E-Car', 'E-Cars Inc.', '80000.00', 2), (4, 'Fantastic E-Bike', 'E-Bikes Co. Ltd.', '16000.00', 2); CREATE TABLE IF NOT EXISTS users ( id int(10) unsigned NOT NULL AUTO_INCREMENT, first_name varchar(100) NOT NULL, last_name varchar(100) NOT NULL, signup_date datetime NOT NULL, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3; INSERT INTO users (id, first_name, last_name, signup_date) VALUES (1, 'Francesco', 'Malatesta', '2014-06-29 13:00:00'), (2, 'John', 'Foo Bar', '2014-06-20 11:16:39'); ALTER TABLE items ADD CONSTRAINT items_ibfk_1 FOREIGN KEY (user_id) REFERENCES users (id);
注意:正如您很容易想像的那樣,這不是一個“完整的”項目。我們只是在嘗試FluentPDO,所以我們不會涵蓋諸如登錄、註冊或應用程序結構之類的內容。
安裝
您可以使用Composer安裝FluentPDO,將其作為依賴項包含在內:
"require": { ... "lichtner/fluentpdo": "dev-master" }
完成後,您需要像這樣實例化它:
CREATE TABLE IF NOT EXISTS items ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL, brand varchar(100) NOT NULL, price decimal(10,2) NOT NULL, user_id int(10) unsigned NOT NULL, PRIMARY KEY (id), KEY user_id (user_id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=5 ; INSERT INTO items (id, name, brand, price, user_id) VALUES (1, 'Last Awesome Phone', 'Awesome Brand', '550.00', 1), (2, 'Last Awesome TV', 'Awesome Brand', '1200.00', 1), (3, 'Fantastic E-Car', 'E-Cars Inc.', '80000.00', 2), (4, 'Fantastic E-Bike', 'E-Bikes Co. Ltd.', '16000.00', 2); CREATE TABLE IF NOT EXISTS users ( id int(10) unsigned NOT NULL AUTO_INCREMENT, first_name varchar(100) NOT NULL, last_name varchar(100) NOT NULL, signup_date datetime NOT NULL, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3; INSERT INTO users (id, first_name, last_name, signup_date) VALUES (1, 'Francesco', 'Malatesta', '2014-06-29 13:00:00'), (2, 'John', 'Foo Bar', '2014-06-20 11:16:39'); ALTER TABLE items ADD CONSTRAINT items_ibfk_1 FOREIGN KEY (user_id) REFERENCES users (id);
您必須在PDO構造函數方法中指定您的連接詳細信息。在第一個參數中,在dbname=部分之後鍵入您的數據庫名稱,然後將您的用戶名和密碼分別作為第二個和第三個參數寫入。
然後,您將PDO對像作為參數傳遞給FluentPDO對象的構造函數。
就是這樣,FluentPDO不需要任何其他東西即可工作。無需額外配置。
基本的SELECT操作
我們已經有一些虛擬數據了。讓我們從SQL查詢的“Hello World”開始。一個簡單的SELECT,帶有一個WHERE子句,以及用戶主鍵ID作為參數來檢索基本信息。
"require": { ... "lichtner/fluentpdo": "dev-master" }
這裡沒有什麼難理解的。 FluentPDO具有良好且易讀的語法,因此很容易理解我們在做什麼。
from()方法用於設置正確的表。 where()方法用於使用相同的名稱子句過濾我們的結果。默認情況下,在where()方法中,您只需指定字段名稱和值。 “=”是隱含的。當然,您也可以使用不同的比較運算符。在這種情況下,您必須將它們寫在字段名稱之後。
$pdo = new PDO("mysql:dbname=wishlist", "root", "password"); $fpdo = new FluentPDO($pdo);
獲取結果非常容易:它們存儲在我們剛剛使用的$query對像中。您可以使用foreach循環迭代它,如示例所示。
在這種特定情況下(按主鍵ID搜索項目),我們也可以在from()方法中使用快捷方式:
$user_id = 1; $query = $fpdo->from('users')->where('id', $user_id); foreach($query as $row){ echo 'Hello, ' . $row['first_name'] . ' ' . $row['last_name'] . '!'; }
讓我們看看比這更複雜的東西。
選擇特定字段
如果需要,您可以使用from()之後的select()方法選擇特定字段。您只需使用數組告訴FluentPDO您想要選擇哪些字段即可。
這是一個示例:
$fpdo->from('items')->where('price >', 1000);
LIMIT和OFFSET
設置LIMIT和OFFSET參數以僅從數據庫中檢索一定數量的行非常容易。您可以像這樣使用limit()和offset()方法。
$query = fpdo->from('users', $user_id); // 将与...相同 $query = $fpdo->from('users')->where('id', $user_id);
這兩個方法的唯一參數是一個整數,指定所需的值(對於limit(),是項目的數量;對於offset(),是要跳過的項目的數量)。
HAVING、GROUP BY和ORDER BY
還提供了用於“HAVING”、“GROUP BY”和“ORDER BY”指令的方法。
讓我們用一些例子來看看它們。
ORDER BY
orderBy()方法用於根據特定條件對結果進行排序。讓我們舉個例子:以下是按價格(從便宜到貴)對結果進行排序的方法。
$query = $fpdo->from('users')->select(array('first_name', 'last_name'))->where('id', $user_id);
如果要反轉順序(從最貴到最便宜獲取結果),只需在選擇的列之後添加“DESC”即可。
// 选择前十个结果... $query = $fpdo->from('users')->where('id', $user_id)->limit(10)->offset(0);
HAVING
having()方法具有非常簡單的語法。在下面的示例中,我們過濾價格低於2000美元的每個商品。
$query = $fpdo->from('items')->orderBy('price');
非常簡單。
您可以使用所需的任何比較運算符。
GROUP BY
使用groupBy()方法,您可以使用特定字段作為條件對結果進行分組。這裡我們顯示每個品牌的商品數量。
CREATE TABLE IF NOT EXISTS items ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL, brand varchar(100) NOT NULL, price decimal(10,2) NOT NULL, user_id int(10) unsigned NOT NULL, PRIMARY KEY (id), KEY user_id (user_id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=5 ; INSERT INTO items (id, name, brand, price, user_id) VALUES (1, 'Last Awesome Phone', 'Awesome Brand', '550.00', 1), (2, 'Last Awesome TV', 'Awesome Brand', '1200.00', 1), (3, 'Fantastic E-Car', 'E-Cars Inc.', '80000.00', 2), (4, 'Fantastic E-Bike', 'E-Bikes Co. Ltd.', '16000.00', 2); CREATE TABLE IF NOT EXISTS users ( id int(10) unsigned NOT NULL AUTO_INCREMENT, first_name varchar(100) NOT NULL, last_name varchar(100) NOT NULL, signup_date datetime NOT NULL, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3; INSERT INTO users (id, first_name, last_name, signup_date) VALUES (1, 'Francesco', 'Malatesta', '2014-06-29 13:00:00'), (2, 'John', 'Foo Bar', '2014-06-20 11:16:39'); ALTER TABLE items ADD CONSTRAINT items_ibfk_1 FOREIGN KEY (user_id) REFERENCES users (id);
注意:您可以像在經典SQL中一樣為字段指定別名。
獲取方法
fetch
使用foreach不是獲取結果的唯一方法。如果我們只想從集合中檢索第一個結果怎麼辦?
只需使用fetch()方法:
"require": { ... "lichtner/fluentpdo": "dev-master" }
您還可以獲取單個列,方法是指定其名稱作為參數。
$pdo = new PDO("mysql:dbname=wishlist", "root", "password"); $fpdo = new FluentPDO($pdo);
fetchPairs
使用fetchPairs(),您可以將結果作為關聯數組檢索。使用以下語法:
$user_id = 1; $query = $fpdo->from('users')->where('id', $user_id); foreach($query as $row){ echo 'Hello, ' . $row['first_name'] . ' ' . $row['last_name'] . '!'; }
您將獲得如下輸出:
$fpdo->from('items')->where('price >', 1000);
這是一個示例,使用用戶唯一ID和名字。
$query = fpdo->from('users', $user_id); // 将与...相同 $query = $fpdo->from('users')->where('id', $user_id);
fetchAll
最後但並非最不重要的是fetchAll()方法。
以下是語法:
$query = $fpdo->from('users')->select(array('first_name', 'last_name'))->where('id', $user_id);
使用fetchAll(),我們可以完全控制從結果中獲取的內容。第一個參數$index是用作索引的字段,$selectOnly用於指定要選擇的字段。
這是一個示例:
// 选择前十个结果... $query = $fpdo->from('users')->where('id', $user_id)->limit(10)->offset(0);
注意:用作索引的列(在本例中為id)也包含在最終數組中。
好了,關於SELECT操作就足夠了。讓我們看看其他CRUD操作。
INSERT、UPDATE和DELETE
FluentPDO不僅僅是關於選擇東西。它還具有以簡單方式操作數據的類。
讓我們從INSERT操作開始。
INSERT
$query = $fpdo->from('items')->orderBy('price');
insertInto()方法用於指定要用於操作的表。然後,您必須使用values()方法分配所需的值(在本例中,它們存儲在$values關聯數組中)。
最後一步將是execute()方法,它將返回新記錄的主鍵。
如果需要,也可以使用此快捷方式:
$query = $fpdo->from('items')->orderBy('price DESC');
UPDATE
UPDATE方法非常相似。讓我們看一個例子。
$query = $fpdo->from('items')->having('price <', 2000);
使用set()方法,您可以為UPDATE操作指定新值。
使用where()方法,我們過濾受影響的行。還有一個快捷方式,如前所述。
DELETE
DELETE操作更簡單。這是一個快速示例。
$query = $fpdo->from('items')->select('brand, COUNT(*) AS c')->groupBy('brand');
如果要刪除知道其主鍵的記錄,可以使用上面的deleteFrom()快捷方式。
注意:正如您從這裡的示例中看到的,您必須使用execute()方法來運行DELETE查詢。如果不這樣做,您將不會更改數據庫中的任何內容。 INSERT和UPDATE也是如此。請記住這一點。
高級特性
正如我之前告訴您的那樣,這類項目都有其獨特的特性。 FluentPDO也不例外:我們將分析其中的兩個特性:JOIN查詢構建器和調試器。
JOIN查詢構建器
可能是FluentPDO最重要的獨特特性。如果要簡化工作並編寫更少的代碼,構建器非常有用。讓我們看看如何使用它。
我們將從使用FluentPDO編寫的“經典”JOIN查詢開始。
類似這樣:
$query = $fpdo->from('users'); $row = $query->fetch(); var_dump($row); // 将输出: // array(4) { ["id"]=> string(1) "1" ["first_name"]=> string(9) "Francesco" ["last_name"]=> string(9) "Malatesta" ["signup_date"]=> string(19) "2014-06-29 13:00:00" }
好的:我們在特殊的leftJoin()方法中使用經典語法。還不錯。
但是,我們可以做得更好。如果在表結構中使用約定,則可以使用此代碼:
CREATE TABLE IF NOT EXISTS items ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL, brand varchar(100) NOT NULL, price decimal(10,2) NOT NULL, user_id int(10) unsigned NOT NULL, PRIMARY KEY (id), KEY user_id (user_id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=5 ; INSERT INTO items (id, name, brand, price, user_id) VALUES (1, 'Last Awesome Phone', 'Awesome Brand', '550.00', 1), (2, 'Last Awesome TV', 'Awesome Brand', '1200.00', 1), (3, 'Fantastic E-Car', 'E-Cars Inc.', '80000.00', 2), (4, 'Fantastic E-Bike', 'E-Bikes Co. Ltd.', '16000.00', 2); CREATE TABLE IF NOT EXISTS users ( id int(10) unsigned NOT NULL AUTO_INCREMENT, first_name varchar(100) NOT NULL, last_name varchar(100) NOT NULL, signup_date datetime NOT NULL, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3; INSERT INTO users (id, first_name, last_name, signup_date) VALUES (1, 'Francesco', 'Malatesta', '2014-06-29 13:00:00'), (2, 'John', 'Foo Bar', '2014-06-20 11:16:39'); ALTER TABLE items ADD CONSTRAINT items_ibfk_1 FOREIGN KEY (user_id) REFERENCES users (id);
很棒,對吧?好吧,快速確實很酷……但是智能呢?
看看這裡:
"require": { ... "lichtner/fluentpdo": "dev-master" }
它變得更好了。
實際上,FluentPDO理解您想要做什麼,並使用您在select()方法中提供的帶有table.fieldname格式字符串的數據自動構建查詢。
您可以在這裡閱讀最後一個示例的最終構建查詢:
$pdo = new PDO("mysql:dbname=wishlist", "root", "password"); $fpdo = new FluentPDO($pdo);
這看起來確實不錯。
如果需要,當然可以為字段創建別名:
$user_id = 1; $query = $fpdo->from('users')->where('id', $user_id); foreach($query as $row){ echo 'Hello, ' . $row['first_name'] . ' ' . $row['last_name'] . '!'; }
調試器
FluentPDO帶有一個內置的調試器系統,您可以使用它來測試查詢並檢查它們。
它使用簡單的閉包系統。如果要使用調試,只需在連接代碼之後放置此代碼即可。
$fpdo->from('items')->where('price >', 1000);
您可以根據需要自定義閉包,只需記住將$BaseQuery對像作為參數即可。
$BaseQuery對像是BaseQuery類的實例。
結論
FluentPDO是一個小型簡單的項目。它絕對不適合每個項目,並且可以改進——尤其是在它已經休眠了六個月的情況下——但是對於小型/中型應用程序來說,它可能是一個不錯的選擇,以防您不想在遊戲中引入大型框架。由於它的一些特性,例如JOIN查詢構建器,它是一個不錯的折衷方案。
關於FluentPDO入門常見問題解答 (FAQs)
什麼是FluentPDO,為什麼我應該使用它?
FluentPDO是一個使用PDO的PHP SQL查詢構建器。它為創建SQL查詢提供了一個簡單易用的界面,使開發人員更容易與數據庫交互。 FluentPDO對於那些不習慣編寫原始SQL查詢或想要加快開發過程的人特別有用。它支持所有SQL函數,並提供了一種安全的方法來防止SQL注入攻擊。
如何安裝FluentPDO?
FluentPDO可以使用Composer(PHP的依賴項管理器)安裝。您可以通過運行命令composer require envms/fluentpdo
來安裝它。運行此命令後,Composer將把FluentPDO及其依賴項下載並安裝到您的項目中。
如何使用FluentPDO連接到數據庫?
要使用FluentPDO連接到數據庫,您需要創建一個新的FluentPDO類實例。您可以通過將PDO實例傳遞給FluentPDO構造函數來實現。這是一個示例:
$query = fpdo->from('users', $user_id); // 将与...相同 $query = $fpdo->from('users')->where('id', $user_id);
如何使用FluentPDO執行SELECT查詢?
FluentPDO提供了一個簡單的界面來執行SELECT查詢。您可以使用from
方法指定表,並使用select
方法指定列。這是一個示例:
$query = $fpdo->from('users')->select(array('first_name', 'last_name'))->where('id', $user_id);
如何使用FluentPDO執行INSERT查詢?
要執行INSERT查詢,您可以使用insertInto
方法指定表,並使用values
方法指定值。這是一個示例:
CREATE TABLE IF NOT EXISTS items ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL, brand varchar(100) NOT NULL, price decimal(10,2) NOT NULL, user_id int(10) unsigned NOT NULL, PRIMARY KEY (id), KEY user_id (user_id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=5 ; INSERT INTO items (id, name, brand, price, user_id) VALUES (1, 'Last Awesome Phone', 'Awesome Brand', '550.00', 1), (2, 'Last Awesome TV', 'Awesome Brand', '1200.00', 1), (3, 'Fantastic E-Car', 'E-Cars Inc.', '80000.00', 2), (4, 'Fantastic E-Bike', 'E-Bikes Co. Ltd.', '16000.00', 2); CREATE TABLE IF NOT EXISTS users ( id int(10) unsigned NOT NULL AUTO_INCREMENT, first_name varchar(100) NOT NULL, last_name varchar(100) NOT NULL, signup_date datetime NOT NULL, PRIMARY KEY (id) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3; INSERT INTO users (id, first_name, last_name, signup_date) VALUES (1, 'Francesco', 'Malatesta', '2014-06-29 13:00:00'), (2, 'John', 'Foo Bar', '2014-06-20 11:16:39'); ALTER TABLE items ADD CONSTRAINT items_ibfk_1 FOREIGN KEY (user_id) REFERENCES users (id);
如何使用FluentPDO執行UPDATE查詢?
要執行UPDATE查詢,您可以使用update
方法指定表,使用set
方法指定新值,並使用where
方法指定條件。這是一個示例:
"require": { ... "lichtner/fluentpdo": "dev-master" }
如何使用FluentPDO執行DELETE查詢?
要執行DELETE查詢,您可以使用deleteFrom
方法指定表,並使用where
方法指定條件。這是一個示例:
$pdo = new PDO("mysql:dbname=wishlist", "root", "password"); $fpdo = new FluentPDO($pdo);
如何處理FluentPDO中的錯誤?
當發生錯誤時,FluentPDO會拋出異常。您可以使用try-catch塊捕獲這些異常並相應地處理它們。這是一個示例:
$user_id = 1; $query = $fpdo->from('users')->where('id', $user_id); foreach($query as $row){ echo 'Hello, ' . $row['first_name'] . ' ' . $row['last_name'] . '!'; }
如何在FluentPDO中使用事務?
FluentPDO提供了啟動、提交和回滾事務的方法。您可以分別使用beginTransaction
、commit
和rollBack
方法。這是一個示例:
$fpdo->from('items')->where('price >', 1000);
如何使用FluentPDO連接表?
FluentPDO提供了一個簡單的界面來連接表。您可以使用join
方法指定表和條件。這是一個示例:
$query = fpdo->from('users', $user_id); // 将与...相同 $query = $fpdo->from('users')->where('id', $user_id);
以上是fluentpdo入門的詳細內容。更多資訊請關注PHP中文網其他相關文章!

長URL(通常用關鍵字和跟踪參數都混亂)可以阻止訪問者。 URL縮短腳本提供了解決方案,創建了簡潔的鏈接,非常適合社交媒體和其他平台。 這些腳本對於單個網站很有價值

在Facebook在2012年通過Facebook備受矚目的收購之後,Instagram採用了兩套API供第三方使用。這些是Instagram Graph API和Instagram Basic Display API。作為開發人員建立一個需要信息的應用程序

Laravel使用其直觀的閃存方法簡化了處理臨時會話數據。這非常適合在您的應用程序中顯示簡短的消息,警報或通知。 默認情況下,數據僅針對後續請求: $請求 -

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显著减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

這是有關用Laravel後端構建React應用程序的系列的第二個也是最後一部分。在該系列的第一部分中,我們使用Laravel為基本的產品上市應用程序創建了一個RESTFUL API。在本教程中,我們將成為開發人員

PHP客戶端URL(curl)擴展是開發人員的強大工具,可以與遠程服務器和REST API無縫交互。通過利用Libcurl(備受尊敬的多協議文件傳輸庫),PHP curl促進了有效的執行

您是否想為客戶最緊迫的問題提供實時的即時解決方案? 實時聊天使您可以與客戶進行實時對話,並立即解決他們的問題。它允許您為您的自定義提供更快的服務

2025年的PHP景觀調查調查了當前的PHP發展趨勢。 它探討了框架用法,部署方法和挑戰,旨在為開發人員和企業提供見解。 該調查預計現代PHP Versio的增長


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SublimeText3 Linux新版
SublimeText3 Linux最新版

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

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!