我已经尝试过阅读CouchDB文档,但我觉得这个领域有点模糊(FAUXTON,vhost规范)。我已经搜索并阅读了stackoverflow上的响应" couchdb vhosts"和" couchdb重写网址"并尝试应用我可以在那里收集的建议。仍然坚持这一点,如果有人能提供它,将会欣赏一些具体的方向。
我在couchDB数据库中有大约1900个文档。每个文档都有一个"类型"键。我已经制作了30个设计文档,每个"类型"。每个设计文档都有一个名为" all"返回该类型文档的所有行。
在下面的信息中,dasvm01.com不是实际的服务器。它位于公司防火墙后面,外部世界无法访问。我一直试图一直使用它,如果我在任何地方都犯了错误,请原谅我。
所以,现在我可以从浏览器执行这样的GET:
dasvm01.com:5984/registryservice/_design/airplaneidtypes/_view/all
我的直接目标是将其缩短为:
dasvm01.com:5984/registryservice/airplaneidtypes
或
dasvm01.com:5984/registryservice/airplaneidtypes/all
为此,我在airplaneidtypes设计文档中添加了一个重写函数:
{
"_id": "_design/airplaneidtypes",
"_rev": "11-c28b41a718017cbcd65f82f4acc611cb",
"views": {
"all": {
"map": "function (doc)
{ if(doc.ddoc === 'airplaneidtypes')
{ emit(doc._rev,doc); }
}"
}
},
"language": "javascript",
"rewrites": [
{
"from": "/airplaneidtypes",
"to": "registryservice/_design/airplaneidtypes/_rewrite",
"method": "GET"
}
]
}
现在我认为我需要更新CouchDB守护进程:vhosts设置:我对它进行了一次破解,但我真的没有信心,而且它似乎没有用。在Fauxton,我有:
daemons
auth_cache {couch_auth_cache, start_link, []}
...
vhosts {dasvm01.com:5984, /registryservice/_design/airplaneidtypes/_rewrite, []}
不确定是否: - 关闭, - 关闭, - 不是正确的地方, - 只需要报价......
你能告诉我什么?我不理解Fauxton试图表达的默认值:
vhosts
Virtual hosts manager. Provides dynamic add of vhosts without restart, wildcards support and dynamic routing via pattern matching
[daemons]
vhosts={couch_httpd_vhost, start_link, []}
最终,我希望/希望允许用户在URL上传递多个key:value对,然后将它们重写为MANGO查询。用户会传递这样的内容:
dasvm01.com:5984/registryservice/airplaneidtypes/model/A320/variant/251N
将被重写为MANGO查询:
{
"selector": {
"model": "A320",
"variant": {"$eq": "251N"}
},
"fields": [
"_id",
"_rev",
"status",
"model",
"variant",
"variant-type",
"oem",
"historicaloem",
"displaymodel",
"actsmodel"
]
}
答案 0 :(得分:0)
最终,我希望/希望允许用户传递多个键:值 在URL上配对,然后将它们重写为MANGO查询。用户 会传递这样的东西:
dasvm01.com:5984/registryservice/airplaneidtypes/model/A320/variant/251N
我不确定您使用的是哪种服务器端技术,但对于NodeJS / ExpressJS,您可以这样做:
用户从浏览器中向ExpressJS服务器发送以下GET请求:
GET /registryservice/airplaneidtypes/model/A320/variant/251N
在dasvm01.com
上运行并侦听(例如)端口8080
的ExpressJS收到GET请求并按如下方式处理:
app.get('/registryservice/:typeId/model/:modelId/variant/:variantId', (req, res)=>{
// Now you have acess to req.params object
// You can use them as you wish:
mango_query = {
"selector": {
"model": `${req.params.modelId}`,
"variant": {"$eq": `${req.params.variantId}`}
},
"fields": [
"_id",
"_rev",
// ...
]
}
// You can communicate with CouchDB by making HTTP requests
// to CouchDB server which is running (for example) on 127.0.0.1 and listening
// on port 5984
// For sending HTTP requests, you might use `node-fetch` package
})
基本上,上述想法是使用ExpressJS服务器的route parameters,以便您可以重新路由用户请求。