- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我想知道在编写应用程序时如何将传输层(REST API/GraphQL)与业务逻辑层分开。实现业务逻辑函数/方法时,例如postCreate
,它可能看起来像这样:
async function postCreate (viewer, params) {
// validate params (don't allow additional params!)
// authorize viewer
// filter/modify/authorize params according to viewer role
// perform some logic
// filter output according to viewer role
// return result
}
如果我想让 GraphQL 远离业务逻辑,我将不得不实现在 postCreate
中执行的所有操作自己运行(或使用第三方库)。另外如果 postCreate
函数将返回嵌套数据,例如 post.author.firends
那么我将不得不处理 postCreate
中复杂的图形结构函数参数。
另一方面,用 GraphQL 编写这样的函数很容易,因为有开箱即用的输入/输出验证/过滤,处理嵌套数据也很容易,可以使用 GraphQL 解析器完成授权 context
参数等。
我想得越久,就越坚信 GraphQL 是编写业务逻辑的理想选择。可以通过 HTTP 公开 GrpahQL api 的事实只是一个不错的功能。如果我想制作一个标准的 REST API,我可以从 http 路由调用 GraphQL,例如:
app.post('/posts', async function (req, res, next) {
const query = `mutation ($input: PostCreateData!) { postCreate (input: $input) { id, title } }`;
const variables = { input: req.body };
await graphql({ query, variables });
})
当然,这是一个非常简单的示例 - 在现实世界中,我们必须实现一些额外的参数,这些参数将表示用户希望在响应中接收的字段(可能是嵌套的)、正确处理错误等等。
无论如何,我的问题不是关于 REST API,因为现在 99% 的人我只写 GraphQL。问题是——为什么不在业务逻辑层使用 GraphQL?我想到的唯一缺点是,如果我想从我的应用程序的“内部”调用一些业务逻辑方法,我将不得不使用 GraphQL 查询来调用它,这感觉有点尴尬——但我想这可以通过以下方式解决将 GraphQL 查询编写为普通对象 (json) 并转换为 GraphQL...
大家怎么看?您是否将 GraphQL 用于业务逻辑?
最佳答案
您可能已经回答了自己的问题:
The only drawback that comes to my mind is that if I would like to call some business logic method from "inside" of my app I would have to call it with GraphQL query which feels little bit awkward
GraphQL 解析器的结构非常容易理解,您当然应该利用它。
有些人最终使用 ORM 来处理业务逻辑,但是,如果这对您来说更容易,您可以使用函数式编程接口(interface)来构建您的业务逻辑。
最重要的部分是您的业务逻辑无需通过 GraphQL 即可直接调用。
关于node.js - 为什么不使用 GraphQL 作为业务逻辑层呢?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44392156/
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我在这里感觉有些不对劲,所以我希望社区提供意见 - 也许我以错误的方式处理这个问题...... 问:是否适合使用传统的基础架构日志框架(如 log4net)来记录业务事件? 当我说业务事件时,我的意思
技术也好,业务也罢; 01 【什么是业务?】 对于那些久经职场的人,也很难一句话说明白; 业务,作为工作中绝对的核心点,即便在一个公司待的足够久,
三天研发,两天设计; 01 【优先做设计方案】 职场中的那些魔幻操作,研发最烦的是哪个? 作为一个数年且资深的互联网普通开发,可以来说明一下为什么
业务、系统、接口(interface)、持久化类是什么意思?用一些例子解释一下? 最佳答案 业务可能是应用程序中所有功能部分发生的部分(即计算或规则) 系统是您的操作系统 接口(interface),
我无法创建带有指向移动应用的外部链接的简单广告。我已正确设置访问权限,可以创建广告系列、广告集、加载图像,但在创建广告期间出现错误: Ads and ad creatives must be asso
我是软件工程专业的学生,现在我正在为我的期末项目工作,安排在交易日进行商务配对。 这个想法是将卖家(开发人员)和买家(有经济能力的人)在一起。 算法应该像“快速约会”。 假设我有 15 张 table
我们只需按照以下说明在 AWS Cloudformation 上部署企业 WhatsApp API: AWS WhatsApp API 所以一切正常,部署正确完成,问题出在“SSL 配置”选项上,我们
我的应用因为以下原因被拒绝了 Guideline 3.2 - Business We found that your app is not appropriate for the App Store
您好,我想在我的网络应用程序中使用 WhatsApp 业务 API。我已经在 postman 中测试过了。 每当在 WhatsApp 选项卡下的 Facebook 业务页面中运行示例 curl 代码时
我是 Skype for Business 技术的新手,我正在尝试部署一个我愿意与 Skype WebSDK 和 AppSDK 一起使用的服务器。 起初我尝试使用Skype进行在线商务,但websdk
Apple 开发人员以此为由拒绝了我的应用。 “业务 - 3.1.1您的应用程序包含一个帐户注册功能,该功能被视为对外部机制的访问,以便在应用程序中使用购买或订阅。此功能不符合 App Store 审
我正在玩 Realm for Android。 我喜欢自动更新对象的想法,但我对它的软件架构有顾虑。 我已经看到许多提议的架构都指定了一个层来处理数据/数据库访问,理想情况下,更高层不会知道有关数据库
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 10 个月前。 Impro
我正在尝试设置 Whatsapp 业务 API。 引用Link用于设置。 我正在使用 Windows 10 操作系统。 -- 仅供引用。 在初始设置部分,使用命令 docker-compose up
我正在尝试使用 Facebook Business SDK 创建一个 facebook Adaccount .但是当我使用方法 createAdAccount 时,它会给我一个错误。请参阅下面的图片。
我想写一个概念证明 MonoMac使用 c# 和 Razor 呈现 html“ View ”的应用程序。 这可能吗? 如果没有,是否有人推荐与 Razor 的简单性相比的任何其他模板引擎。如果必须的话
无法解析 ':business:diary@debug/compileClasspath': Could not resolve project :fun:push. 的依赖关系 无法解析项目:fun
当我尝试在 Visual Studio Professional 2015 14.0.23107.0 中打开某些 XML 文件时,XML 编辑器出现白屏并显示以下文本: 为什么我不能编辑这个文件?此项
我是一名优秀的程序员,十分优秀!