Loopback 4中间件未注册

如何解决Loopback 4中间件未注册

我正在遵循此example here进行简单的日志记录中间件设置。但是我似乎无法获取它来记录我的请求信息。当我按下/ping时,我得到标准响应,但是没有任何内容注销到控制台。

我尝试在两个不同的位置注册中间件。 index.tsapplication.ts

// src/middleware/log.middleware.ts

import { Next } from '@loopback/core'
import { Middleware,MiddlewareContext } from '@loopback/rest'

export const testLoggingMiddleware: Middleware = async (
  middlewareCtx: MiddlewareContext,next: Next,) => {
  const { request } = middlewareCtx
  console.log('Request: %s %s',request.method,request.originalUrl)
  try {
    // Proceed with next middleware
    await next()
    // Process response
    console.log('Response received for %s %s',request.originalUrl)
  } catch (err) {
    // Catch errors from downstream middleware
    console.error('Error received for %s %s',request.originalUrl)
    throw err
  }
}
// src/index.ts

import { ApplicationConfig,RemoteConfigurationsApplication } from './application'
import { testLoggingMiddleware } from './middleware/log.middleware'
import { NodeEnvironmentService } from './services'

export * from './application'

export async function main(
  options: ApplicationConfig = {},): Promise<RemoteConfigurationsApplication> {
  const app = new RemoteConfigurationsApplication(options)

  app.middleware(testLoggingMiddleware) // trying to add the middleware here as well

  await app.boot()
  await app.start()

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

  return app
}

if (require.main === module) {
  // Run the application
  const config = {
    rest: {
      port: +(process.env.PORT ?? 8081),host: process.env.HOST,// The `gracePeriodForClose` provides a graceful close for http/https
      // servers with keep-alive clients. The default value is `Infinity`
      // (don't force-close). If you want to immediately destroy all sockets
      // upon stop,set its value to `0`.
      // See https://www.npmjs.com/package/stoppable
      gracePeriodForClose: 5000,// 5 seconds
      openApiSpec: {
        // useful when used with OpenAPI-to-GraphQL to locate your application
        setServersFromRequest: true,},basePath: `/`,cors: {
        origin: '*',methods: 'GET,HEAD,PUT,PATCH,POST,DELETE',preflightContinue: false,optionsSuccessStatus: 204,credentials: true,}
  main(config).catch((err) => {
    console.error('Cannot start the application.',err)
    process.exit(1)
  })
}
// src/application.ts

require('dotenv').config()

import { BootMixin } from '@loopback/boot'
import { ApplicationConfig } from '@loopback/core'
import { HealthComponent } from '@loopback/extension-health'
import { RestExplorerBindings,RestExplorerComponent } from '@loopback/rest-explorer'
import { RepositoryMixin } from '@loopback/repository'
import { RestApplication } from '@loopback/rest'
import { ServiceMixin } from '@loopback/service-proxy'
import * as path from 'path'
import { testLoggingMiddleware } from './middleware/log.middleware'
import { MySequence } from './sequence'

export { ApplicationConfig }

export class RemoteConfigurationsApplication extends BootMixin(
  ServiceMixin(RepositoryMixin(RestApplication)),) {
  constructor(options: ApplicationConfig = {}) {
    super(options)

    // Set up the custom sequence
    this.sequence(MySequence)

    // Set up default home page
    this.static('/',path.join(__dirname,'../public'))

    // Customize @loopback/http-explorer configuration here
    this.configure(RestExplorerBindings.COMPONENT).to({
      path: '/explorer',})
    this.component(RestExplorerComponent)

    this.component(HealthComponent)

    this.middleware(testLoggingMiddleware) // adding middleware in application

    this.projectRoot = __dirname
    // Customize @loopback/boot Booter Conventions here
    this.bootOptions = {
      controllers: {
        // Customize ControllerBooter Conventions here
        dirs: ['controllers'],extensions: ['.controller.js'],nested: true,}
  }
}

解决方法

使用您的中间件,我可以在控制台上看到日志,按照 @Varun 建议将 MySequence 类替换为以下代码后,您可以获得更多详细信息 here

import { MiddlewareSequence } from '@loopback/rest';

export class MySequence extends MiddlewareSequence {}

为了能够向客户端发送响应,您需要从中间件返回 await next()

export const testLoggingMiddleware: Middleware = async (
  middlewareCtx: MiddlewareContext,next: Next,) => {
  const {request} = middlewareCtx
  console.log('Request: %s %s',request.headers,request.method,request.originalUrl)
  try {
    // Proceed with next middleware
    const result = await next()
    // Process response
    console.log('Response received for %s %s',request.originalUrl)
    return result
  } catch (err) {
    // Catch errors from downstream middleware
    console.error('Error received for %s %s',request.originalUrl)
    throw err
  }
}
,

如果有人仍然遇到这个问题,这对我有用:

  1. 更新您的 sequence.ts 使其看起来像这样:
    import { MiddlewareSequence } from '@loopback/rest';
    
    export class MySequence extends MiddlewareSequence {}
  1. 在 /src/middleware/example.middleware.ts 上创建中间件

import { Next } from '@loopback/core'
import { Middleware,MiddlewareContext } from '@loopback/rest'

export const exampleMiddleware: Middleware = async (
  middlewareCtx: MiddlewareContext,request.originalUrl)
    throw err
  }
}
  1. 在 application.ts 中注册您的中间件
    import {ApplicationConfig} from '@loopback/core';
    import {RestApplication} from '@loopback/rest';
    import {exampleMiddleware} from './middleware/example.middleware';

    export class MyApplication extends RestApplication {
      constructor(config: ApplicationConfig) {
        // register your middleware
        this.middleware(exampleMiddleware);
      }
    }

  1. 运行应用并检查您的控制台。

Reference doc

,

@Rifa所述,您需要更新MySequence

之前,它具有以下内容-

import { inject } from '@loopback/context';
import {
  FindRoute,InvokeMethod,ParseParams,Reject,RequestContext,RestBindings,Send,SequenceHandler,InvokeMiddleware
} from '@loopback/rest';

const SequenceActions = RestBindings.SequenceActions;

export class MySequence implements SequenceHandler {
  /**
   * Optional invoker for registered middleware in a chain.
   * To be injected via SequenceActions.INVOKE_MIDDLEWARE.
   */
  @inject(SequenceActions.INVOKE_MIDDLEWARE,{ optional: true })
  protected invokeMiddleware: InvokeMiddleware = () => false;

  constructor(
    @inject(SequenceActions.FIND_ROUTE) protected findRoute: FindRoute,@inject(SequenceActions.PARSE_PARAMS) protected parseParams: ParseParams,@inject(SequenceActions.INVOKE_METHOD) protected invoke: InvokeMethod,@inject(SequenceActions.SEND) public send: Send,@inject(SequenceActions.REJECT) public reject: Reject
  ) {}

  async handle(context: RequestContext) {
    try {
      const { request,response } = context;
      // Invoke registered Express middleware
      const finished = await this.invokeMiddleware(context);
      if (finished) {
        // The response been produced by the middleware chain
        return;
      }
      const route = this.findRoute(request);
      const args = await this.parseParams(request,route);
      const result = await this.invoke(route,args);
      this.send(response,result);
    } catch (err) {
      this.reject(context,err);
    }
  }
}

替换为-

import { MiddlewareSequence } from '@loopback/rest';

export class MySequence extends MiddlewareSequence {}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-