1

OSXを実行し、同じApache/2.4、PHP/5.6.27、およびPhalcon/2.0.7パッケージをインストールしたラップトップでローカル開発システムの再構築を行う必要がありました。サーバーコードは、ルーティングを除いて正しく機能しているようです (.htaccess コードは正しく、_url に適切に追加されています)。

元のルーティング コード:

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

このルートは以前は、/user (ユーザー リストを表示) から /user/1234 (ユーザーを表示)、/user/do_action/1234 などのアクションまで、すべての URI で機能していました。そのルートが機能しただけなので、ルーティングについてこれ以上詳しく説明したことはありません。そのままのコードも本番環境で動作しています(本番環境で使用されているライブラリをミラーリングしており、ローカルで異なる動作を取得していますが、発散動作を引き起こしている他の違いもわかりません)。

ローカルに再インストールすると、これらのパスは機能しなくなり、すべてが /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+} が機能する必要がありますが、現時点ではそれは問題ではありません。

また、PCRE がインストールされ、動作していることも確認しました (Phpinfo は、php が --with-pcre-regex でコンパイルされ、有効になっていることを示しています。ライブラリ バージョンは 8.02 2010-03-19 です)。

前もって感謝します!新しい Phalcon/3.0.1 へのアップグレードも試みましたが、同じルーティングの問題が発生しました。2.0.7 で解決しようと思ったのは、2.0.7 が現在の運用環境だからです。他のアップグレードは別の日に取っておきます。

編集 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 you@example.com

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 you@example.com
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>
4

1 に答える 1

0

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

于 2017-01-02T15:24:49.387 に答える