1.ディスパッチ - マイクロフレームワーク
Dispatch は PHP 用の小さなフレームワークです。完全なMVCのセットアップはできませんが、URLルールやメソッドを定義してアプリケーションをよりよくまとめることができます。APIやシンプルなサイト、プロトタイプに最適です。
//含まれるライブラリ
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リクエストとパスをマッチさせたり、ビューをレンダリングしたり、他にもいろいろできます。chを他のフレームワークと組み合わせれば、かなりパワフルで軽量なアプリケーションを作ることができます!
クライン - PHP ライトニング・ファスト・ルーティング
Kleinも PHP バージョン 5.3 以降用の軽量なルーティングライブラリです。Dispatchよりも長い構文がありますが、かなり高速です。以下に例を示します:
respond('/[:name]', function ($request) {
echo 'Hello ' . $request->name;
});
HTTPメソッドを指定したり、正規表現をパスとして使用するようにカスタマイズすることもできます。
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のような本格的なフレームワークと組み合わせる方が良いでしょう。
3. Ham - キャッシュ機能付きルーティングライブラリ
Hamも軽量なルーティングフレームワークですが、キャッシュを使うことでさらに高速になります。XCache/APCにI/Oに関連するものをキャッシュすることでこれを実現しています:
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のどちらかがインストールされている必要があり、おそらくほとんどのホスティングプロバイダでは動作しないことを意味します。しかし、もしこれらのうちの1つがインストールされているホストをお持ちなら、あるいはウェブサーバにアクセスできるなら、この最速のフレームワークを試してみるべきです。
4.アセティック--資源管理
Asseticは、CSS/JSリソースのマージと削減を行うPHPリソース管理フレームワークです。以下に例を示します。
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リクエストの多くを排除することができます!
#p#
5.ImageWorkshop-レイヤーによるイメージ処理
ImageWorkshopは、レイヤーを使ってイメージを操作できるオープンソースライブラリです。このライブラリを使うと、サイズの再定義、トリミング、サムネイルの作成、透かしなど、さまざまなことができます。以下に例を示します:
// ノルウェーより.jpgノルウェー・レイヤーを初期化するイメージ
$norwayLayer = ImageWorkshop::initFromPath('/path/to/images/norway.jpg');
// 透かしから.pngイメージ初期化透かしレイヤー
$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でイメージを処理する際に最も一般的ないくつかのケースをより簡単にするために開発されました!
6.スナップショット/PDFライブラリ
スナップショット、URL、HTML、PDFを生成するPHP5ライブラリです:
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://..com');
ホスティングプロバイダが外部バイナリの呼び出しを許可していない可能性があることに注意してください。
7. Idiorm - 軽量ORMライブラリ
Idiorm は個人的にお気に入りで、このサイトのチュートリアルでも使っています。軽量な ORM ライブラリで、PDO の上に構築された PHP5 のクエリコンストラクタです。これを使えば、面倒なSQLの書き方を忘れることができます:
$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;
}
8.アンダースコア - PHPのツールベルト
__::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)
このライブラリは連鎖構文もサポートしており、さらに強力になっています。
9.リクエスト - シンプルなHTTPリクエスト
RequestsはHTTPリクエストを簡素化するライブラリです。もしあなたが私のように、rlに渡される多種多様なパラメータをほとんど覚えていないのであれば、このライブラリはあなたのためのものです:
$headers = array('Accept' => 'application/json');
$options = array('auth' => array('user', 'pass'));
$request = Requests::get('https://..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リクエストを送信したり、配列を介してファイルやパラメータを追加したり、対応するすべてのデータにアクセスしたりすることができます。
#p#
10. Buzz - シンプルな HTTP リクエストライブラリ
BuzzもHTTPリクエストを完了させるためのライブラリです。以下はその例です:
$request = new Buzz\Message\Request('HEAD', '/', 'http://.com');
$response = new Buzz\Message\Response();
$client = new Buzz\Client\FileGetContents();
$client->send($request, $response);
echo $request;
echo $response;
ドキュメントがないため、サポートしているすべてのパラメータについて知るにはソースコードを読む必要があります。
11. Goutte - ウェブクローラライブラリ
Goutteウェブサイトをクロールしてデータを抽出するためのライブラリです。リモートページから特定の要素を簡単に選択できるエレガントなAPIを提供します。
require_once '/path/to/goutte.phar';
use Goutte\Client;
$client = new Client();
$crawler = $client->request('GET', 'http://.symfony-.org/');
//リンクをクリックする
$link = $crawler->selectLink('Plugins')->link();
$crawler = $client->click($link);
//CSSライクな構文を使ってデータを抽出する
$t = $crawler->filter('#data')->text();
echo "Here is the text: $t";
12. Carbon - DateTime ライブラリ
Carbon は DateTime API のシンプルな拡張です。
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
13. Ubench - マイクロベンチマークライブラリ
Ubench は PHP コードを評価し、実行時間やメモリ使用量を監視するためのミニライブラリです。以下に例を示します:
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
開発時にこれらのチェックを実行するのは良いアイデアです。
14.バリデーション - 入力検証エンジン
バリデーションは、PHP ライブラリの中で最も強力なバリデーションエンジンだと主張しています。しかし、その名に恥じないものなのでしょうか?以下を参照ください:
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
このライブラリを使用して、フォームやその他のユーザが送信したデータを検証することができます。これに加えて、組み込みのチェックサムや例外のスロー、 カスタムのエラーメッセージが多数用意されています。
#p#
15.Filterus - フィルタリングライブラリ
Filterusはもうひとつのフィルタリングライブラリですが、単に検証するだけでなく、あらかじめ設定されたパターンにマッチする出力をフィルタリングします。以下はその例です:
$f = Filter::factory('string,max:5');
$str = 'This is a test string';
$f->validate($str); // false
$f->filter($str); // 'This '
Filterusには多くの組み込みモードがあり、連鎖的な使用をサポートし、独立した検証ルールで配列要素を検証することもできます。
16.フェイカー - 偽のデータジェネレーター
Faker は、偽のデータを生成してくれる PHP ライブラリです。テスト用のデータベースにデータを投入したり、ウェブアプリケーションのテストデータを生成したりするときに便利です。使い方もとても簡単です:
//引用Faker 自动加载器
require_once '/path/to/Faker/src/autoload.php';
//Factory Createを使って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 ...
オブジェクトのプロパティにアクセスし続ける限り、ランダムに生成されたデータを返し続けます。
17. Mustache.php - エレガントテンプレートライブラリ
Mustache は、様々なプログラミング言語で実際に実装されている有名なテンプレート言語です。これを使うことで、クライアントやサービスセグメントでテンプレートを再利用することができます。 お察しの通り、Mustache.phpはPHPで実装されています。
$m = new Mustache_Engine;
echo $m->render('Hello {{planet}}', array('planet' => 'World!')); // "Hello World!"
より高度な例については、Mustache docs 公式ドキュメントを 参照することをお勧めします。
18. Gaufrette - ファイルシステム抽象化レイヤ
Gaufretteは、ファイルシステムの抽象化レイヤーを提供するPHP5ライブラリです。これにより、ローカルファイル、FTPサーバー、Amazon S3、またはそれ以上の操作を同じ方法で操作することが可能になります。これにより、将来どのようにファイルにアクセスするかを理解することなくプログラムを開発することができます。
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);
また、キャッシュアダプターやメモリーアダプターもあり、今後も追加される予定です。
19.オムニペイ - 決済処理ライブラリ
OmnipayはPHPの決済処理ライブラリです。明確で一貫性のあるAPIを持ち、数十のゲートウェイをサポートしています。このライブラリを使用するには、単にAPIを学び、多種多様な決済処理業者に対応する必要があります。以下はその例です:
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を使用することで、複数の支払処理業者をサポートしたり、必要に応じて切り替えたりすることが簡単にできます。
20.アップロード - ファイルのアップロードを処理します。
Uploadは、ファイルのアップロードと検証を簡素化するライブラリです。フォームをアップロードするとき、このライブラリはファイルのタイプとサイズをチェックします。
$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以下であることを確認する。
new \Upload\Validation\Size('5M')
));
//ファイルをアップロードしようとする
try {
//成功
$file->upload();
} catch (\Exception $e) {
// !
$errors = $file->getErrors();
}
面倒なコードをかなり減らすことができます。
#p#
21.HTMLPurifier-HTMLのXSS保護
HTMLPurifierは、強力なホワイトリストと集約分析によってXSS攻撃からコードを保護するHTMLフィルタリングライブラリです。また、出力されるマークアップが標準に準拠していることを保証します。
require_once '/path/to/HTMLPurifier.auto.php';
$config = HTMLPurifier_Config::createDefault();
$purifier = new HTMLPurifier($config);
$clean_html = $purifier->purify($dirty_html);
ユーザーがHTMLコードを投稿し、それを修正せずに表示できるサイトであれば、このライブラリの出番です。
22. ColorJizz-PHP - 色操作ライブラリ
ColorJizzは、異なるカラーフォーマットを変換し、簡単な色演算を行うことができるシンプルなライブラリです。
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
すでにすべての主要なカラーフォーマットをサポートし、操作できます!
23. PHP Geo - 地理位置情報ライブラリ
phpgeo は、地理座標間の高精度な距離を計算するためのシンプルなライブラリです。例
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)
24.ShellWrap - エレガントなコマンドラインラッパー
ShellWrap ライブラリを使用すると、強力な Linux/Unix コマンドラインツールを PHP コードで使用することができます。
require 'ShellWrap.php';
use \MrRio\ShellWrap as sh;
//現在のファイルの下にあるすべてのファイルを一覧表示する
echo sh::ls();
//gitブランチをチェックアウトする
sh::git('checkout', 'master');
//あるコマンドの出力をパイプで別のコマンドに渡すこともできる。
//以下は、curlで位置を追跡し、grepで'html'パイプをフィルタリングしてサンプルをダウンロードする。.com
echo sh::grep('html', sh::curl('http://.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';
}





