CouchDB vhosts和URL重写多个参数

时间:2018-04-22 16:04:33

标签: url-rewriting couchdb vhosts couchdb-mango fauxton

我已经尝试过阅读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"
    ]
}

1 个答案:

答案 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,以便您可以重新路由用户请求。