2

だから私はジレンマを持っています..

この URL をこの URL に書き換える方法がわかりません:

URL=www.EXAMPLE.com/users/USERNAME

この URL= www.EXAMPLE.com/USERNAME

Stack Overflow を使用するのはこれが初めてではありませんが、答えを見つけるために実際にアカウントが必要になるのはこれが初めてです。それに応じて感謝します。

ありがとう、ニック

編集:

    RewriteRule ^user/(.*)$ /$1 [R=301,L]

しかし、私は404ページを取得します。奇妙なことです。

ページは正常にリダイレクトされますが、代わりに 404 が返されます。

HTACCESS は次のとおりです。

   ## Mod_rewrite in use.

   RewriteEngine On
   RewriteRule ^user/(.*)$ /$1 [R=301,L]

   ## Begin - Rewrite rules to block out some common exploits.
   # If you experience problems on your site block out the operations listed below
   # This attempts to block the most common type of exploit `attempts` to Joomla!
   #
   # Block out any script trying to base64_encode data within the URL.
   RewriteCond %{QUERY_STRING} base64_encode[^(]*\([^)]*\) [OR]
   # Block out any script that includes a <script> tag in URL.
   RewriteCond %{QUERY_STRING} (<|%3C)([^s]*s)+cript.*(>|%3E) [NC,OR]
   # Block out any script trying to set a PHP GLOBALS variable via URL.
   RewriteCond %{QUERY_STRING} GLOBALS(=|\[|\%[0-9A-Z]{0,2}) [OR]
   # Block out any script trying to modify a _REQUEST variable via URL.
   RewriteCond %{QUERY_STRING} _REQUEST(=|\[|\%[0-9A-Z]{0,2})
   # Return 403 Forbidden header and show the content of the root homepage
   RewriteRule .* index.php [F]
   #
   ## End - Rewrite rules to block out some common exploits.

   ## Begin - Custom redirects
   #
   # If you need to redirect some pages, or set a canonical non-www to
   # www redirect (or vice versa), place that code here. Ensure those
   # redirects use the correct RewriteRule syntax and the [R=301,L] flags.
   #

   ## End - Custom redirects

   ##
   # Uncomment following line if your webserver's URL
   # is not directly related to physical file paths.
   # Update Your Joomla! Directory (just / for root).
   ##

   # RewriteBase /

   ## Begin - Joomla! core SEF Section.
   #
   RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
   #
   # If the requested path and file is not /index.php and the request
   # has not already been internally rewritten to the index.php script
   RewriteCond %{REQUEST_URI} !^/index\.php
   # and the request is for something within the component folder,
   # or for the site root, or for an extensionless URL, or the
   # requested URL ends with one of the listed extensions
   RewriteCond %{REQUEST_URI} /component/|(/[^.]*|\.(php|html?|feed|pdf|vcf|raw))$ [NC]
   # and the requested path and file doesn't directly match a physical file
   RewriteCond %{REQUEST_FILENAME} !-f
   # and the requested path and file doesn't directly match a physical folder
   RewriteCond %{REQUEST_FILENAME} !-d
   # internally rewrite the request to the index.php script
   RewriteRule .* index.php [L]
   #
   ## End - Joomla! core SEF Section.

[2013 年 4 月 8 日更新] しばらくして、私が使用している拡張機能が Joomla と一緒に機能する唯一の方法であることがわかりました。これを機能させるには、sh404sef という別の拡張機能を使用する必要があります。つまり、思ったように HTACCESS ファイルを編集しても意味がありません。40ドルを費やしてしまい、すぐに機能しました。ハハ

4

3 に答える 3

4

.htaccessURLの書き換えに役立つサイトは次のとおりです。http: //roshanbh.com.np/2008/03/url-rewriting-examples-htaccess.html

例:

yoursite.com/user.php?username=xyzをyoursite.com/xyzに書き換えます

zorpia.comを確認しましたか。ブラウザでhttp://zorpia.com/roshanbh233 と入力すると、そこに私のプロファイルが表示されます。同じ種類のリダイレクト、つまりhttp://yoursite.com/xyzから http://yoursite.com/user.php?username=xyzを実行する場合は、次のコードを.htaccessファイルに追加できます。

RewriteEngine On
RewriteRule ^([a-zA-Z0-9_-]+)$ user.php?username=$1
RewriteRule ^([a-zA-Z0-9_-]+)/$ user.php?username=$1

だからあなたの場合、あなたは行くことができます:

RewriteRule ^users/([a-zA-Z0-9_-]+)$ user.php?username=$1
RewriteRule ^users/([a-zA-Z0-9_-]+)/$ user.php?username=$1
于 2013-03-15T15:41:25.653 に答える
4

これはあなたの質問に答えるはずです

RewriteRule ^users/(.*)$ $1

ソース:サブディレクトリからルートへの .htaccess 書き換え

于 2013-03-15T15:43:40.637 に答える