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