繁体   English   中英

Htaccess Mod 重写不适用于漂亮的 URL

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM