phalconplus
1.0.0
Phalcon+は、PhalConphpに基づいた軽量のゼフィル/Cフレームワークです。 Phalcon開発者向けのワンステップソリューションを構築したいと考えています。それはまさに、ファルコンの非常に高い柔軟性があるため、開発者があまりにも多くの選択肢を提供します。交差点が多すぎて迷子になるのは簡単な場合があるため、この一連の選択を行った後、プロセスを記録し、現在のPhalcon+に徐々に進化しました。すべての開発者がこれらの選択を繰り返し行わないようにするために、私は断固としてオープンソースのPhalcon+がコミュニケーションと学習をするために断固としてオープンソースのPhalcon+です。
そのため、要約すると、Phalcon+はまったく新しいフレームワークではなく、Phalconフレームワークの優れた実践です。これは、Phalconフレームワークの再処理と補足です。 Phalcon開発者がより簡単に開始してマスターし、最終的に人間と自然の間の最高レベルの統一に到達できるようになります。
* PHP 7.0 or above
* cPhalcon 3.4.x,在官方发布3.4.6之前一定要下载此分支,通过`zephir build`手动编译phalcon - https://github.com/phalcon/cphalcon/tree/3.4.x
> 安装zephir之前,需要先安装扩展 https://github.com/phalcon/php-zephir-parser ,然后使用`composer`安装`zephir`
`composer global require phalcon/zephir`
Srv RPCサービスを提供し、 Web Restful Servicesを提供できますApp::import("test")を介してプロジェクトの他のモジュールで紹介できます ➜ git clone https://github.com/bullsoft/phalconplus.git
➜ cd phalconplus/ext/
➜ /usr/bin/phpize
➜ ./configure --with-php-config=/usr/bin/php-configure
➜ make
➜ make install
グラフTD
a [phalconplus bootstrap :: __ construct] - > | sys :: init、initconf | a1(superapp :: env、runmodeを備えたブート)
a1 - > | sys :: iniapp、グローバル定数を定義し、最初のモジュールはプライマリです| a2(superapp :: bootprimarymodule)
a2 - > |有効なモジュールがあることを確認してください:web/cli/srv | a3(moduledef)
a3 - > | superapp :: booted-> trueを割り当てる、これをdefaultmodule | a4(superapp :: registermodule with moduledef)
a4 - > |このモジュールがsuperapp ::モジュールで実行されていないことを確認してください| a5(チェックアウトモジュール)
A5 - > | AbstractModule :: RegisterAutoloaders/registerServices/RegisterEvents | A6(sys :: load composerautoloadpath)
a6-> a7(superapp :: handle)
a7 - > | params = func_get_args、event:superapp:beforeexecmodule | b1(superapp :: defaultmodule-> exec with params)
b1-> | event:superapp:afterexecmodule | b2(abstractmodule :: registerengine)
b2-> | event:module:beforestartengine | b3(abstractmodule :: exec with params)
b3-> b31(runmode:cli) - > c1(phalcon cli console :: handle) - > d1
b3-> b32(runmode:web)
b3-> b33(runmode:srv)
B32-> c2 {Engine web ::ハンドラーは}
c2-> | request:guzzlehttp \ psr7 \ serverRequest | c21(psrhandler :: handle) - > d1
c2-> | reqeust:string | c22(phalcon mvc application :: handle) - > d1
c2-> c23(除く:無効なハンドラー)
b33-> c3 {application.handler == yar?}
c3-> | yes | c31(yarservice :: handle) - > d1
c3-> | no | c32(simpleservice :: handle) - > d1
d1(イベント:モジュール:afterstartengine) - > | event:superapp:afthexecmodule | d2(return)
# 下载骨架
➜ composer create-project bullsoft/fp-project fp-app
# 生成模块,假设生成的模块名为test
➜ cd fp-app
➜ ./common/bin/fp-devtool module:create
现在开始引导您创建Phalcon+模块 ...
Step 1 请输入该模块的名称,如"api"
[Enter]: test
Step 2 ...
...
...
Webモジュールの構造は次のとおりです。すべてのモードは、CLIやRPCServiceを含むWebモジュールに統合されています。
test
.
├── app
│ ├── Module.php
│ ├── auth
│ │ ├── AclResources.php
│ │ ├── Model.php
│ │ ├── Resources
│ │ │ ├── Actions.php
│ │ │ └── Models.php
│ │ └── User.php
│ ├── config
│ │ └── dev.php
│ ├── controllers
│ │ ├── BaseController.php
│ │ ├── ErrorController.php
│ │ ├── IndexController.php
│ │ ├── UserController.php
│ │ └── apis
│ │ └── DemoController.php
│ ├── events
│ │ ├── Acl.php
│ │ ├── AppConsole.php
│ │ ├── AppHandler.php
│ │ ├── BackendServer.php
│ │ ├── Db.php
│ │ ├── EventProvider.php
│ │ ├── Model.php
│ │ ├── MvcDispatch.php
│ │ ├── Router.php
│ │ ├── SuperApp.php
│ │ └── View.php
│ ├── exceptions
│ │ ├── EnumExceptionCode.php
│ │ ├── Handler.php
│ │ ├── UnknownException.php
│ │ ├── UserAlreadyExistsException.php
│ │ └── UserNotExistsException.php
│ ├── plugins
│ │ └── Volt.php
│ ├── providers
│ │ ├── CookieServiceProvider.php
│ │ ├── CryptServiceProvider.php
│ │ ├── DatabaseServiceProvider.php
│ │ ├── DispatcherServiceProvider.php
│ │ ├── LoggerServiceProvider.php
│ │ ├── RedisServiceProvider.php
│ │ ├── RouterServiceProvider.php
│ │ ├── RpcServiceProvider.php
│ │ ├── ServiceProvider.php
│ │ ├── SessionServiceProvider.php
│ │ ├── UrlServiceProvider.php
│ │ └── ViewServiceProvider.php
│ ├── routes
│ │ ├── Api.php
│ │ └── Bare.php
│ └── views
│ ├── error
│ │ ├── show403.volt
│ │ ├── show404.volt
│ │ └── show500.volt
│ ├── index
│ │ └── index.volt
│ └── index.volt
├── cli
│ ├── init.php
│ └── tasks
│ └── HelloTask.php
├── public
│ ├── index.php
│ └── rpc.php
├── src
│ ├── models
│ │ └── UserModel.php
│ ├── protos
│ │ ├── Enums
│ │ │ └── UserStatus.php
│ │ └── Schemas
│ │ └── RegInfo.php
│ └── services
│ ├── BaseService.php
│ └── DemoService.php
└── var
└── cache
➜ ./common/bin/fp-devtool server:start test
正在为您启动服务器...
{
" command " : " { (php -S 0.0.0.0:8181 -t public/ .htrouter.php) <&3 3<&- 3>/dev/null & } 3<&0;pid= $! ; echo $pid > /path/to/test/var/run/server.pid " ,
" pid " : 8249,
" running " : true,
" signaled " : false,
" stopped " : false,
" exitcode " : -1,
" termsig " : 0,
" stopsig " : 0
}
... 启动成功,请使用 http://127.0.0.1:8181 访问 ➜ cd test
➜ ../vendor/bin/ppm start --bridge="PhalconPlus\Bridge" --bootstrap="PhalconPlus\Bootstrap" --static-directory=public/ --port=8181 --workers=2
もちろん、構成ファイルを作成して、毎回開始しやすくすることもできます
➜ cd test
➜ touch ppm.json
➜ ../vendor/bin/ppm start -c ppm.json
ppm.jsonの内容は次のとおりです。
{
"bridge" : " PhalconPlus \ Bridge " ,
"host" : " 127.0.0.1 " ,
"port" : 8181 ,
"workers" : 2 ,
"app-env" : " dev " ,
"debug" : 1 ,
"logging" : 1 ,
"static-directory" : " public/ " ,
"bootstrap" : " PhalconPlus \ Bootstrap " ,
"max-requests" : 1000 ,
"concurrent-requests" : 20 ,
"php-cgi" : " /usr/local/opt/[email protected]/bin/php "
} ➜ composer require spiral/roadrunner
➜ cd test
➜ touch .rr.json
➜ touch psr-worker.php
.rr.jsonの内容は次のとおりです。
{
"http" : {
"address" : " 0.0.0.0:8181 " ,
"workers" : {
"command" : " /usr/local/opt/[email protected]/bin/php psr-worker.php " ,
"relay" : " unix://rr.sock " ,
"pool" : {
"numWorkers" : 2
}
}
},
"static" : {
"enable" : true ,
"dir" : " public " ,
"forbid" : [ " .php " , " .htaccess " ]
}
}psr-worker.phpの内容は次のとおりです。
<?php
use Spiral Goridge ;
use Spiral RoadRunner ;
use PhalconPlus Http PsrResponseFactory ;
ini_set ( ' display_errors ' , ' stderr ' );
$ app = ( new PhalconPlus Bootstrap ( __DIR__ ))-> app ();
$ worker = new RoadRunner Worker (
new Goridge SocketRelay ( __DIR__ . " /rr.sock " , null , Goridge SocketRelay:: SOCK_UNIX )
);
$ psr7 = new RoadRunner PSR7Client ( $ worker );
while ( $ req = $ psr7 -> acceptRequest ()) {
try {
$ resp = $ app -> handle ( $ req );
} catch ( Throwable $ e ) {
Test Exceptions Handler:: catch ( $ e );
$ resp = $ app -> response ();
}
$ psr7 -> respond (PsrResponseFactory:: create ( $ resp ));
$ app -> terminate ();
unset( $ req , $ resp );
}次に、モジュールディレクトリで実行します
➜ rr serve -d -v
構成ファイル
server {
listen 8181 ;
server_name localhost;
access_log /var/log/nginx/test.access.log;
index index.php index.html index.htm;
set $root_path '/home/work/wwwroot/fp-app/test/public' ;
root $root_path ;
try_files $uri $uri / @rewrite;
location @rewrite {
rewrite ^/(.*)$ /index.php last ;
}
location ~ .php {
fastcgi_pass unix:/run/php/php7.2-fpm.sock;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name ;
}
location ~* ^/(css|img|js|flv|swf|download)/(.+)$ {
root $root_path ;
}
location ~ /.ht {
deny all ;
}
}どんなフィードバックも大歓迎です。私はすべての人から寄付とサポートを受けたいと思っています。
私はあなたにすべての最高を願っています、兄弟82 :)