ユーザが生成したバグレポートのためにhttp://www.example.com/submit-bugにPOSTを行っている約40のC#デスクトップアプリケーションがあります。単一のURL POSTを.htaccess内のGETリダイレクトに変更する方法を教えてください。
しかし、私は最近、私のウェブサイト(POSTデータが処理されるところ)をHTTPSに切り替えたので、htaccess経由でHTTPSにすべてが301'edになりました。
これはまた、http://www.example.com/submit-bugへの私のPOSTがhttps://www.example.com/submit-bugに301'されていることを意味します。これはPOSTからGETリダイレクトに向かう途中ですべてのPOSTデータが失われる原因となります。
投稿をhttp://www.example.com/submit-bugにリダイレクトするのを無視するようにhtaccessに指示するには、Laravelが使用する通常のindex.phpルーティングをそのまま続けます。
私はLとPフラグのあらゆる種類の組み合わせを試しましたが、無視されるか、または500/404エラーが発生します。
これは、あなたがRewriteCond %{HTTPS} off
前に、先頭に追加することにより、任意のリダイレクトを削除するか、POSTに関して書き換えることができます私の現在のhtaccess
RewriteEngine On
#RewriteCond %{REQUEST_URI} (.*)submit-bug(.*)
#RewriteRule^index.php [L]
RewriteCond %{HTTPS} off
# First rewrite to HTTPS:
# Don't put www. here. If it is already there it will be included, if not
# the subsequent rule will catch it.
RewriteRule .* https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
# Now, rewrite any request to the wrong domain to use www.
# [NC] is a case-insensitive match
RewriteCond %{HTTP_HOST} !^www\. [NC]
RewriteRule .* https://www.%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
# Redirect Trailing Slashes If Not A Folder...
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)/$ /$1 [L,R=301]
# Handle Front Controller...
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule^index.php [L]
# Handle Authorization Header
RewriteCond %{HTTP:Authorization} .
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
素晴らしいです!だから私は最終的に必要なすべてが\t するRewriteCondの%{REQUEST_METHOD} POST のRewriteRule^index.phpを[L]だった バウンティは – jamie
:-)私の友人を付与ありがとうございます! ;-) – Croises