gpt4 book ai didi

clojure - 我应该如何与服务器通信?

转载 作者:行者123 更新时间:2023-12-02 21:16:39 24 4
gpt4 key购买 nike

想象一下有人想要向披萨服务器查询披萨列表。这个人会简单地做

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

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

  1. 一个效果消费者
    • 将消息转换为 HTTP 请求
    • 将结果转换回(例如 [{:type :add :topic [:pizzas] :value "cheese"} ...])
    • 将消息放入队列
  2. 服务器上的专用资源(例如“/edn”)
    • 接受基础消息
    • 分派(dispatch)到正确的函数
    • 响应原始数据( [“奶酪”、“额外奶酪”、“西兰花”])
    • 让效果消费者将结果转换回消息
  3. 使用路由的专用资源。就像#2一样,但是
    • 更改请求
    • 将其转发到路由表中的另一个条目
  4. 双方消息
    • 服务器将消息转换为函数调用
    • 服务器将结果转换回消息
    • 客户端只是将这些消息添加到队列中

在我看来,使用方法 #2 和 #4,我会绕过并失去拦截器的所有好处。使用方法#2,我需要加倍路由逻辑。使用方法 #4,我还需要生成大量代码来适应基座客户端。

选项#1和#3看起来更好,但是#3有点老套,而#1则误导了。

你们做得怎么样?

谢谢!

最佳答案

我不知道 pedestal,我一直在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"])

如果您的库不支持这些行为,您可能可以从ring等中提取相关代码。

关于clojure - 我应该如何与服务器通信?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19073865/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com