我该如何与服务器通信?

时间:2013-09-29 02:42:18

标签: clojure pedestal

想象一下,有些人想要在披萨服务器上查询比萨饼列表。这个人只会做

 GET /pizzas
 ;=> ["cheese", "extra cheese", "broccoli"]

使用 pedestal-app 的数据模型和消息,我不知道如何设计客户端 - 服务器通信。以下是几分钟的吊床带来的可能性:

  1. 效果消费者
    • 将邮件转换为HTTP请求
    • 将结果转换回(例如[{:type :add :topic [:pizzas] :value "cheese"} ...]
    • 将消息放入队列
  2. 服务器上的专用资源例如“/ edn”)
    • 接受基座消息
    • 发送到正确的功能
    • 回复原始数据( [“奶酪”,“额外的奶酪”,“西兰花”])
    • 让effect-consumer将结果转换回消息
  3. 使用路径的专用资源。就像#2一样,但是
    • 更改请求
    • 将其转发到路线表中的另一个条目
  4. 双方留言,有
    • 服务器将消息转换为函数调用
    • 服务器将结果转换回消息
    • 客户端只是将这些消息添加到队列
  5. 在我看来,通过方法#2和#4,我绕过并失去了拦截器的所有好处。方法#2,我需要加倍路由逻辑。使用方法#4,我还需要生成大量代码来容纳基座客户端。

    选项#1和#3看起来更好,但#3闻起来很乱,#1,误导。

    你们是怎么做到的?

    谢谢!

1 个答案:

答案 0 :(得分:0)

我不知道基座,我一直在使用ring / compojure / etc。

使用ring,您可以使用ring.middleware.json并在页面周围放置ring.middleware.json/wrap-json-responsering.middleware.json/wrap-json-params,然后将入站json数据解析为参数,您可以将json返回为:

(ring.util.response/response ["cheese", "extra cheese", "broccoli"])

如果您的图书馆不支持这些行为,您可以从环等中提取相关代码。