原文來自於:http://blog.jobbole.com/54201/php
做爲一個PHP開發者,如今是一個使人激動的時刻。天天有許許多多有用的庫分發出來,在Github上很容易發現和使用這些庫。下面是我曾經遇到過最酷的24個庫。你最喜歡的庫沒有在這個列表裏面?那就在評論中分享吧!html
Dispatch是一個PHP小框架。它並無給你完整的MVC設置,但你能夠定義URL規則和方法,以便更好組織應用程序。這對API、簡單的站點或原型來講是完美的。jquery
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
//包含庫
include
'dispatch.php'
;
// 定義你的路由
get(
'/greet'
,
function
() {
//渲染視圖
render(
'greet-form'
);
});
//post處理
post(
'/greet'
,
function
() {
$name
= from(
$_POST
,
'name'
);
// render a view while passing some locals
render(
'greet-show'
,
array
(
'name'
=>
$name
));
});
// serve your site
dispatch();
|
你能夠匹配特定類型的HTTP請求和路徑,渲染視圖或作更多事情。若是你合併Dispatch和其餘框架,那你就能夠擁有一個至關強大而且輕量級的程序!ios
Klein是另外一款針對PHP5.3+版本的輕量級路由庫。雖然它有一些比Dispatch冗長的語法,但它至關快。這有一個例子:laravel
1
2
3
|
respond(
'/[:name]'
,
function
(
$request
) {
echo
'Hello '
.
$request
->name;
});
|
你也能夠定製來指定HTTP方法和使用正則表達式做爲路徑。git
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
respond(
'GET'
,
'/posts'
,
$callback
);
respond(
'POST'
,
'/posts/create'
,
$callback
);
respond(
'PUT'
,
'/posts/[i:id]'
,
$callback
);
respond(
'DELETE'
,
'/posts/[i:id]'
,
$callback
);
//匹配多種請求方法:
respond(
array
(
'POST'
,
'GET'
),
$route
,
$callback
);
//你或許也想在相同的地方處理請求
respond(
'/posts/[create|edit:action] /[i:id] '
,
function
(
$request
,
$response
) {
switch
(
$request
->action) {
// do something
}
});
|
對於小型項目來講這是很棒的,但當你把一個像這樣的庫用於大型應用時,你不得不遵照規矩,由於你的代碼可能很快就變得不可維護。因此你最好搭配一個像Laravel或者CodeIgniter這樣徹底成熟的框架。github
Ham也是一款輕量級的路由框架,可是它利用緩存甚至得到了更快的速度。它經過把任何I/O相關的東西緩存進XCache/APC。下面是一個例子:web
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
require
'../ham/ham.php'
;
$app
=
new
Ham(
'example'
);
$app
->config_from_file(
'settings.php'
);
$app
->route(
'/pork'
,
function
(
$app
) {
return
"Delicious pork."
;
});
$hello
=
function
(
$app
,
$name
=
'world'
) {
return
$app
->render(
'hello.html'
,
array
(
'name'
=>
$name
));
};
$app
->route(
'/hello/<string>'
,
$hello
);
$app
->route(
'/'
,
$hello
);
$app
->run();
|
這個庫要求你至少安裝了XCache和APC其中的一個,這可能意味着,在大多數主機提供商提供的主機上它可能用不了。可是若是你擁有一個安裝它們其一的主機,或者你能夠操控你的web服務器,你應該嘗試這款最快的框架。正則表達式
Assetic是一個PHP的資源管理框架,用於合併和減少了CSS/JS資源。下面是例子。shell
1
2
3
4
5
6
7
8
9
10
11
|
use
Assetic\Asset\AssetCollection;
use
Assetic\Asset\FileAsset;
use
Assetic\Asset\GlobAsset;
$js
=
new
AssetCollection(
array
(
new
GlobAsset(
'/path/to/js/*'
),
new
FileAsset(
'/path/to/another.js'
),
));
//當資源被輸出時,代碼會被合併
echo
$js
->dump();
|
以這種方式合併資源是一個好主意,由於它能夠加速站點。不只僅總下載量減少了,也消除了大量沒必要要的HTTP請求(這是最影響頁面加載時間的兩件事)
ImageWorkshop是一個讓你操控帶層圖片的開源庫。藉助它你能夠重定義尺寸、裁剪、製做縮略圖、打水印或作更多事情。下面是一個例子:
1
2
3
4
5
6
7
8
9
10
11
|
// 從norway.jpg圖片初始化norway層
$norwayLayer
= ImageWorkshop::initFromPath(
'/path/to/images/norway.jpg'
);
// 從watermark.png圖片初始化watermark層(水印層)
$watermarkLayer
= ImageWorkshop::initFromPath(
'/path/to/images/watermark.png'
);
$image
=
$norwayLayer
->getResult();
// 這是生成的圖片!
header(
'Content-type: image/jpeg'
);
imagejpeg(
$image
, null, 95);
// We choose to show a JPG with a quality of 95%
exit
;
|
ImageWorkshop被開發用於使一些PHP中最通用的處理圖片的案例簡化,若是你須要一些更強大的東西,你應該看下Imagine library!
Snappy是一個PHP5庫,能夠生成快照、URL、HTML、PDF。它依賴於wkhtmltopdf binary(在Linux,Windows和OSX上均可用)。你能夠像這樣使用它們:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
require_once
'/path/to/snappy/src/autoload.php'
;
use
Knp\Snappy\Pdf;
//經過wkhtmltopdf binary路徑初始化庫
$snappy
=
new
Pdf(
'/usr/local/bin/wkhtmltopdf'
);
//經過把Content-type頭設置爲pdf來在瀏覽器中展現pdf
header(
'Content-Type: application/pdf'
);
header(
'Content-Disposition: attachment; filename="file.pdf"'
);
echo
$snappy
->getOutput(
'http://www.github.com'
);
|
要記得,你的主機提供商可能不容許調用外部二進制程序。
Idiorm是我的以前在本網站教程中用過最喜好的一款。它是一款輕量級的ORM庫,一個創建在PDO之上的PHP5查詢構造器。藉助它,你能夠忘記如何書寫乏味的SQL:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
$user
= ORM::for_table(
'user'
)
->where_equal(
'username'
,
'j4mie'
)
->find_one();
$user
->first_name =
'Jamie'
;
$user
->save();
$tweets
= ORM::for_table(
'tweet'
)
->select(
'tweet.*'
)
->join(
'user'
,
array
(
'user.id'
,
'='
,
'tweet.user_id'
))
->where_equal(
'user.username'
,
'j4mie'
)
->find_many();
foreach
(
$tweets
as
$tweet
) {
echo
$tweet
->text;
}
|
Idiorm有一個姊妹庫叫Paris,Paris是一個基於Idiorm的Active Record實現。
Underscore是原始Underscore.js的一個接口 – Javascript應用的工具腰帶。PHP版本沒有讓人失望,並且支持了幾乎全部原生功能。下面是一些例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
__::each(
array
(1, 2, 3),
function
(
$num
) {
echo
$num
.
','
; });
// 1,2,3,
$multiplier
= 2;
__::each(
array
(1, 2, 3),
function
(
$num
,
$index
)
use
(
$multiplier
) {
echo
$index
.
'='
. (
$num
*
$multiplier
) .
','
;
});
// prints: 0=2,1=4,2=6,
__::reduce(
array
(1, 2, 3),
function
(
$memo
,
$num
) {
return
$memo
+
$num
; }, 0);
// 6
__::find(
array
(1, 2, 3, 4),
function
(
$num
) {
return
$num
% 2 === 0; });
// 2
__::filter(
array
(1, 2, 3, 4),
function
(
$num
) {
return
$num
% 2 === 0; });
// array(2, 4)
|
這個庫也支持鏈式語法,這使得它更爲強大。
Requests是一個簡化HTTP請求的庫。若是你和我同樣,幾乎歷來都記不住傳遞給Curl的各類各樣的參數,那麼它就是爲你準備的:
1
2
3
4
5
6
7
8
9
10
11
12
|
$headers
=
array
(
'Accept'
=>
'application/json'
);
$options
=
array
(
'auth'
=>
array
(
'user'
,
'pass'
));
$request
= Requests::get(
'https://api.github.com/gists'
,
$headers
,
$options
);
var_dump(
$request
->status_code);
// int(200)
var_dump(
$request
->headers[
'content-type'
]);
// string(31) "application/json; charset=utf-8"
var_dump(
$request
->body);
// string(26891) "[…]"
|
藉助這個庫,你能夠發送HEAD、GET、POST、PUT、DELTE和PATCH HTTP請求,你能夠經過數組添加文件和參數,而且能夠訪問全部相應數據。
Buzz是另外一個完成HTTP請求的庫。下面是一個例子:
1
2
3
4
5
6
7
8
|
$request
=
new
Buzz\Message\Request(
'HEAD'
,
'/'
,
'http://google.com'
);
$response
=
new
Buzz\Message\Response();
$client
=
new
Buzz\Client\FileGetContents();
$client
->send(
$request
,
$response
);
echo
$request
;
echo
$response
;
|
由於它缺少文檔,因此你不得不閱讀源碼來獲知它支持的全部參數。
Goutte是一個抓取網站和提取數據的庫。它提供了一個優雅的API,這使得從遠程頁面上選擇特定元素變得簡單。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
require_once
'/path/to/goutte.phar'
;
use
Goutte\Client;
$client
=
new
Client();
$crawler
=
$client
->request(
'GET'
,
'http://www.symfony-project.org/'
);
//點擊連接
$link
=
$crawler
->selectLink(
'Plugins'
)->link();
$crawler
=
$client
->click(
$link
);
//使用一個類CSS語法提取數據
$t
=
$crawler
->filter(
'#data'
)->text();
echo
"Here is the text: $t"
;
|
Carbon 是 DateTime API 的一個簡單擴展。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
printf(
"Right now is %s"
, Carbon::now()->toDateTimeString());
printf(
"Right now in Vancouver is %s"
, Carbon::now(
'America/Vancouver'
));
$tomorrow
= Carbon::now()->addDay();
$lastWeek
= Carbon::now()->subWeek();
$nextSummerOlympics
= Carbon::createFromDate(2012)->addYears(4);
$officialDate
= Carbon::now()->toRFC2822String();
$howOldAmI
= Carbon::createFromDate(1975, 5, 21)->age;
$noonTodayLondonTime
= Carbon::createFromTime(12, 0, 0,
'Europe/London'
);
$endOfWorld
= Carbon::createFromDate(2012, 12, 21,
'GMT'
);
//老是以UTC對比
if
(Carbon::now()->gte(
$endOfWorld
)) {
die
();
}
if
(Carbon::now()->isWeekend()) {
echo
'Party!'
;
}
echo
Carbon::now()->subMinutes(2)->diffForHumans();
// '2分鐘以前'
|
Ubench 是一個用於評測PHP代碼的微型庫,可監控(代碼)執行時間和內存使用率。下面是範例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
use
Ubench\Ubench;
$bench
=
new
Ubench;
$bench
->start();
//執行一些代碼
$bench
->
end
();
//獲取執行消耗時間和內存
echo
$bench
->getTime();
// 156ms or 1.123s
echo
$bench
->getTime(true);
// elapsed microtime in float
echo
$bench
->getTime(false,
'%d%s'
);
// 156ms or 1s
echo
$bench
->getMemoryPeak();
// 152B or 90.00Kb or 15.23Mb
echo
$bench
->getMemoryPeak(true);
// memory peak in bytes 內存峯值
echo
$bench
->getMemoryPeak(false,
'%.3f%s'
);
// 152B or 90.152Kb or 15.234Mb
//在結束標識處返回內存使用狀況
echo
$bench
->getMemoryUsage();
// 152B or 90.00Kb or 15.23Mb
|
(僅)在開發時運行這些校驗是一個好主意。
Validation 聲稱是PHP庫裏最強大的驗證引擎。可是,它能名副其實嗎?看下面:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
use
Respect\Validation\Validator
as
v;
//簡單驗證
$number
= 123;
v::numeric()->validate(
$number
);
//true
//鏈式驗證
$usernameValidator
= v::alnum()->noWhitespace()->length(1,15);
$usernameValidator
->validate(
'alganet'
);
//true
//驗證對象屬性
$user
=
new
stdClass;
$user
->name =
'Alexandre'
;
$user
->birthdate =
'1987-07-01'
;
//在一個簡單鏈中驗證他的屬性
$userValidator
= v::attribute(
'name'
, v::string()->length(1,32))
->attribute(
'birthdate'
, v::
date
()->minimumAge(18));
$userValidator
->validate(
$user
);
//true
|
你能夠經過這個庫驗證你的表單或其餘用戶提交的數據。除此以外,它內置了不少校驗,拋出異常和定製錯誤信息。
Filterus是另外一個過濾庫,但它不只僅能夠驗證,也能夠過濾匹配預設模式的輸出。下面是一個例子:
1
2
3
4
5
|
$f
= Filter::factory(
'string,max:5'
);
$str
=
'This is a test string'
;
$f
->validate(
$str
);
// false
$f
->filter(
$str
);
// 'This '
|
Filterus有不少內建模式,支持鏈式用法,甚至能夠用獨立的驗證規則去驗證數組元素。
Faker 是一個爲你生成假數據的PHP庫。當你須要填充一個測試數據庫,或爲你的web應用生成測試數據時,它能派上用場。它也很是容易使用:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
//引用Faker 自動加載器
require_once
'/path/to/Faker/src/autoload.php'
;
//使用工廠建立來建立一個Faker\Generator實例
$faker
= Faker\Factory::create();
//經過訪問屬性生成假數據
echo
$faker
->name;
// 'Lucy Cechtelar';
echo
$faker
->address;
// "426 Jordy Lodge
// Cartwrightshire, SC 88120-6700"
echo
$faker
->text;
// Sint velit eveniet. Rerum atque repellat voluptatem quia ...
|
只要你繼續訪問對象屬性,它將繼續返回隨機生成的數據。
Mustache是一款流行的模板語言,實際已經在各類編程語言中獲得實現。使用它,你能夠在客戶端或服務段重用模板。 正如你猜得那樣,Mustache.php 是使用PHP實現的。
1
2
|
$m
=
new
Mustache_Engine;
echo
$m
->render(
'Hello {{planet}}'
,
array
(
'planet'
=>
'World!'
));
// "Hello World!"
|
建議看一下官方網站Mustache docs 查看更多高級的例子。
Gaufrette是一個PHP5庫,提供了一個文件系統的抽象層。它使得以相同方式操控本地文件,FTP服務器,亞馬遜 S3或更多操做變爲可能。它容許你開發程序時,不用瞭解將來你將怎麼訪問你的文件。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
use
Gaufrette\Filesystem;
use
Gaufrette\Adapter\Ftp
as
FtpAdapter;
use
Gaufrette\Adapter\Local
as
LocalAdapter;
//本地文件:
$adapter
=
new
LocalAdapter(
'/var/media'
);
//可選地使用一個FTP適配器
// $ftp = new FtpAdapter($path, $host, $username, $password, $port);
//初始化文件系統
$filesystem
=
new
Filesystem(
$adapter
);
//使用它
$content
=
$filesystem
->read(
'myFile'
);
$content
=
'Hello I am the new content'
;
$filesystem
->write(
'myFile'
,
$content
);
|
也有緩存和內存適配器,而且隨後將會增長更多適配器。
Omnipay是一個PHP支付處理庫。它有一個清晰一致的API,而且支持數十個網關。使用這個庫,你僅僅須要學習一個API和處理各類各樣的支付處理器。下面是一個例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
use
Omnipay\CreditCard;
use
Omnipay\GatewayFactory;
$gateway
= GatewayFactory::create(
'Stripe'
);
$gateway
->setApiKey(
'abc123'
);
$formData
= [
'number'
=>
'4111111111111111'
,
'expiryMonth'
=> 6,
'expiryYear'
=> 2016];
$response
=
$gateway
->purchase([
'amount'
=> 1000,
'card'
=>
$formData
]);
if
(
$response
->isSuccessful()) {
//支付成功:更新數據庫
print_r(
$response
);
}
elseif
(
$response
->isRedirect()) {
//跳轉到異地支付網關
$response
->redirect();
}
else
{
//支付失敗:向客戶顯示信息
exit
(
$response
->getMessage());
}
|
使用相同一致的API,能夠很容易地支持多種支付處理器,或在須要時進行切換。
Upload是一個簡化文件上傳和驗證的庫。上傳表單時,這個庫會校驗文件類型和尺寸。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
$storage
=
new
\Upload\Storage\FileSystem(
'/path/to/directory'
);
$file
=
new
\Upload\File(
'foo'
,
$storage
);
//驗證文件上傳
$file
->addValidations(
array
(
//確保文件類型是"image/png"
new
\Upload\Validation\Mimetype(
'image/png'
),
//確保文件不超過5M(使用"B","K","M"或者"G")
new
\Upload\Validation\Size(
'5M'
)
));
//試圖上傳文件
try
{
//成功
$file
->upload();
}
catch
(\Exception
$e
) {
//失敗!
$errors
=
$file
->getErrors();
}
|
它將減小很多乏味的代碼。
HTMLPurifier是一個HTML過濾庫,經過強大的白名單和彙集分析,保護你代碼遠離XSS攻擊。它也確保輸出標記符合標準。 (源碼在github上)
1
2
3
4
5
|
require_once
'/path/to/HTMLPurifier.auto.php'
;
$config
= HTMLPurifier_Config::createDefault();
$purifier
=
new
HTMLPurifier(
$config
);
$clean_html
=
$purifier
->purify(
$dirty_html
);
|
若是你的網站容許用戶提交 HTML 代碼,不修改就展現代碼的話,那這時候就是用這個庫的時候了。
ColorJizz是一個簡單的庫,藉助它你能夠轉換不一樣的顏色格式,而且作簡單的顏色運算
1
2
3
4
5
6
7
|
use
MischiefCollective\ColorJizz\Formats\Hex;
$red_hex
=
new
Hex(0xFF0000);
$red_cmyk
=
$hex
->toCMYK();
echo
$red_cmyk
;
// 0,1,1,0
echo
Hex::fromString(
'red'
)->hue(-20)->greyscale();
// 555555
|
它已經支持而且能夠操控全部主流顏色格式了
phpgeo是一個簡單的庫,用於計算地理座標之間高精度距離。例如:
1
2
3
4
5
6
7
8
|
use
Location\Coordinate;
use
Location\Distance\Vincenty;
$coordinate1
=
new
Coordinate(19.820664, -155.468066);
// Mauna Kea Summit 茂納凱亞峯
$coordinate2
=
new
Coordinate(20.709722, -156.253333);
// Haleakala Summit
$calculator
=
new
Vincenty();
$distance
=
$calculator
->getDistance(
$coordinate1
,
$coordinate2
);
// returns 128130.850 (meters; ≈128 kilometers)
|
它將在使用地理位置數據的app裏出色工做。你能夠試譯 HTML5 Location API,雅虎的API(或二者都用,咱們在weather web app tutorial中這樣作了),來獲取座標。
藉助 ShellWrap 庫,你能夠在PHP代碼裏使用強大的 Linux/Unix 命令行工具。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
require
'ShellWrap.php'
;
use
\MrRio\ShellWrap
as
sh;
//列出當前文件下的全部文件
echo
sh::ls();
//檢出一個git分支
sh::git(
'checkout'
,
'master'
);
//你也能夠經過管道把一個命令的輸出用戶另外一個命令
//下面經過curl跟蹤位置,而後經過grep過濾’html’管道來下載example.com網站
echo
sh::grep(
'html'
, sh::curl(
'http://example.com'
,
array
(
'location'
=> true
)));
//新建一個文件
sh::touch(
'file.html'
);
//移除文件
sh::rm(
'file.html'
);
//再次移除文件(此次失敗了,而後由於文件不存在而拋出異常)
try
{
sh::rm(
'file.html'
);
}
catch
(Exception
$e
) {
echo
'Caught failing sh::rm() call'
;
}
|
當命令行裏發生異常時,這個庫拋出異常,因此你能夠及時對之作出反應。它也能夠經過管道讓你一個命令的輸出做爲另外一個命令的輸入,來實現更強的靈活性。