异常参考
在本指南中,我们将介绍框架核心和官方包抛出的已知异常列表。一些异常被标记为自处理。自处理异常可以将自己转换为 HTTP 响应。
E_ROUTE_NOT_FOUND
当 HTTP 服务器收到不存在路由的请求时抛出该异常。默认情况下,客户端将收到 404 响应,您可以选择使用状态页面渲染 HTML 页面。
- 状态码:404
- 自处理:否
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_ROUTE_NOT_FOUND) {
// 处理错误
}E_ROW_NOT_FOUND
当查找单个项目的数据库查询失败时抛出该异常[例如使用 Model.findOrFail() 时]。默认情况下,客户端将收到 404 响应,您可以选择使用状态页面渲染 HTML 页面。
- 状态码:404
- 自处理:否
import { errors as lucidErrors } from '@adonisjs/lucid'
if (error instanceof lucidErrors.E_ROW_NOT_FOUND) {
// 处理错误
console.log(`${error.model?.name || 'Row'} 未找到`)
}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>
@endE_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
当 auth finder 无法验证用户凭据时抛出该异常。该异常是自处理的,并使用内容协商向客户端返回适当的错误响应。
- 状态码: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 请求期间抛出错误的通用异常。您可以直接使用此异常或创建扩展它的自定义异常。
- 状态码:在抛出异常时定义
- 自处理:是
// title: 抛出异常
import { errors } from '@adonisjs/core'
throw errors.E_HTTP_EXCEPTION.invoke(
{
errors: ['无法处理请求']
},
422
)// title: 处理异常
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_HTTP_EXCEPTION) {
// 处理错误
}E_HTTP_REQUEST_ABORTED
E_HTTP_REQUEST_ABORTED 是 E_HTTP_EXCEPTION 异常的子类。此异常由 response.abort 方法抛出。
import { errors } from '@adonisjs/core'
if (error instanceof errors.E_HTTP_REQUEST_ABORTED) {
// 处理错误
}E_INSECURE_APP_KEY
当 appKey 的长度小于 16 个字符时抛出该异常。您可以使用 generate:key 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_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)
}