前端页面如何直接请求 MarkLogic 的 REST API

2019-09-09 15:05:21 +08:00
 jmyz0455

是这样的,接到一个需求,是要在页面上请求客户自己 MarkLogic 的内容,然后把结果展示在页面上。比如客户给的 MarkLogic 链接是 http://ip/res/tag?rs:uri=uuid,在浏览器上访问是需要填写账户密码的,在 postman 里则要在验证里选择 Digest Auth,然后填写账号密码,才能请求成功,请求成功之后返回的是一个记录列表。

结果第一步请求 MarkLogic 链接就失败了,我前端用的 HTTP 库是 Axios,代码如下:

axios.request({
    url: http://ip/res/tag?rs:uri=uuid,
    method: 'get',
    headers: {'content-type': 'application/json',},
    auth: {
        username: 'uname',
        password: 'passd',
    },
});

结果就报跨域和 401,但是网上并没有搜到页面直接请求 MarkLogic 链接的案例,于是把焦点放在摘要认证上,在网上搜到一个 digest-auth-request 前端库,然而 demo 非常简单,我照着写了段代码:

digestAuthRequest('GET', http://ip/res/tag?rs:uri=uuid, 'uname', 'passd');

依旧是报跨域和 401,问题是我无法操作客户的服务器、没法看日志、也不懂 MarkLogic 是个什么东西,网上也没有案例,但是客户一口咬定他们之前自己用 flutter 可以调取这个链接,不需要额外的配置。后来我扒了官方的文档( https://www.marklogic.com/blog/securing-a-rest-api/ ),找到了由中间件链接 MarkLogic 生成 token,再在页面里请求里,Axios 带着 token 访问 MarkLogic 链接的方法,于是我用 nodejs 写了个 express 中间件,把跨域和 401 的问题都解决了,能正常请求和返回值,我的代码如下:

axios.request({
    url: http://ip/res/tag?rs:uri=uuid,
    method: 'get',
    headers: {
        'content-type': 'application/json',
        Authorization: token, // 在中间件先生成令牌再获取到这里
    },
});

OK,这一关是通过了,但是客户还是觉得他们没有问题,是我把事情搞复杂化了,我确实不了解 MarkLogic,请问前端页面如何直接请求 MarkLogic 的 REST API ?

727 次点击
所在节点    程序员
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/599317

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX