今天,我想展示如何在你的网站上强制使用 SSL。也就是说,将所有用户的 HTTP 请求重定向到对应的 HTTPS。

创建页面规则重定向 HTTP 请求

像往常一样,让我们进入 OpenResty Edge 的 Admin Web 控制台。这是我们的控制台的样本部署。每个用户都有自己的本地部署。

这一次我们继续使用 test-edge.com 域名的样本应用。

屏幕截图

进入这个应用。

屏幕截图

再进入页面规则页面。

屏幕截图

创建一个新的页面规则。

屏幕截图

我们为所有的 HTTP 请求启用一个规则条件。

屏幕截图

先来看看我们可以选择的所有变量。

屏幕截图

选择 Scheme

屏幕截图

保持字符串等号运算符不动。

屏幕截图

再选择 http 作为值。

屏幕截图

屏幕截图

这个条件就完成了。它会匹配所有的 HTTP 请求,并排除任何 HTTPS 请求。

然后对于规则的动作部分,我们可以配置一个 301 重定向动作。

屏幕截图

在这里有很多的动作。

屏幕截图

所以最好直接搜索一下 Redirect 动作。

屏幕截图

选择它。

屏幕截图

我们保持当前的请求 URI 不变。

屏幕截图

同时也继承当前请求的 URI 参数或查询字符串。

屏幕截图

不过我们需要改变新请求的 Scheme。

屏幕截图

选择 https

屏幕截图

我们可以在这里选择 301 重定向来代替。

屏幕截图

意味着是“永久重定向”。

屏幕截图

我们需要确保这个规则在任何现有的正常规则之前运行。

屏幕截图

确保当此规则被匹配时,我们跳过任何后续的规则。

屏幕截图

对于这条规则来说,虽然这并不是真的必要,但是,当我们想立即停止处理请求时,明确说明总是一个好主意。

现在创建这个规则。

屏幕截图

这里可以看到新的页面规则,将所有的 HTTP 请求重定向到它们对应的 HTTPS 请求。

屏幕截图

像往常一样,我们需要发布来推送这个新的页面规则。

屏幕截图

点击这个按钮。

屏幕截图

发布!

屏幕截图

已经完全同步。

屏幕截图

现在,新的页面规则已经被推送到所有的网关集群和服务器。

屏幕截图

我们的配置更改不需要重新加载服务器、重启或二进制升级服务器进程。所以它是非常有效和可扩展的。

嵌入图片

测试页面规则

让我们打开一个新的浏览器标签页,通过 HTTP 访问 test-edge.com 网站。

我们可以看到它确实变成了 HTTPS。注意浏览器地址栏中的小锁图标。

在终端上,我们也可以用 curl 进行测试。

curl -Ss -I http://test-edge.com/

确实是一个 301 重定向,并使用 HTTPS 协议。

screenshot 1

也可以来尝试一个更复杂的 URI 和查询字符串。

curl -Ss -I 'http://test-edge.com/foo/bar?a=32&b=56'

我们可以看到它仍然被重定向到 HTTPS

屏幕截图 3

而且 URI 和查询字符串也被保留下来了。

截图 4

如果你喜欢这个教程,请订阅这个博客网站和我们的 YouTube 频道B 站频道。谢谢!

关于本文和关联视频

本文和相关联的视频都是完全由我们的 OpenResty Showman 产品从一个简单的剧本文件自动生成的。

关于作者

章亦春是开源 OpenResty® 项目创始人兼 OpenResty Inc. 公司 CEO 和创始人。

章亦春(Github ID: agentzh),生于中国江苏,现定居美国湾区。他是中国早期开源技术和文化的倡导者和领军人物,曾供职于多家国际知名的高科技企业,如 Cloudflare、雅虎、阿里巴巴, 是 “边缘计算“、”动态追踪 “和 “机器编程 “的先驱,拥有超过 22 年的编程及 16 年的开源经验。作为拥有超过 4000 万全球域名用户的开源项目的领导者。他基于其 OpenResty® 开源项目打造的高科技企业 OpenResty Inc. 位于美国硅谷中心。其主打的两个产品 OpenResty XRay(利用动态追踪技术的非侵入式的故障剖析和排除工具)和 OpenResty Edge(最适合微服务和分布式流量的全能型网关软件),广受全球众多上市及大型企业青睐。在 OpenResty 以外,章亦春为多个开源项目贡献了累计超过百万行代码,其中包括,Linux 内核、Nginx、LuaJITGDBSystemTapLLVM、Perl 等,并编写过 60 多个开源软件库。

关注我们

如果您喜欢本文,欢迎关注我们 OpenResty Inc. 公司的博客网站 。也欢迎扫码关注我们的微信公众号:

我们的微信公众号

翻译

我们提供了英文版原文和中译版(本文) 。我们也欢迎读者提供其他语言的翻译版本,只要是全文翻译不带省略,我们都将会考虑采用,非常感谢!