2017-10-21 11 views
1

ユーザが生成したバグレポートのために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}] 

答えて

1

です:

RewriteCond %{REQUEST_METHOD} POST 
RewriteRule^- [L] 
+1

素晴らしいです!だから私は最終的に必要なすべてが\t するRewriteCondの%{REQUEST_METHOD} POST のRewriteRule^index.phpを[L]だった バウンティは – jamie

+0

:-)私の友人を付与ありがとうございます! ;-) – Croises

関連する問題