PHP 開発者が知っておくべき 24 のライブラリ
PHP 開発者にとって、今は素晴らしい時代です。 Github では、簡単に見つけて使用できる便利なライブラリが毎日大量に配布されています。以下に、私がこれまで出会った中で最もクールなライブラリを 24 個紹介します。あなたのお気に入りの図書館がこのリストに載っていませんか?コメントでシェアしてください!
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 リクエストとパスを照合したり、ビューをレンダリングしたり、その他のことを行うことができます。 Dispatch を他のフレームワークと組み合わせると、非常に強力で軽量なプログラムを作成できます。
Klein は、PHP5.3+ 用のもう 1 つの軽量ルーティング ライブラリです。 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 のような完全に成熟したフレームワークを使用する方がよいでしょう。
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/', $hello); $app->route('/', $hello); $app->run();
このライブラリを使用するには、XCache と APC の少なくとも 1 つがインストールされている必要があります。これは、ほとんどのホスティング プロバイダーが提供するホストでは利用できない可能性があることを意味します。ただし、これらのいずれかがインストールされているホストがある場合、または Web サーバーを制御できる場合は、この最速のフレームワークを試してください。
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 リクエストが削除されます (ページの読み込み時間に最も影響を与える 2 つの要素)
ImageWorkshop は、レイヤー化された画像を操作できるオープンソース ライブラリです。これを使用すると、サイズ変更、トリミング、サムネイルの作成、透かしなどを行うことができます。以下に例を示します:
// 从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 ライブラリをチェックしてください。
Snappy は、スナップショット、URL、HTML、PDF を生成できる PHP5 ライブラリです。これは、wkhtmltopdf バイナリ (Linux、Windows、および OSX で利用可能) に依存しています。次のように使用できます:
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 は、以前この Web サイトのチュートリアルで使用した私のお気に入りです。これは軽量の 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; }
Idiorm には Paris という姉妹ライブラリがあり、これは Idiorm に基づいた Active Record 実装です。
Underscore は、JavaScript アプリケーション用のツールベルトであるオリジナルの Underscore.js へのインターフェイスです。 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)
このライブラリはチェーン構文もサポートしているため、さらに強力になります
Requests は、HTTP リクエストを簡素化するライブラリです。あなたも私と同じで、Curl に渡されるさまざまなパラメータをほとんど覚えていない場合は、これが最適です:
$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 つのライブラリです。以下に例を示します:
$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 は、Web サイトをクローリングしてデータを抽出するためのライブラリです。リモート ページから特定の要素を簡単に選択できるエレガントな API を提供します。
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 的一个简单扩展。
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代码的微型库,可监控(代码)执行时间和内存使用率。下面是范例:
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库里最强大的验证引擎。但是,它能名副其实吗?看下面:
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是另一个过滤库,但它不仅仅可以验证,也可以过滤匹配预设模式的输出。下面是一个例子:
$f = Filter::factory('string,max:5'); $str = 'This is a test string'; $f->validate($str); // false $f->filter($str); // 'This '
Filterus有很多内建模式,支持链式用法,甚至可以用独立的验证规则去验证数组元素。
Faker 是一个为你生成假数据的PHP库。当你需要填充一个测试数据库,或为你的web应用生成测试数据时,它能派上用场。它也非常容易使用:
//引用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实现的。
$m = new Mustache_Engine; echo $m->render('Hello {{planet}}', array('planet' => 'World!')); // "Hello World!"
建议看一下官方网站Mustache docs 查看更多高级的例子。
Gaufrette是一个PHP5库,提供了一个文件系统的抽象层。它使得以相同方式操控本地文件,FTP服务器,亚马逊 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);
也有缓存和内存适配器,并且随后将会增加更多适配器。
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,可以很容易地支持多种支付处理器,或在需要时进行切换。
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(使用"B","K","M"或者"G") new \Upload\Validation\Size('5M') )); //试图上传文件 try { //成功 $file->upload(); } catch (\Exception $e) { //失败! $errors = $file->getErrors(); }
它将减少不少乏味的代码。
HTMLPurifier是一个HTML过滤库,通过强大的白名单和聚集分析,保护你代码远离XSS攻击。它也确保输出标记符合标准。
require_once '/path/to/HTMLPurifier.auto.php'; $config = HTMLPurifier_Config::createDefault(); $purifier = new HTMLPurifier($config); $clean_html = $purifier->purify($dirty_html);
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
它已经支持并且可以操控所有主流颜色格式了
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)
借助 ShellWrap 库,你可以在PHP代码里使用强大的 Linux/Unix 命令行工具。
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'; }
当命令行里发生异常时,这个库抛出异常,所以你可以及时对之做出反应。它也可以通过管道让你一个命令的输出作为另一个命令的输入,来实现更强的灵活性。