我们有一个由Django制作的网站。访问时没有问题 关注本地工作环境的网址:

http://site/tags/c%23/

" C%23 QUOT;是“c#”的urlencode,在本地工作正常。 但是在我们将它部署到Bluehost托管服务器(apache + fastcgi)之后,此URL已经解析为一个新的地址,如下所示:

http://site/t/tags/c/ 

太奇怪了。可能这不是Django的问题,而是与某些事情有关 Apache url的重写。如果您有任何想法或建议如何解决这个问题,请告诉我。 提前谢谢。

这里可以考虑.htaccess文件:

AddHandler fcgid-script .fcgi 
#AddHandler fastcgi-script .fcgi 
#AddHandler application/cgi .fcgi 
#AddHandler cgi-script .fcgi 
RewriteEngine On 
RewriteBase / 
#static file setting 
RewriteRule ^(media/.*)$ - [L] 
RewriteRule ^(static/.*)$ - [L] 
RewriteCond %{REQUEST_URI} !(dispatch.fcgi) 
RewriteRule ^(.*)$ dispatch.fcgi/$1 [L] 

和dispatch.fcgi文件:

#!/home/***/python/bin/python 
import sys, os 
# Add a custom Python path. 
sys.path.insert(0, "/home/***/python") 
sys.path.insert(0, "/home/***/working/Django-1.0") 
os.chdir("/home/***/working/Django-1.0/project") 
os.environ['DJANGO_SETTINGS_MODULE'] = "project.settings" 
from django.core.servers.fastcgi import runfastcgi 
runfastcgi(["method=threaded", "daemonize=false"]) 

UPDAET:如果这是由httpd.conf中的设置引起的,我如何在没有权限的情况下覆盖.htaccess文件?

有帮助吗?

解决方案

进一步说明之前的一些提示:

您是否尝试过其他字符,例如空格(%20)或带重音的ASCII字符?另外,你是否尝试过将其他字符放在%23之后(斜杠除外)以查看它们是否也被剥离了?

有一种猜测可能是因为#被认为是当前页面上的锚点,所以#和后面的内容将被重写中删除。

其他提示

我必须同意第一个答案 - 如果没有访问apache配置,你可能会失败。使用'CSharp'或其他东西可能是最佳选择。

#在URI中有特殊含义,与/或?相同?确实。你有其他符号这个问题吗?最终,您不应该在URI中使用#符号,除非您在页面上引用了锚点。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top