如何解决如何在Marklogic Grove中的node.js中处理REST API?
我正在使用MarkLogic grove(React)开发UI应用程序。
默认情况下,来自Web浏览器的REST API调用将直接转发到MarkLogic。
例如:http://主机名/ v1 / resources / foo /
如果REST API是特定路径,我想按原样在node.js中进行处理,而无需将调用转发给MarkLogic。 我应该在哪里以及如何实现它?(仅对经过身份验证的用户可用)。
例如:http://主机名/ my-rest-api / bar
解决方法
不幸的是,Grove的文档还不存在。如果要讨论对MarkLogic后端的封送前端调用,则是在谈论Grove中间层:grove-node。该子项目中嵌入了一些文档,这可能是最好的起点。
该子项目的顶级README具有指向Endpoints and Routes的更多文档的指针。它也没有提供很多帮助,但是确实告诉您在哪里看。格罗夫节点中间层基本上是ExpressJS服务器。我们将主要逻辑(主要是静态逻辑)隐藏在可以找到here的子模块中。重要的部分是实际的业务逻辑(称为中间件)已放入名为routes/
的文件夹中。
尽管我们试图以默认Route的形式提供许多常用功能,但您仍可以在其中编写/添加任何您喜欢的ExpressJS逻辑。您可以在routeFactory
顶部附近找到routes/api/index.js
。
包含分支最新版本的grove-node的master分支是相当最新的,但是克隆该存储库的development分支并替换/更新生成的{{1} }文件夹中包含该开发分支中的内容。您应该能够做一个相当简单的目录比较,以应用看起来有价值的更新。
开发分支至少包含一个名为Grove defaultRestRoute的新添加项,它允许将随机URI重写为MarkLogic中的任何新目标URI。本来是用于REST扩展的,但是对于映射到数据服务,/ v1 / values,/ v1 / rows或/ v1 / sparql调用也非常有用。这比传统的白名单代理要好得多,后者通常是为了快速解决和向后兼容而维护的。
下面是一个使用defaultRestRoute的示例,该代码附加在middle-tier/
的结尾处:
middle-tier/routes/api/index.js
它在具有CRUD终结点的应用程序中使用,该终结点用于名为Media的实体。上面的路由提供对媒体文件实际二进制文件的访问,而普通的CRUD GET调用返回包含元信息的Entity信封。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。