Page Contents

总览

服务器(Server)接口定义了必须的函数(start 和 stop)和一个“listening”属性 以实现 LoopBack 应用程序。在 LoopBack 4 中,Server(服务器)用于代表“入站传输”和/或“协议”,例如:REST over http,gRPC over http2,graphQL over https 等。它们一般监听特定端口的 Request(请求),处理请求,并且返回适当的 Response(响应)。 一个 Application(应用)可以有多个 Server(服务器)实例、监听不同的端口、以不同的协议工作。

用法

LoopBack 4 提供@loopback/rest这一“开箱即用”包,它提供了基于 HTTP/HTTPS 的服务器RestServer用于处理 REST 请求。

要在你的应用中使用此包,你的 Application 类需要扩展RestApplication以提供一个RestServer的实例用于监听 3000 端口。 下列实例代码展示了如何使用RestApplication

import { RestApplication, RestServer } from "@loopback/rest";

export class HelloWorldApp extends RestApplication {
  constructor() {
    super();
    // 给我们的RestServer实例一个时序处理函数,
    // 此函数会为所有的RestApplication请求返回"Hello World“字符串,
    // 处理函数可以注册在应用层。
    this.handler((sequence, request, response) => {
      sequence.send(response, "Hello World!");
    });
  }

  async start() {
    // 在application类调用start,会启动所有的注册的服务器。
    await super.start();

    // 获得HTTP服务器的实例。
    const rest = await this.getServer(RestServer);
    console.log(`REST server running on port: ${await rest.get("rest.port")}`);
  }
}

配置

配置 REST 服务器,可以通过在你的 RestApplication 选项中传入rest 属性 。例如,下列代码可以自定义 REST 服务器的监听端口。

const app = new RestApplication({
  rest: {
    port: 3001
  }
});

自定义如何提供 OpenAPI 规范

rest.openApiSpec有一些选项可以配置 REST 服务器如何提供 OpenAPI 规范。

  • servers: 配置 OpenAPI 规范的 servers(服务器)。
  • setServersFromRequest: 基于 HTTP 请求头设置servers,默认为false
  • disabled: 设为true以禁用 OpenAPI 规范。这同时也会禁用 API Explorer。
  • endpointMapping: 为不同格式的规范提供映射 url。默认为:
    {
      '/openapi.json': {version: '3.0.0', format: 'json'},
      '/openapi.yaml': {version: '3.0.0', format: 'yaml'},
    }
const app = new RestApplication({
  rest: {
    openApiSpec: {
      servers: [{ url: "http://127.0.0.1:8080" }],
      setServersFromRequest: false,
      endpointMapping: {
        "/openapi.json": { version: "3.0.0", format: "json" },
        "/openapi.yaml": { version: "3.0.0", format: "yaml" }
      }
    }
  }
});

配置 API Explorer

LoopBack 允许为 REST 服务器提供外部托管 API Explorer 界面,此类 URL 使用rest.apiExplorer指明:

  • url:托管 API Explorer 界面的 URL,默认为https://loopback.io/api-explorer
  • httpUrl:托管 API explorer 界面的 URL,通过普通的 http 提供,以处理当规范通过 HTTP 暴露时,浏览器默认的混合内容安全加强。 详情查看此页面:https://github.com/strongloop/loopback-next/issues/1603。 默认使用url的值。
const app = new RestApplication({
  rest: {
    apiExplorer: {
      url: "https://petstore.swagger.io",
      httpUrl: "http://petstore.swagger.io"
    }
  }
});

禁止重定向到 API Explorer

如要禁止重定向到外部托管的 API Explorer,设置配置选项rest.apiExplorer.disabledtrue

const app = new RestApplication({
  rest: {
    apiExplorer: {
      disabled: true
    }
  }
});

使用自托管的 API Explorer

托管 API Explorer 到外部 URL 有一些缺点,例如,需要一个可以正常工作的互联网以浏览 API。作为一个替代建议,LoopBack 带有扩展,用于提供自托管的 API Explorer 界面。 更多详情参见自托管的 REST API Explorer

启用 HTTPS

为 LoopBack REST 服务器启用 HTTPS,只需要指明协议为https并指明证书。

下面这个应用中,我们配置了一个使用秘钥-证书链的变种 HTTPS 的最小应用。

import { RestApplication, RestServer, RestBindings } from "@loopback/rest";
import * as fs from "fs";

export async function main() {
  const options = {
    rest: {
      protocol: "https",
      key: fs.readFileSync("./key.pem"),
      cert: fs.readFileSync("./cert.pem")
    }
  };
  const app = new RestApplication(options);
  app.handler(handler => {
    handler.response.send("Hello");
  });
  await app.start();

  const url = app.restServer.url;
  console.log(`Server is running at ${url}`);
}

自定义 CORS

REST 服务器默认使用以下选项启用CORS

{
  origin: '*',
  methods: 'GET,HEAD,PUT,PATCH,POST,DELETE',
  preflightContinue: false,
  optionsSuccessStatus: 204,
  maxAge: 86400,
  credentials: true,
}

Application 通过 REST 配置自定义 CORS:

export async function main() {
  const options = {
    rest: {
      cors: {...},
    },
  };
  const app = new RestApplication(options);
}

CORS 的完整选项列表,参见此页:https://github.com/expressjs/cors#configuration-options。

快捷设置

覆盖默认的快捷设置和/或分配你自己的设置:

const app = new RestApplication({
  rest: {
    expressSettings: {
      'x-powered-by': false,
      env: 'production',
      ...
    },
  },
});

查看express documentation以了解更多关于内置设置的详情。

配置基本路径(Base Path)

有时候,合意使用基本路径(Base Path)暴露 REST 服务端,例如/api。 基本路径(Base Path)是 RestServer 配置的一部分。

const app = new RestApplication({
  rest: {
    basePath: "/api"
  }
});

RestApplicationRestServer都提供basePath() API:

const app: RestApplication;
// ...
app.basePath("/api");

当有配置basePath时,所有的 REST API 和静态资产都通过basePath开头的 URL 提供。

配置路由器

路由器可以由以下方式被配置为强制strict(严格)模式:

  1. stricttrue
  • 请求/orders符合路由/orders但不符合/orders/
  • 请求/orders/ 符合路由/orders/但不符合/orders
  1. strictfalse(默认)
  • 请求/orders首先符合路由/orders然后才是/orders/
  • 请求/orders/首先符合路由/orders/然后才是/orders

查阅strict routing(严格路由)http://expressjs.com/en/4x/api.html#app以获得更多信息。

配置请求体 Parser(解析器)选项

我们可以通过下列代码配置请求体解析器:

const app = new Application({
  rest: { requestBodyParser: { json: { limit: "1mb" } } }
});

rest.requestBodyParser的值会被绑定到RestBindings.REQUEST_BODY_PARSER_OPTIONS。 查阅Customize request body parser options以了解详情。

rest选项

属性 类型 描述
host string 指明 RestServer 将要监听的服务器名或 IP 地址。
port number 指明 RestServer 将要监听的端口。
protocol string (http/https) 指明 RestServer 将要监听的协议。
basePath string 指明 RestServer 暴露的 HTTP 服务端的 base path(基本路径)。
key string 为 HTTPS 指明 SSL 私钥。
cert string 为 HTTPS 指明 SSL 证书。
cors CorsOptions 指明 CORS 选项。
sequence SequenceHandler 使用自定义的 SequenceHandler 以改变 RestServer 的 Request(请求)-Response(响应)生命周期。
openApiSpec OpenApiSpecOptions 自定义如何提供 OpenAPI 规范。
apiExplorer ApiExplorerOptions 自定义如何提供 API Explorer。
requestBodyParser RequestBodyParserOptions 自定义如何解析请求体。
router RouterOptions 自定义如何路由以/结尾的请求。

为 application 实例添加服务器

你可以通过个别调用app.server()函数,或以数组的方式使用app.servers()函数。 使用app.server()允许你为每个服务器实例设置独立的键。 下列代码演示了如何使用这些函数:

import { Application } from "@loopback/core";
import { RestServer } from "@loopback/rest";

export class HelloWorldApp extends Application {
  constructor() {
    super();
    // 这个服务器实例会被绑定到“servers.fooServer”。
    this.server(RestServer, "fooServer");
    // 为"servers.MQTTServer"和"servers.SOAPServer"创建绑定。
    this.servers([MQTTServer, SOAPServer]);
  }
}

你同样可以在你的 Application 类的构造函数中添加多个服务器,请参考这个页面.

下一步