我正在尝试使用clojure neocons在我的Neo4j数据存储中创建一个节点,我遇到了一个错误,我认为这与格式化json有关:
Exception: com.fasterxml.jackson.core.JsonGenerationException: Cannot JSON encode object of class: class recursiftion.dao_graph$create_node: recursiftion.dao_graph$create_node@32693b5
generate.clj:148 cheshire.generate/generate
generate.clj:119 cheshire.generate/generate
core.clj:31 cheshire.core/generate-string
core.clj:21 cheshire.core/generate-string
cypher.clj:51 clojurewerkz.neocons.rest.cypher/query
core.clj:2440 clojure.core/comp[fn]
dao_graph.clj:428 recursiftion.dao-graph/create-node
model.clj:131 recursiftion.model/createNode
controller.clj:206 recursiftion.controller/fn
core.clj:99 compojure.core/make-route[fn]
core.clj:45 compojure.core/if-route[fn]
core.clj:30 compojure.core/if-method[fn]
core.clj:112 compojure.core/routing[fn]
core.clj:2570 clojure.core/some
core.clj:112 compojure.core/routing
RestFn.java:139 clojure.lang.RestFn.applyTo
core.clj:632 clojure.core/apply
core.clj:117 compojure.core/routes[fn]
keyword_params.clj:32 ring.middleware.keyword-params/wrap-keyword-params[fn]
...
根据错误报告,我怀疑这可能与Cheshire有关。但是我很困惑,因为我没有在错误发生的文件中包括Cheshire库。
我有这个作为我的包装,因为我正在制作cors POST &GET请求,我需要从控制器。clj
返回JSON(def app
(-> (handler/api app-routes)
(middleware/wrap-json-body {:keywords? true})
(middleware/wrap-json-response)
(wrap-cors routes #"^http://localhost:9000$")))
下面是controller.clj
中引用的库(ns recursiftion.controller
(:use [ring.adapter.jetty :only [run-jetty]]
[recursiftion.websocket :only [wamp-handler]]
[recursiftion.config :only [conf]]
)
(:require [compojure.core :refer :all]
[compojure.handler :as handler]
[compojure.route :as route]
[clojure.java.io :as io]
[ring.util.io :refer [string-input-stream]]
[ring.util.response :as resp]
[ring.util.response :refer [response]]
[ring.middleware.json :as middleware]
[ring.middleware.cors :refer [wrap-cors]]
[environ.core :refer [env]]
[cheshire.core :refer :all]
[recursiftion.model :as model]
[monger.json]
[clojure.pprint :refer [pprint]]))
这是我的POST端点代码在我的controller.clj
(POST "/node/create" request
(let [node_object (or (get-in request [:params :data])
(get-in request [:body :data])
"1ROUTER_ERROR")]
{:status 200
:headers {"Content-Type" "application/json"}
:body (recursiftion.model/createNode node_object)
}
))
下面是通过我的模型并在dao_graph.clj
中找到的引用库(ns recursiftion.dao_graph
(:require [clojure.string]
[clojurewerkz.neocons.rest :as nr]
[clojurewerkz.neocons.rest.cypher :as cy]
[clojure.pprint :refer [pprint]])
(:import [org.bson.types.ObjectId])
)
下面是在dao_graph.clj中调用的函数的定义:
(defn create-node [ nodeobj ]
(let [ _nodeobj nodeobj ]
(cy/tquery conn create-node { :_nodetype (get-in _nodeobj [:type]) })))
这里是一个cypher查询,它返回一个映射,"…"作为键
(def create-node "CREATE (m:{_nodetype})
RETURN M;")
我非常感谢你帮助我解决这个问题。
没有足够的信息。然而,当cheshire不能识别被告知编码为json的数据类型时,通常会出现这种异常。错误看起来像你可能试图json编码一个函数,而不是从一个函数输出?我将在端点中添加println,并打印出您认为返回的内容。如果输出看起来像一个函数对象,而不是json可以编码的东西,这可能是原因。
至于发生这种情况的地方,我的猜测是您的中间件正在尝试将响应体编码为json。
是的,这些信息还不够。但是,根据您的异常,可以清楚地看到cheshire不知道类型"recursiftion.dao_graph$create_node"这就是它抛出这个异常的原因。
简单的解决方案是在发送到Cheshire之前将其解析为已知数据,例如
(defn my-parser
[data]
(assoc data :index_with_not_know_type (str (:index_with_not_know_type data))))
Obs:在我的情况下,我只是cast:index_with_not_know_type值字符串
然后,在你的例子中,你可以这样做
(POST "/node/create" request
(let [node_object (or (get-in request [:params :data])
(get-in request [:body :data])
"1ROUTER_ERROR")]
{:status 200
:headers {"Content-Type" "application/json"}
:body (-> (recursiftion.model/createNode node_object)
(my-parser))
}
))