Deno 是一种现代的 JavaScript 和 TypeScript 运行时环境,具有安全性、可靠性和专业性等特点。Deno 的 Http 模块是 Deno 提供的内置库之一,可以实现基本的 HTTP 或 HTTPS 服务器和客户端。
本文将介绍如何在 Deno 中使用 Http 模块支持 HTTPS,包括如何创建 HTTPS 服务器和客户端,以及如何生成和使用证书等。
准备工作
在开始实现 HTTPS 之前,需要进行以下准备工作:
- 安装 Deno 运行时环境。
- 安装 OpenSSL 工具。在 Linux、macOS 等操作系统中,可以使用系统自带的 OpenSSL;在 Windows 操作系统中,需要下载安装 OpenSSL 工具,并将其添加到系统环境变量中。
- 生成证书和密钥文件。可以使用 OpenSSL 工具生成自签名的证书和私钥,也可以购买商业证书。
在本文中,我们使用自签名的证书和私钥,命名为 cert.pem
和 key.pem
。
创建 HTTPS 服务器
使用 Deno 中的 Http 模块创建 HTTPS 服务器需要以下步骤:
- 导入 Http 模块和 fs 模块。
- 加载证书和私钥文件。
- 创建服务器,并将证书和密钥文件传递给服务器选项。
- 启动服务器。
下面是示例代码:
-- -------------------- ---- ------- ------ - ----- - ---- --------------------------------------- ------ - ------------ - ---- ---------------------------------- ----- ------- - - --------- ----------- -------- ---------- -- ----- ------ - --------------- ------------------ ------ ------- -- ---- ------- --- ----- ------ --- -- ------- - ------------- ----- ------ ---- -------- --- -
在上面的代码中,使用了 serve
函数创建了一个 HTTPS 服务器,将证书和密钥文件作为选项传递给该函数。服务器监听 8000
端口,当收到请求时,发送 Hello Deno HTTPS
字符串作为响应体。
创建 HTTPS 客户端
使用 Deno 中的 Http 模块创建带有 HTTPS 调用的客户端需要以下步骤:
- 导入 Http 模块。
- 创建代表服务器的 URL 对象。
- 创建 HTTPS 请求客户端,并将选项传递给该函数。
下面是示例代码:
-- -------------------- ---- ------- ------ - ----- - ---- ------------------------------------- ------ - ------- - ---- --------------------------------------- ----- ---- - ----------------- ----- ------- - - --------- ------------ ----- ----- ---- - ------------ ----- ------------------------------ ---- ----- ----------------------------- -- -- ----- ------ - ----------------- ----- -------- - ----- ---------------- ------- ------ ----- ---- --- ----- ---- - --- ---------------- ------------------------------------ --------------- ----------------------------
在上面的代码中,使用了 connect
函数创建了一个 HTTPS 客户端,将选项传递给该函数。客户端连接到 localhost
的 8000
端口,发送 GET
请求,获取服务器响应,并将响应体作为字符串输出。
证书的生成与使用
在上面的示例中,我们使用了自签名的证书和密钥文件。我们可以使用 OpenSSL 工具生成自签名的证书和私钥。
首先,使用以下命令生成私钥:
$ openssl genrsa -out key.pem 2048
然后,使用以下命令将私钥文件转换为 PKCS#8 格式:
$ openssl pkcs8 -topk8 -inform PEM -outform PEM -in key.pem -out key.pem.pkcs8 -nocrypt
最后,使用以下命令生成证书:
$ openssl req -new -x509 -sha256 -key key.pem -out cert.pem -days 3650
在生成证书时,需要填写一些基本信息,比如国家、省份、城市、组织名、邮箱等。
可以使用以下命令查看证书内容:
$ openssl x509 -text -noout -in cert.pem
在上面的示例中,我们将证书和密钥文件作为选项传递给服务器和客户端。在实际应用中,我们可以将证书和密钥文件放在安全的位置,并在运行时读取它们,以提高安全性。
总结
到此为止,我们已经学习了如何在 Deno 中使用 Http 模块支持 HTTPS。首先,我们需要生成证书和密钥文件;然后,我们可以使用 Http 模块创建 HTTPS 服务器和客户端,并将证书和密钥文件作为选项传递给它们。
使用 Http 模块支持 HTTPS 是 Deno 的一个重要特性,它不仅提供了安全的通信方式,而且可以在各种场景下发挥作用,比如 Web 开发、网络爬虫、API 调用等。希望本文对你有所帮助。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/64e3fabdf6b2d6eab3f59800