重定向pdf文件.htaccess

重定向pdf文件.htaccess,.htaccess,redirect,.htaccess,Redirect,我正在尝试重定向这样一个url:website\u name/download?q=filename.pdf到website\u name/resources/filename.pdf 此外,网站_name/download?q=filename.pdf不存在,但用户有机会找到此链接,因此我想重定向它 我在.htaccess中编写了以下代码: <IfModule mod_rewrite.c> RewriteEngine On RewriteCond %{REQUEST_URI

我正在尝试重定向这样一个url:website\u name/download?q=filename.pdf到website\u name/resources/filename.pdf

此外,网站_name/download?q=filename.pdf不存在,但用户有机会找到此链接,因此我想重定向它

我在.htaccess中编写了以下代码:

<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteCond %{REQUEST_URI} /download?q=$1
  RewriteRule ([^\/]+\.pdf)$ /resources [NC,L,R=301]
</IfModule>

重新启动发动机
重写cond%{REQUEST_URI}/下载?q=$1
重写规则([^\/]+\.pdf)$/resources[NC,L,R=301]

但由于某些原因,它不起作用。如果有人有主意!谢谢你

你的问题有点含糊,但我知道你想要外部重定向和内部重写的结合:

RewriteEngine On

# external redirect from /download?q=file.pdf to /resources/file.pdf
RewriteCond %{QUERY_STRING} (?:^|&)q=([^&]+\.pdf)(?:&|$)
RequestRule ^/?download /resources/%1.pdf [R=301]

# internal rewrite from /resources/file.pdf to /download?q=file.pdf
RewriteRule ^/?resources/([^/]+\.pdf)$ /download?q=$1 [END]
一开始使用302临时重定向是一个好主意,在确定所有设置都正确后,只需将其更改为301永久重定向。这样可以防止在尝试时出现缓存问题

如果您使用上述规则收到一个内部服务器错误(http状态500),那么很可能您操作的是非常旧版本的apache http服务器。在这种情况下,您将在http服务器错误日志文件中看到不支持的
[END]
标志的明确提示。您可以尝试升级或使用较旧的
[L]
标志,在这种情况下可能也会使用相同的标志,不过这取决于您的设置

此实现将在http服务器主机配置或分布式配置文件(“.htaccess”文件)中同样工作。显然,重写模块需要在http服务器中加载,并在http主机中启用。在使用分布式配置文件的情况下,您需要注意在主机配置中启用该文件的解释,并且该文件位于主机的
DOCUMENT\u ROOT
文件夹中


还有一个一般性的注释:您应该总是更喜欢将这些规则放在http服务器主机配置中,而不是使用分布式配置文件(“.htaccess”)。这些分布式配置文件增加了复杂性,通常是导致意外行为的原因,难以调试,而且它们确实降低了http服务器的速度。只有在您无法访问真正的http服务器主机配置(读:真正廉价的服务提供商)或坚持编写自己的规则的应用程序(这显然是一个安全噩梦)的情况下,才提供它们作为最后一个选项

每当我使用[END]或[L]时,我都会出现一个内部服务器错误(http状态500)。为什么它是外部重定向和内部重写的组合?此外,两个链接都来自同一个网站,“内部服务器错误”只是http服务器向不受信任的客户端提供的少量信息。您需要找到实际问题,您可以在http服务器的错误日志文件中读取该问题。它说什么?这样的组合是一种典型的模式。。。它将仍然使用“传统”URL的客户端重定向到“漂亮URL”,并注意将“漂亮URL”映射到真正的资源上。