PhalCon+는 PhalConphp를 기반으로 한 경량 Zephir/C 프레임 워크입니다. Phalcon 개발자를위한 1 단계 솔루션을 구축하고자합니다. 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
[phalconplus bootstrap :: __ construct] -> | sys :: init, initconf | a1 (superApp :: env with env, runmode)
a1-> | sys :: iniapp, 글로벌 상수 정의, 첫 번째 모듈은 1 차 | A2 (SuperApp :: BootPrimaryModule)
a2-> | 유효한 모듈이 있는지 확인하십시오 : Web/Cli/Srv | a3 (moduledef)
a3-> | superApp :: booted -> true 할당, defaultModule | a4 (superApp :: registerModule with moduledef)
a4-> |이 모듈이 SuperApp :: 모듈에서 실행되지 않도록하십시오 | a5 (체크 아웃 모듈)
A5-> | AbstractModule :: RegesterAutoloaders/RegisterServices/RegisterEvents | a6 (sys :: load composerautoloadpath)
A6-> A7 (SuperApp :: 핸들)
a7-> | params = func_get_args, 이벤트 : SuperApp : perectexeCmodule | B1 (superApp :: defaultModule-> exec with params)
B1-> | 이벤트 : SuperApp : AfterExecModule | B2 (AbstractModule :: RegisterEngine)
B2-> | 이벤트 : 모듈 : 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 :: Handler IS}
C2-> | 요청 : guzzlehttp \ psr7 \ serverrequest | c21 (psrhandler :: hands) -> d1
c2-> | reqeust : 문자열 | c22 (phalcon mvc application :: hands) -> d1
C2-> C23 (제외 : 유효하지 않은 핸들러)
b33-> c3 {application.handler == yar?}
C3-> | 예 | C31 (yarservice :: hands) -> d1
C3-> | no | c32 (simpleservice :: hands) -> d1
D1 (이벤트 : 모듈 : Af
# 下载骨架
➜ 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 ...
...
...
웹 모듈의 구조는 다음과 같습니다. 모든 모드는 CLI 및 RPCService를 포함한 웹 모듈에 통합됩니다.
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 :)