ログインメカニズムを備えた Silex プロジェクトを構築しました。
Symfony の専門家ではないので、認証プロセスについてはこちらのガイドラインに厳密に従いました: http://silex.sensiolabs.org/doc/providers/security.html
...そして、私の開発環境では問題なく動作します
ただし、プロジェクトを本番サーバーにプッシュすると、Web アプリにログインしようとするたびに次のエラーが表示されます。
[2012-12-18 16:35:33] CRITICAL: Symfony\Component\Security\Core\Exception\AuthenticationCredentialsNotFoundException:
A Token was not found in the SecurityContext. (uncaught exception) at
/my/app/path/vendor/symfony/security/Symfony/Component/Security/Http/Firewall/AccessListener.php line 53 [] []
つまり、AccessListener.php の次のコード
$this->context->getToken());
期待を投げかける
同じコードが私の開発環境で完全に正常に動作するという事実を考えると、それは実稼働サーバーの構成に関係があると思います。
このスレッドhttp://groups.google.com/forum/#!msg/symfony-devs/jKphNy_0Q2Y/vYfkAuyjSHEJを見つけ、プロジェクトの .htaccess に次の行を追加することを提案しています
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization},L]
結果なし。「SecurityContext にトークンが見つかりませんでした」という例外が引き続き発生します。
誰かアイデアはありますか?
編集
の内容$app['security.firewalls']
は次のとおりです
$app->register(new Silex\Provider\SecurityServiceProvider(), array(
'security.firewalls' => array(
'login' => array(
'pattern' => '^/login$'
),
'admin' => array(
'pattern' => '^/',
'form' => array('login_path' => '/login', 'check_path' => '/admin/login_check'),
'logout' => array('logout_path' => '/admin/logout'), // url to call for logging out
'users' => array(
'admin' => array('ROLE_ADMIN', 'SOMEPASSWORD'),
),
)
)
));