异常

异常参考

在本指南中,我们将遍历框架核心和官方包引发的已知异常列表。其中一些异常被标记为 自处理自处理异常 可以自行转换为 HTTP 响应。

E_ROUTE_NOT_FOUND

当 HTTP 服务器收到对不存在路由的请求时,会引发此异常。默认情况下,客户端将收到 404 响应,并且你可以选择使用 状态页面 渲染 HTML 页面。

  • 状态码:404
  • 自处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_ROUTE_NOT_FOUND) {
// 处理错误
}

E_AUTHORIZATION_FAILURE

当 bouncer 授权检查失败时,会引发此异常。该异常是自处理的,并且使用内容协商 向客户端返回适当的错误响应。

  • 状态码:403
  • 自处理:是
  • 翻译标识符errors.E_AUTHORIZATION_FAILURE
import { errors as bouncerErrors } from '@adonisjs/bouncer'
if (error instanceof bouncerErrors.E_AUTHORIZATION_FAILURE) {
}

E_TOO_MANY_REQUESTS

当请求在给定时间内耗尽了所有允许的请求时,@adonisjs/rate-limiter 包会引发此异常。该异常是自处理的,并且使用内容协商 向客户端返回适当的错误响应。

  • 状态码:429
  • 自处理:是
  • 翻译标识符errors.E_TOO_MANY_REQUESTS
import { errors as limiterErrors } from '@adonisjs/limiter'
if (error instanceof limiterErrors.E_TOO_MANY_REQUESTS) {
}

E_BAD_CSRF_TOKEN

当提交使用 CSRF 保护 的表单时,如果没有 CSRF 令牌或 CSRF 令牌无效,会引发此异常。

  • 状态码:403
  • 自处理:是
  • 翻译标识符errors.E_BAD_CSRF_TOKEN
import { errors as shieldErrors } from '@adonisjs/shield'
if (error instanceof shieldErrors.E_BAD_CSRF_TOKEN) {
}

E_BAD_CSRF_TOKEN 异常是自处理的,用户将被重定向回表单,并且你可以使用闪存消息访问错误。

@error('E_BAD_CSRF_TOKEN')
<p>{{ message }}</p>
@end

E_OAUTH_MISSING_CODE

当 OAuth 服务在重定向期间未提供 OAuth 代码时,@adonisjs/ally 包会引发此异常。

如果在调用 .accessToken.user 方法之前处理错误,可以避免此异常。

  • 状态码:500
  • 自处理:否
import { errors as allyErrors } from '@adonisjs/bouncer'
if (error instanceof allyErrors.E_OAUTH_MISSING_CODE) {
}

E_OAUTH_STATE_MISMATCH

当重定向期间定义的 CSRF 状态缺失时,@adonisjs/ally 包会引发此异常。

如果在调用 .accessToken.user 方法之前处理错误,可以避免此异常。

  • 状态码:400
  • 自处理:否
import { errors as allyErrors } from '@adonisjs/bouncer'
if (error instanceof allyErrors.E_OAUTH_STATE_MISMATCH) {
}

E_UNAUTHORIZED_ACCESS

当某个身份验证守卫无法对请求进行身份验证时,会引发此异常。该异常是自处理的,并使用内容协商 向客户端返回适当的错误响应。

  • 状态码:401
  • 自处理:是
  • 翻译标识符errors.E_UNAUTHORIZED_ACCESS
import { errors as authErrors } from '@adonisjs/auth'
if (error instanceof authErrors.E_UNAUTHORIZED_ACCESS) {
}

E_INVALID_CREDENTIALS

当身份验证查找器无法验证用户凭据时,会引发此异常。该异常被处理,并使用内容协商 向客户端返回适当的错误响应。

  • 状态码:400
  • 自处理:是
  • 翻译标识符errors.E_INVALID_CREDENTIALS
import { errors as authErrors } from '@adonisjs/auth'
if (error instanceof authErrors.E_INVALID_CREDENTIALS) {
}

E_CANNOT_LOOKUP_ROUTE

当你尝试使用 URL 构建器 为路由创建 URL 时,会引发此异常。

  • 状态码:500
  • 自处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_CANNOT_LOOKUP_ROUTE) {
// 处理错误
}

E_HTTP_EXCEPTION

E_HTTP_EXCEPTION 是在 HTTP 请求期间抛出错误的通用异常。你可以直接使用此异常或创建扩展它的自定义异常。

  • 状态码:在引发异常时定义
  • 自处理:是
抛出异常
import { errors } from '@adonisjs/core'
throw errors.E_HTTP_EXCEPTION.invoke(
{
errors: ['无法处理请求']
},
422
)
处理异常
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_HTTP_EXCEPTION) {
// 处理错误
}

E_HTTP_REQUEST_ABORTED

E_HTTP_REQUEST_ABORTEDE_HTTP_EXCEPTION 异常的子类。此异常由 response.abort 方法引发。

import { errors } from '@adonisjs/core'
if (error instanceof errors.E_HTTP_REQUEST_ABORTED) {
// 处理错误
}

E_INSECURE_APP_KEY

appKey 的长度小于 16 个字符时,会引发此异常。你可以使用 generate ace 命令生成一个安全的应用程序密钥。

  • 状态码:500
  • 自处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_INSECURE_APP_KEY) {
// 处理错误
}

E_MISSING_APP_KEY

config/app.ts 文件中未定义 appKey 属性时,会引发此异常。默认情况下,appKey 的值是通过 APP_KEY 环境变量设置的。

  • 状态码:500
  • 自处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_INSECURE_APP_KEY) {
// 处理错误
}

E_MISSING_APP_KEY

config/app.ts 文件中未定义 appKey 属性时,会抛出此异常。默认情况下,appKey 的值是通过 APP_KEY 环境变量设置的。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_MISSING_APP_KEY) {
// 处理错误
}

E_INVALID_ENV_VARIABLES

当一个或多个环境变量未通过验证时,会抛出此异常。可以通过 error.help 属性访问详细的验证错误信息。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_INVALID_ENV_VARIABLES) {
console.log(error.help)
}

E_MISSING_COMMAND_NAME

当命令未定义 commandName 属性或其值为空字符串时,会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_MISSING_COMMAND_NAME) {
console.log(error.commandName)
}

E_COMMAND_NOT_FOUND

当 Ace 无法找到命令时,会抛出此异常。

  • 状态码:404
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_COMMAND_NOT_FOUND) {
console.log(error.commandName)
}

E_MISSING_FLAG

当执行命令时未传递必需的 CLI 标志时,会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_MISSING_FLAG) {
console.log(error.commandName)
}

E_MISSING_FLAG_VALUE

当尝试执行命令但未为非布尔 CLI 标志提供任何值时,会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_MISSING_FLAG_VALUE) {
console.log(error.commandName)
}

E_MISSING_ARG

当执行命令时未定义所需的参数时,会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_MISSING_ARG) {
console.log(error.commandName)
}

E_MISSING_ARG_VALUE

当执行命令时未为所需参数定义值时,会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_MISSING_ARG_VALUE) {
console.log(error.commandName)
}

E_UNKNOWN_FLAG

当执行命令时使用了未知的 CLI 标志时,会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_UNKNOWN_FLAG) {
console.log(error.commandName)
}

E_INVALID_FLAG

当为 CLI 标志提供的值无效时(例如,为接受数值的标志传递字符串值)时,会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_INVALID_FLAG) {
console.log(error.commandName)
}

E_MULTIPLE_REDIS_SUBSCRIPTIONS

当你尝试多次订阅给定的发布/订阅频道时,@adonisjs/redis 包会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors as redisErrors } from '@adonisjs/redis'
if (error instanceof redisErrors.E_MULTIPLE_REDIS_SUBSCRIPTIONS) {
}

E_MULTIPLE_REDIS_PSUBSCRIPTIONS

当你尝试多次订阅给定的发布/订阅模式时,@adonisjs/redis 包会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors as redisErrors } from '@adonisjs/redis'
if (error instanceof redisErrors.E_MULTIPLE_REDIS_PSUBSCRIPTIONS) {
}

E_MAIL_TRANSPORT_ERROR

@adonisjs/mail 包无法使用给定的传输方式发送电子邮件时,会抛出此异常。这通常发生在电子邮件服务的 HTTP API 返回非 200 HTTP 响应时。

你可以使用 error.cause 属性访问网络请求错误。cause 属性是 got(npm 包)返回的错误对象

  • 状态码:400
  • 自行处理:否
import { errors as mailErrors } from '@adonisjs/mail'
if (error instanceof mailErrors.E_MAIL_TRANSPORT_ERROR) {
console.log(error.cause)
}

E_SESSION_NOT_MUTABLE

当会话存储以只读模式启动时,@adonisjs/session 包会抛出此异常。

  • 状态码:500
  • 自行处理:否
import { errors as sessionErrors } from '@adonisjs/session'
if (error instanceof sessionErrors.E_SESSION_NOT_MUTABLE) {
console.log(error.message)
}

E_SESSION_NOT_READY

当会话存储尚未启动时,@adonisjs/session 包会抛出此异常。如果你未使用会话中间件,则会出现这种情况。

  • 状态码:500
  • 自行处理:否
import { errors as sessionErrors } from '@adonisjs/session'
if (error instanceof sessionErrors.E_SESSION_NOT_READY) {
console.log(error.message)
}