跳到主要内容

使用 Deno 构建 API 服务器


为什么选择 Deno?

当你开始构建 API 服务器时,使用 Deno 可以立即提高效率

Web 服务器

你可以用一行代码创建一个服务器。无需依赖项或依赖清单文件。

Deno.serve((req) => new Response("Hello world"));

在我们的手册中了解更多关于 Deno.serve() 的信息。

这是一个更长的例子,展示了如何检查 Request 对象 并使用 Response 对象进行响应。

Deno.serve(async (req) => {
  console.log("Method:", req.method);

  const url = new URL(req.url);
  console.log("Path:", url.pathname);
  console.log("Query parameters:", url.searchParams);

  console.log("Headers:", req.headers);

  if (req.body) {
    const body = await req.text();
    console.log("Body:", body);
  }

  return new Response("Hello, world", {
    status: 200,
    headers: {
      "content-type": "text/plain; charset=utf-8",
    },
  });
});
Node 呢?
注意在 Node.js 中,你不能使用 web 标准的 Request() 构造函数。相反,你必须导入 node:http 或第三方模块来创建 HTTP 请求。 了解 Node 与 web 标准的偏离如何导致漫长的构建时间、依赖膨胀等问题。

定义 API 路由

Oak 是一个受 Koa 启发的用于处理 HTTP 的中间件框架,它可以轻松地为 HTTP 服务器创建路由和路由处理程序。

import { Application, Router } from "https://deno.land/x/oak/mod.ts";

const books = new Map<string, any>();
books.set("1", {
  id: "1",
  title: "The Hound of the Baskervilles",
  author: "Conan Doyle, Arthur",
});

const router = new Router();
router
  .get("/", (context) => {
    context.response.body = "Hello world!";
  })
  .get("/book", (context) => {
    context.response.body = Array.from(books.values());
  })
  .get("/book/:id", (context) => {
    if (books.has(context?.params?.id)) {
      context.response.body = books.get(context.params.id);
    }
  });

const app = new Application();
app.use(router.routes());
app.use(router.allowedMethods());

await app.listen({ port: 8000 });

由于 Deno 支持 npm,你也可以使用 Express、Koa、Fastify 和其他 npm 模块来构建你的 API 路由。

部署到生产环境

Deno Deploy,我们的全球边缘无服务器平台,允许你在全球范围内托管和运行你的服务器,靠近你的用户,提供高可用性和最低的网络延迟。

通过连接 GitHub 帐户,在 Deno Deploy 上托管你的服务器既简单又免费。

了解为什么边缘是 Web 的未来.

你也可以在任何运行 VM 或 VPS 并带有 Docker 的平台上托管你的 Deno 服务器。这里有一些指南可以帮助你入门。

更多资源

有很多框架可以帮助你构建 HTTP 和 API 服务器

这里有一些关于使用 Deno 构建 HTTP 和 API 服务器的示例、博客文章和视频。