2017-01-02 5 views
1

同じApache/2.4、PHP/5.6.27、およびPhalcon/2.0.7パッケージをインストールしたラップトップでローカルdevシステムの再構築が必要でした。そのルートは、以前に/ユーザーから、すべてのURIのために働い正規表現またはプレースホルダを使用したPhalcon 2.xおよび3.xルーティングの分割

$di->set('router', function(){ 
    $router = new \Phalcon\Mvc\Router(); 
    $router->add("/{controller}/{id:\d+}", [ "action" => "index",]); 
    return $router; 
} 

(:サーバー・コードは、ルーティング(と.htaccessコードが正しく、適切に_urlする追加)

オリジナルルーティングコードとは別に正しく動作しているように見えますユーザリストを表示)、/ user/1234(ユーザの表示)、/ user/do_action/1234などのアクションそのルートがちょうど働いたので、私は決してルーティングをより深く扱ったことはありません。このコードは本番環境でも動作しています(私は本番環境で使用されているライブラリをミラーリングしていますが、ローカルで別の動作が得られていますが、それ以外のものが異なる可能性があります。

ローカルで再インストールすると、これらのパスは機能しなくなり、すべてをデフォルト/ index/indexのようにデフォルト設定します。以前と同じPhalcon/Apache/PHP/etcのバージョンを使用していると考えて、そのルートがもはや適切でない理由を理解できません。

回避策の観点から、私はより明示的なパスを試しています。これらの作業:

$router->add("/user", ['controller' => 'user','action'=>'index']); 
$router->add("/user/index", ['controller' => 'user','action'=>'index']); 

しかしダイナミックルーティング方法の仕事(正規表現を使って何、プレースホルダ、変数):

$router->add("/user/:action", ['controller' => 'user','action'=> 1 ]); 
$router->add("/:controller", [ "controller" => 1, "action" => "index",]); 
$router->add("/{controller}", [ "action" => "index",]); 
$router->add("/user/{id:[0-9]+}", ['controller' => 'user','action'=>'index', ]); 

私はこの研究のトンをやったし、何も意味がありません、以外変数/正規表現はよくある問題です。コントローラファイルをスキャンしてすべてのルートを生成するスクリプトを書くのは気にしませんが、それでもID番号を取得するためには{id:\ d +}が必要ですが、この時点では非スターターです。

私も(のphpinfoは、PHPが--with-PCRE-正規表現でコンパイルされ、有効化され、ライブラリのバージョン8.02 2010-03-19示しています。)PCREがインストールされている検証し、作業している

事前にありがとうございます! 私はまた新しいPhalcon/3.0.1にアップグレードしてみて、同じルーティング問題を見ました。私は2.0.7でそれを試して解決しようと考えていました。生産が現在行われているので、別のアップグレードを別の日に保存します。

EDIT 1:httpd.confファイルとhttpdの-ssl.confの

# httpd.conf 

ServerRoot "/usr/local/opt/httpd24" 

Listen 8080 

LoadModule authn_file_module libexec/mod_authn_file.so 
LoadModule authn_core_module libexec/mod_authn_core.so 
LoadModule authz_host_module libexec/mod_authz_host.so 
LoadModule authz_groupfile_module libexec/mod_authz_groupfile.so 
LoadModule authz_user_module libexec/mod_authz_user.so 
LoadModule authz_core_module libexec/mod_authz_core.so 
LoadModule access_compat_module libexec/mod_access_compat.so 
LoadModule auth_basic_module libexec/mod_auth_basic.so 
LoadModule socache_shmcb_module libexec/mod_socache_shmcb.so 
LoadModule reqtimeout_module libexec/mod_reqtimeout.so 
LoadModule filter_module libexec/mod_filter.so 
LoadModule mime_module libexec/mod_mime.so 
LoadModule log_config_module libexec/mod_log_config.so 
LoadModule env_module libexec/mod_env.so 
LoadModule headers_module libexec/mod_headers.so 
LoadModule setenvif_module libexec/mod_setenvif.so 
LoadModule version_module libexec/mod_version.so 
LoadModule ssl_module libexec/mod_ssl.so 
LoadModule unixd_module libexec/mod_unixd.so 
LoadModule status_module libexec/mod_status.so 
LoadModule autoindex_module libexec/mod_autoindex.so 
<IfModule mpm_prefork_module> 
</IfModule> 
<IfModule !mpm_prefork_module> 
</IfModule> 
LoadModule dir_module libexec/mod_dir.so 
LoadModule alias_module libexec/mod_alias.so 
LoadModule rewrite_module libexec/mod_rewrite.so 

<IfModule unixd_module> 
User me 
Group staff 

</IfModule> 

<Directory "/Users/me/app/www"> 
    Options Indexes FollowSymLinks 
    Require all granted 
    AllowOverride All 
</Directory> 



ServerAdmin [email protected] 

ServerName localhost 

<Directory /> 
    AllowOverride none 
    Require all granted 
</Directory> 


DocumentRoot "/usr/local/var/www/htdocs" 
<Directory "/usr/local/var/www/htdocs"> 
    Options Indexes FollowSymLinks 

    AllowOverride None 

    Require all granted 
</Directory> 

<IfModule dir_module> 
    DirectoryIndex index.php 
</IfModule> 

<Files ".ht*"> 
    Require all denied 
</Files> 

ErrorLog "/usr/local/var/log/apache2/error_log" 

LogLevel warn 

<IfModule log_config_module> 
    LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined 
    LogFormat "%h %l %u %t \"%r\" %>s %b" common 

    <IfModule logio_module> 
     LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio 
    </IfModule> 

    CustomLog "/usr/local/var/log/apache2/access_log" common 

</IfModule> 

<IfModule alias_module> 


    ScriptAlias /cgi-bin/ "/usr/local/var/apache2/cgi-bin/" 

</IfModule> 

<IfModule cgid_module> 
</IfModule> 

<Directory "/usr/local/var/apache2/cgi-bin"> 
    AllowOverride None 
    Options None 
    Require all granted 
</Directory> 

<IfModule mime_module> 
    TypesConfig /usr/local/etc/apache2/2.4/mime.types 

    AddType application/x-compress .Z 
    AddType application/x-gzip .gz .tgz 

</IfModule> 

<IfModule proxy_html_module> 
Include /usr/local/etc/apache2/2.4/extra/proxy-html.conf 
</IfModule> 

Include /usr/local/etc/apache2/2.4/extra/httpd-ssl.conf 
<IfModule ssl_module> 
SSLRandomSeed startup builtin 
SSLRandomSeed connect builtin 
</IfModule> 


LoadModule php5_module /usr/libexec/apache2/libphp5.so 

AddType application/x-httpd-php .php 

のhttpd-ssl.confの

# httpd-ssl.conf 

Listen 443 


SSLCipherSuite HIGH:MEDIUM:!MD5:!RC4 
SSLProxyCipherSuite HIGH:MEDIUM:!MD5:!RC4 


SSLHonorCipherOrder on 

SSLProtocol all -SSLv3 
SSLProxyProtocol all -SSLv3 

SSLPassPhraseDialog builtin 

SSLSessionCache  "shmcb:/usr/local/var/run/apache2/ssl_scache(512000)" 
SSLSessionCacheTimeout 300 


<VirtualHost dev.myserver.com:443> 
Options Indexes FollowSymLinks MultiViews 
DocumentRoot "/Users/me/app/www/" 
ServerName dev.myserver.com:443 
ServerAdmin [email protected] 
ErrorLog "/private/var/log/apache2/myserver-error_log" 
CustomLog "/private/var/log/apache2/myserver-access_log" common 


<Directory "/Users/me/app/www/"> 
     RewriteBase /Users/me/app/www/ 
     RewriteEngine On 
     RewriteCond %{REQUEST_FILENAME} !-d 
     RewriteCond %{REQUEST_FILENAME} !-f 
     RewriteRule ^(.*)$ index.php?_url=/$1 [QSA,L] 

    Options Indexes FollowSymLinks 
    Require all granted 
    AllowOverride All 
</Directory> 

TransferLog "/usr/local/var/log/apache2/access_log" 

SSLEngine on 

SSLCertificateFile "/usr/local/etc/apache2/2.4/dev.myserver.com.crt" 

SSLCertificateKeyFile "/usr/local/etc/apache2/2.4/dev.myserver.com.key" 


<FilesMatch "\.(cgi|shtml|phtml|php)$"> 
    SSLOptions +StdEnvVars 
</FilesMatch> 
<Directory "/usr/local/var/apache2/cgi-bin"> 
    SSLOptions +StdEnvVars 
</Directory> 

BrowserMatch "MSIE [2-5]" \ 
     nokeepalive ssl-unclean-shutdown \ 
     downgrade-1.0 force-response-1.0 

CustomLog "/usr/local/var/log/apache2/ssl_request_log" \ 
      "%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b" 

</VirtualHost>         

の.htaccess

<IfModule mod_rewrite.c> 
    RewriteEngine On 
    RewriteCond %{REQUEST_FILENAME} !-d 
    RewriteCond %{REQUEST_FILENAME} !-f 
    RewriteRule ^((?s).*)$ index.php?_url=/$1 [QSA,L] 
</IfModule> 

答えて

0

含め それはあなたのapacheについてです100%の構成です。しかし、あなたはそれを提供していませんでした。例えば、これを確認することができます。https://docs.phalconphp.com/en/latest/reference/routing.html#uri-sources

+0

ありがとう、Juri。 httpd.confファイルとhttpd-ssl.confファイルに追加されました。うまくいけば何かが飛び出すでしょう。私はラインごとに行って、私の仕事の生産設定からこれらをすべて比較しました。私はPhalconのルーティング文書を徹底的に見てきて、それらが提供するいくつかの方法を試しました。 –

関連する問題