面对羽毛挑战
在使用 FeathersJS V5 和 TypeScript 时,我遇到了一个特殊的挑战:在自定义服务中访问用户对象。虽然身份验证机制仍然生成用户对象,但它不再包含在默认的ServiceParams
类型定义中。这给基于 TypeScript 的项目带来了类型安全障碍。
揭晓解决方案
幸运的是,有一个简单的解决方案可以弥补这一差距。以下是有效访问用户对象的分步指南:
-
在您的自定义服务类中,
@feathersjs/cli
创建了一个自定义接口,该接口扩展了基本ServiceParams
接口:export interface OrdersParams extends Params < OrdersQuery > { // add user property to params user : UserModel ; }
-
现在您将能够在服务方法中访问用户对象:
export class OrdersService < ServiceParams extends OrdersParams = OrdersParams > implements ServiceInterface < Orders , OrdersData , ServiceParams , OrdersPatch > { constructor ( public options: OrdersServiceOptions ) {} async find (_params?: ServiceParams ): Promise < any > { // Access user properties safely here const user = _params?. user ; return []; } }
主要考虑因素:
- 确保您的身份验证插件将用户对象正确附加到上下文。
- 处理用户对象可能丢失或无效的情况,以确保稳健的应用程序行为。
- 遵守可维护和可扩展代码的类型安全原则。
这种方法的好处:
- 类型安全:保持类型一致性并防止潜在错误。
- 灵活性:在特定服务方法中自定义用户对象访问。
- 清晰度:提高未来开发人员的代码可读性和理解性。
结论
通过执行这些步骤,您可以放心地访问 TypeScript FeathersJS V5 自定义服务中的用户对象,确保类型安全并简化您的开发体验。采用这种技术来解锁 FeathersJS 应用程序中以用户为中心的功能!
原文: https://atlassc.net/2024/01/05/unlocking-user-data-in-typescript-feathersjs-v5-custom-services