繁体   English   中英

htaccess:保护手动重写URL地址

[英]htaccess: Protecting manual re-write of URL address

是否可以防止单个网站URL多个 网站URL被手动更改?

例:

www.example.com/here-is-example-url/1234/page/这是正确的网址

www.example.com/here-is-example错误的网址(手动更改)或

www.example.com/here-is-错误的网址(手动更改)或

www.example.com/here-is-example-2错误的网址(手动更改)

目前,我确实使用上一个RewriteRule将这样更改的地址重定向到主页,但是我宁愿看到一些解决方案来检测URL的手动更改并阻止此类访问者的访问。

什么RewriteRuleRewriteCond可以防止这种情况?

这是我到目前为止所拥有的:

#redirect to canonical url if no ending slash
RewriteRule ^([A-Za-z0-9-]+)/([0-9]+)/page$ $1/$2/page/ [R,L]
#redirect to canonical url if anything behind slash
RewriteRule ^([A-Za-z0-9-]+)/([0-9]+)/page/(.+)$ $1/$2/page/ [R,L]
#rewrite to PHP file if visiting the canonical url
RewriteRule ^([A-Za-z0-9-]+)/([0-9]+)/page/$ page.php?val1=$1&val2=$2 [L]

#redirect to Homepage url if no other rule match with missing ending slash
RewriteCond %{REQUEST_URI} !(/$|\.) 
RewriteRule (.*) http://www.domain.com/ [R,L]

如果某些RewriteRule无法解决此问题,是否可以将这种行为重定向到500次访问被拒绝?

您可以使用F禁止标志

RewriteRule here-is-example$ - [F,L]

正如您提到的,以上规则仅捕获第一个示例。

大多数人看不到HTTP状态代码,您可以使用ErrorDocument来显示自定义错误消息。

ErrorDocument 404 /access-denied.html 

https://httpd.apache.org/docs/2.4/custom-error.html

请小心,因为无法知道某人是由于剪切和粘贴错误还是对您的网站的故意探测而输入了错误的URL。

这不是您应该担心的事情。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM