WWWをホームページにリダイレクトする、htaccessエラー

I have a product page that loads fine when I type in the www with the URL (www.domain.com/product), but when I don’t, it redirects to the home page(domain.com/product -> www.domain.com). I'm using Magento.

私は検索してきたが、htaccessメソッドを試してみたが、他のスレッドには言及されていたが役に立たなかった。

############################################ 
## 301 the url for SEO 
RewriteEngine On 
RewriteCond %{HTTP_HOST} !^www\.example\.com$ 
RewriteRule ^(.*)$ http://www.example.com/$1 [R=permanent,L]

Redirect 301 /home http://www.example.com/ 
############################################

私がこれを追加すると、私は変更がないか、またはサイト全体が500エラーでダウンします:あまりにも多くの書き換え。

私のメインドメインはwwwの有無に関係なくうまく動作します。これは私のhtaccessの様子です:

############################################
## uncomment these lines for CGI mode
## make sure to specify the correct cgi PHP binary file name
## it might be /cgi-bin/php-cgi

#    Action php5-cgi /cgi-bin/php5-cgi
#    AddHandler php5-cgi .php

############################################
## GoDaddy specific options

#   Options -MultiViews

## you might also need to add this line to php.ini
##     cgi.fix_pathinfo = 1
## if it still doesn't work, rename php.ini to php5.ini

############################################
## this line is specific for 1and1 hosting

#AddType x-mapp-php5 .php
#AddHandler x-mapp-php5 .php

############################################
## default index file

DirectoryIndex index.php



############################################
## adjust memory limit

#    php_value memory_limit 64M
php_value memory_limit 256M
php_value max_execution_time 18000

############################################
## disable magic quotes for PHP request vars

php_flag magic_quotes_gpc off

############################################
## disable automatic session start
## before autoload was initialized

php_flag session.auto_start off

############################################
## enable resulting html compression

php_flag zlib.output_compression on

###########################################
# disable user agent verification to not break multiple image upload

php_flag suhosin.session.cryptua off

###########################################
# turn off compatibility with PHP4 when dealing with objects

php_flag zend.ze1_compatibility_mode Off




###########################################
# disable POST processing to not break multiple image upload

SecFilterEngine Off
SecFilterScanPOST Off




############################################
## enable apache served files compression
## http://developer.yahoo.com/performance/rules.html#gzip

# Insert filter on all content
###SetOutputFilter DEFLATE
# Insert filter on selected content types only
#AddOutputFilterByType DEFLATE text/html text/plain text/xml text/css text/javascript

# Netscape 4.x has some problems...
#BrowserMatch ^Mozilla/4 gzip-only-text/html

# Netscape 4.06-4.08 have some more problems
#BrowserMatch ^Mozilla/4\.0[678] no-gzip

# MSIE masquerades as Netscape, but it is fine
#BrowserMatch \bMSIE !no-gzip !gzip-only-text/html

# Don't compress images
#SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary

# Make sure proxies don't deliver the wrong content
#Header append Vary User-Agent env=!dont-vary





############################################
## make HTTPS env vars available for CGI mode

SSLOptions StdEnvVars





############################################
## enable rewrites

Options +FollowSymLinks
RewriteEngine on

############################################
## you can put here your magento root folder
## path relative to web root

#RewriteBase /magento/

############################################
## workaround for HTTP authorization
## in CGI environment

RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]

############################################
## always send 404 on missing files in these folders

RewriteCond %{REQUEST_URI} !^/(media|skin|js)/

############################################
## never rewrite for existing files, directories and links

RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-l

############################################
## rewrite everything else to index.php

RewriteRule .* index.php [L]




############################################
## Prevent character encoding issues from server overrides
## If you still have problems, use the second line instead

AddDefaultCharset Off
#AddDefaultCharset UTF-8



############################################
## Add default Expires header
## http://developer.yahoo.com/performance/rules.html#expires

ExpiresDefault "access plus 1 year"



############################################
## By default allow all access

Order allow,deny
Allow from all

###########################################
## Deny access to release notes to prevent disclosure of the installed Magento version


order allow,deny
deny from all


############################################
## If running in cluster environment, uncomment this
## http://developer.yahoo.com/performance/rules.html#etags

#FileETag none

誰でもアイデアはありますか?

1
http://domain.com/product?test と入力するとどうなりますか?
追加された 著者 Gerben,
私はいずれかの結果を生み出したhtaccessのいくつかのバリエーションを試しました。私はそれを調べます、ありがとう
追加された 著者 miles,
サイトが変更されていないか、または500エラーが表示されますか?あなたが同じページを訪問している場合は、どちらか一方だけを実行する必要があります。あまりにも多くのリダイレクトが500件ある場合は、Googleの「サーバーヘッダーチェッカー」を使用して、サイトがリダイレクト先のページを確認します。それ以降は見つけるのがとても簡単です。
追加された 著者 iJeep,

1 答え

RewriteRule Redirect の両方を使用しないでください。それらは異なるモジュールであり、奇妙なやり取りをして、珍しい副作用を引き起こします。

RewriteEngine On 
RewriteCond %{HTTP_HOST} !^www\.example\.com$ 
RewriteRule ^(.*)$ http://www.example.com/$1 [R=permanent,L]

RewriteRule ^home$/[L,R=301]

また、301は非常に積極的にキャッシュされるため、ブラウザのキャッシュをクリアしてみてください。

編集

あなたのコメントと元の質問をより徹底的に読んだ後、あなたは間違った場所にwww-rulesを置いたと思います。それらのルールを現在のhtaccessファイルの先頭に置いてみてください。

3
追加された
@Gerben Google検索の5時間後、私は最終的に私のために働く解決策を見つけました。どうもありがとうございました。私は理由を知らないが、.htaccessファイルは1and1.comサーバーで作業するのに約5分かかった。
追加された 著者 black_belt,
私の記事を更新しました
追加された 著者 Gerben,
あなたの方法を試してみましたが、サイトをリロードするとエラーが発生します。
追加された 著者 miles,
とった! woohoo!
追加された 著者 miles,