有人可以帮助我了解如何在 graphQL lambda 应用程序中抛出身份验证错误吗?我正在使用无服务器的 graphQL-yoga,我可以对请求进行身份验证,并返回我从 jwt 获得的用户、无令牌{}
,或者在令牌旧时抛出身份验证错误。当我抛出错误时,它会被我的身份验证块的 catch 语句捕获,但我不知道如何实际从 lambda 返回它。
const lambda = new GraphQLServerLambda({
typeDefs,
context: ({ event, context }) =>
authenticate(event.headers.Authorization)
.then(user => ({ db: mainDb, user}))
.catch(e => {
console.log('Caught the auth error here');
throw e;
}),
Query: { \ some queries here.... },
Mutation: { \ some mutations here...}
});
如何格式化错误或从正确的位置抛出错误,以便出现实际的格式化错误?相反,我在客户端中收到Unexpected token I in JSON...
错误。显然,我需要在throw
期间进行某种格式化,但对我来说如何做到这一点并不完全明显。
如果有帮助,请在我的导出部分中。我正在尝试从尝试/捕获到然后/捕获的所有方法,在这一点上,我似乎已经错过了捕获错误。有没有更好的方法可以做到这一点?我需要的主要事情是能够进行身份验证,拒绝不良令牌,否则只需为未登录的用户返回{}
。我很难找到允许非登录用户的自定义授权方,这就是为什么我直接在我的 graphQL 端点中进行身份验证的原因
exports.server = (event, context, callback) => {
try {
return lambda
.graphqlHandler(event, context, callback)
.then(b => b)
.catch(e => console.log(`can't catch it here ${e}`));
} catch (e) {
console.log('or here');
callback(e);
}
};
我终于明白了!以下是抛出、捕获和格式化在无服务器的 lambda 函数中生成的错误的正确方法。诀窍是创建一个修改后的回调,该回调被传递到 graphQL Handler 中。解析函数后,它将运行所需的任何代码。
此外,Seanvm 是正确的,研究 lambda 函数的类型很重要 - 默认情况下,无服务器设置了一个代理 lambda 函数,这需要像我在下面所做的那样格式化输出并将 null 作为错误传递。
exports.server = (event, context, callback) => {
const modifiedCallback = (error, output) => {
if (output.body.includes('401')) {
callback(null, {
statusCode: 401,
headers: { 'Content-Type': 'application/javascript' },
body: JSON.stringify({ message: 'Unauthorized' })
});
} else {
callback(error, output);
}
};
return lambda.graphqlHandler(event, context, modifiedCallback);
};
自定义错误消息的一个选项是创建Error
类的新实例。
一个例子是:
.catch(e => {
console.log('Caught the auth error here');
throw new Error('Authentication Failed');
}),
由于回调函数的第一个参数将是错误消息,因此您也可以将一般错误直接粘贴到处理程序函数中:
callback("An error happened!");
您还可以使用 Middy 等中间件来帮助处理错误:
https://github.com/middyjs/middy/blob/master/docs/middlewares.md#httperrorhandler
关于 NodeJS 错误处理的有用链接:
https://www.joyent.com/node-js/production/design/errors