Linux下nginx支持.htaccess文件实现伪静态的方法

在 Google 上搜索的资料很多人都说 nginx 目前不支持. htaccess 文件,我按照 nginx 的规则试验了一下,结果发现 nginx 是完全支持. htaccess 文件的!

方法如下:

1. 在需要使用. htaccess 文件的目录下新建一个. htaccess 文件, 如本人的一个 Discuz 论坛目录:

  vim /var/www/html/168pc/bbs/.htaccess

2. 在里面输入规则,我这里输入 Discuz 的伪静态规则:

# nginx rewrite rule
rewrite ^(.*)/archiver/((fid|tid)-[w-]+.html)$ $1/archiver/index.php?$2 last;
rewrite ^(.*)/forum-([0-9]+)-([0-9]+).html$ $1/forumdisplay.php?fid=$2&page=$3 last;
rewrite ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+).html$ $1/viewthread.php?tid=$2&extra=page%3D$4&page=$3 last;
rewrite ^(.*)/profile-(username|uid)-(.+).html$ $1/viewpro.php?$2=$3 last;
rewrite ^(.*)/space-(username|uid)-(.+).html$ $1/space.php?$2=$3 last;
rewrite ^(.*)/tag-(.+).html$ $1/tag.php?name=$2 last;
# end nginx rewrite rule

wq 保存退出。

3. 修改 nginx 配置文件:

    vim /etc/nginx/nginx.conf

4. 在需要添加伪静态的虚拟主机的 server{} 中引入. htaccess 文件,如图所示:

include /var/www/html/168pc/bbs/.htaccess;(把这个改成你. htaccess 文件的具体位置) wq 保存退出。

5. 重新加载 nginx 配置文件:

 /etc/init.d/nginx reload

重新打开网页看看,如果伪静态正常就证明你的 rewrite rule 语法是正确的。

正常,完毕!

补充:偶在网上发现了个可以在线将 Apache Rewrite 伪静态规则自动转换为 Nginx Rewrite 网页。大家可以试试看。

http://www.anilcetin.com/convert-apache-htaccess-to-nginx/

此地址里面的内容包含可以完成上面说的略做修改的功能。就是把. htaccess 中的规则自动转换成 nginx 下面可用的规则。

总结:.htaccess 文件本来是 apache 专用的分布式配置文件,提供了针对每个目录改变配置的方法,即在一个特定的目录中放置一个包含指令的文件,其中的指令作用于此目录及其所有子目录。其实修改一下,nginx 也可使用. htaccess 文件实现多种功能。实现伪静态只是. htaccess 的其中一个用途,.htaccess 还可以做很多的用途,如过滤访问 IP,设置 web 目录访问权限、密码等。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Apache Hadoop

Apache Hadoop大数据生态

Apache Hadoop2.7,是经历多年企业生产应用和社区代码优化的稳定版。选用为BR-odp为基础大数据开发框架,既是大数据生态发展也是技术先进性突破。

23460
来自专栏Apache Hadoop

数道云大数据|大数据处理的核心技术有哪些?

大数据时代,数据来源途径越来越丰富,而且类型也很多花样,存储和数据处理的需求量很大,对于数据展现也非常的高,并且很看重数据处理的高效性和可用性。

25740
来自专栏Java架构师进阶

Kafka从入门到进阶

如果想学习Java工程化、高性能及分布式、深入浅出。微服务、Spring,MyBatis,Netty源码分析的朋友可以加我的Java高级交流:854630135...

16420
来自专栏Java开发必知必会

JanusGraph -- 简介

图数据库的基本含义是以“图”这种数据结构存储和查询数据,而不是存储图片的数据库。它的数据模型主要是以节点和关系(边)来体现,也可处理键值对。它的优点是快速解决复...

1.1K10
来自专栏Java开发必知必会

Hadoop与Spark关系

这是官网上的一句话,意思就是“Spark是大规模数据处理的统一分析引擎”,是专为大规模数据处理而设计的快速通用的计算引擎。由UC Berkeley AMP La...

1.9K10
来自专栏加米谷大数据

大数据处理必备的十大工具

Hive是一个建立在Hadoop上的开源数据仓库基础设施,通过Hive可以很容易的进行数据的ETL,对数据进行结构化处理,并对Hadoop上大数据文件进行查询和...

23430
来自专栏码匠的流水账

聊聊flink的consecutive windowed operations

本文主要研究一下flink的consecutive windowed operations

19510
来自专栏加米谷大数据

大数据Hadoop入门需要填的坑

Hadoop是一个由Apache基金会所开发的分布式系统集成架构,用户可以在不了解分布式底层细节情况下,开发分布式程序,充分利用集群的威力来进行高速...

14720
来自专栏加米谷大数据

比拼生态和未来,Spark和Flink哪家强?

Spark 是最活跃的 Apache 项目之一。Spark 的开源社区一度达到上千的活跃贡献者。最主要推动者是 Databricks,由最初的 Spark 创...

10720
来自专栏加米谷大数据

容易搞混大数据分析学习的工具

大数据已成为当今企业不可分割的一部分,越来越多的企业纷纷寻找熟悉大数据分析工具的人。他们都期望员工在技术方面体现能力,并展示才华和思维过程。到目前为...

11220

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励