deno.com
在当前页面

TCP 套接字和 TLS

Deno Deploy 支持出站 TCP 和 TLS 连接。这些 API 允许你在 Deploy 中使用 PostgreSQL、SQLite、MongoDB 等数据库。

Deno.connect Jump to heading

建立出站 TCP 连接。

函数定义与 Deno 相同,但有限制:transport 选项只能是 tcp,且 hostname 不能是 localhost 或为空。

function Deno.connect(options: ConnectOptions): Promise<Conn>

示例 Jump to heading

async function handler(_req) {
  // 建立到 example.com 的 TCP 连接
  const connection = await Deno.connect({
    port: 80,
    hostname: "example.com",
  });

  // 发送原始的 HTTP GET 请求。
  const request = new TextEncoder().encode(
    "GET / HTTP/1.1\nHost: example.com\r\n\r\n",
  );
  const _bytesWritten = await connection.write(request);

  // 从连接中读取 15 字节。
  const buffer = new Uint8Array(15);
  await connection.read(buffer);
  connection.close();

  // 将字节作为纯文本返回。
  return new Response(buffer, {
    headers: {
      "content-type": "text/plain;charset=utf-8",
    },
  });
}

Deno.serve(handler);

Deno.connectTls Jump to heading

建立出站 TLS 连接。

函数定义与 Deno 相同,但有限制:hostname 不能是 localhost 或为空。

function Deno.connectTls(options: ConnectTlsOptions): Promise<Conn>

示例 Jump to heading

async function handler(_req) {
  // 建立到 example.com 的 TLS 连接
  const connection = await Deno.connectTls({
    port: 443,
    hostname: "example.com",
  });

  // 发送原始的 HTTP GET 请求。
  const request = new TextEncoder().encode(
    "GET / HTTP/1.1\nHost: example.com\r\n\r\n",
  );
  const _bytesWritten = await connection.write(request);

  // 从连接中读取 15 字节。
  const buffer = new Uint8Array(15);
  await connection.read(buffer);
  connection.close();

  // 将字节作为纯文本返回。
  return new Response(buffer, {
    headers: {
      "content-type": "text/plain;charset=utf-8",
    },
  });
}

Deno.serve(handler);

你找到需要的内容了吗?

隐私政策