所以我的服务器上有以下.htaccess
文件,该文件从所有文件中删除了.php扩展名,强制使用https并还删除了www。:
RewriteEngine On
RewriteBase /
RewriteCond %{THE_REQUEST} ^[A-Z]{3,}\s([^.]+)\.php [NC]
RewriteRule ^ %1 [R=301,L]
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME}.php -f
RewriteRule ^(.*?)/?$ $1.php [NC,L]
# remove www and turn on https in same rule
RewriteCond %{HTTP_HOST} ^www\. [NC,OR]
RewriteCond %{HTTPS} !on
RewriteCond %{HTTP_HOST} ^(?:www\.)?(.+)$ [NC]
RewriteRule ^ https://%1%{REQUEST_URI} [R=301,L,NE]
问题是我有一个供用户上传图像的上传表单,因此当他们上传图像时,由于文件从/upload.php重定向到/ upload,因此由于重定向而变成了GET请求。
有什么办法可以阻止这个文件删除.php扩展名吗?
答案 0 :(得分:1)
只需添加一个附加条件:
RewriteCond %{REQUEST_URI} !/upload\.php$
这种情况将阻止您的规则应用于您的upload.php文件。