[英]Htaccess Mod Rewrite Not working for Pretty URL
我觉得这是一个不得不发布这个问题的工具,但对于我的生活,我无法弄清楚如何解决我的问题。 (我也读过/尝试过以前的帖子,但没有一个对我有帮助)
我正在尝试将https://mywebsite.com/article.php?slug=pretty-url 转换为https://mywebsite.com/article/pretty-url
我遇到的问题是$_GET
方法无法识别 slug,所以它给了我一个 404 错误。 slug 肯定在我的数据库中。 我不知道为什么我无法检索它。
下面是我的 htaccess 代码和我调用页面的 php 代码。
Htaccess代码:
<IfModule mod_rewrite.c>
Options +FollowSymLinks
RewriteEngine On
# Redirect www urls to non-www
RewriteEngine on
RewriteCond %{HTTP_HOST} ^www\.mywebsite\.com [NC]
RewriteRule (.*) https://mywebsite.com/$1 [L]
RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://mywebsite.com/$1 [L]
ErrorDocument 404 /404.php
#Pretty URL for Blog
RewriteRule ^article/([0-9a-zA-Z]+) article.php?slug=$1
#Rewrite for certain files with .php extension
RewriteRule ^about$ about.php
RewriteRule ^services$ services.php
RewriteRule ^portfolio$ portfolio.php
RewriteRule ^blogs$ blogs.php
RewriteRule ^tutorials$ tutorials.php
RewriteRule ^contact$ contact.php
RewriteRule ^privacy-policy$ privacy-policy.php
RewriteRule ^terms-of-service$ terms-of-service.php
RewriteRule ^sitemap$ sitemap.php
</IfModule>
article.php 页面上的 PHP 代码:
//Get the blog. Only blogs that are published
$slug = $_GET['slug'];
$publish = intval(1);
//Query the database
$sql = "SELECT * FROM blogs WHERE publish = $publish AND slug = $slug";
//Execute the query
$stmt = $db->query($sql);
$row = $stmt->fetch(PDO::FETCH_ASSOC);
([0-9a-zA-Z]+)
不会捕获pretty-url
因为该组不允许使用连字符。 将其更改为([A-Za-z0-9-]+)
并将[L]
添加到该行的末尾。
另外,为了正确处理,删除第二次和第三次对RewriteEngine On
调用。
永远不要为一个问题道歉! 如果您遇到困难,我们会尽力提供帮助。
您在 htaccess 中需要的是以下内容:
RewriteEngine On
RewriteRule ^([^/]*)\.html$ /article.php?slug=$1 [L]
这应该将您的网址更改为https://mywebsite.com/pretty-url.html
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.