POST CherryPyのリクエストからJSONを受信する方法は?
私は このページ に行ったことがありますが、API、そのパラメーター、およびAPIが何をするかを説明するのに優れています。それらを使用して受信JSONをオブジェクトに解析する方法を理解できないようです。
ここに私がこれまで持っているものがあります:
import cherrypy
import json
from web.models.card import card
from web.models.session import getSession
from web.controllers.error import formatEx, handle_error
class CardRequestHandler(object):
@cherrypy.expose
def update(self, **jsonText):
db = getSession()
result = {"operation" : "update", "result" : "success" }
try:
u = json.loads(jsonText)
c = db.query(card).filter(card.id == u.id)
c.name = u.name
c.content = u.content
rzSession.commit()
except:
result["result"] = { "exception" : formatEx() }
return json.dumps(result)
そして、これが投稿をするための私のjquery呼び出しです
function Update(el){
el = jq(el); // makes sure that this is a jquery object
var pc = el.parent().parent();
pc = ToJSON(pc);
//$.ajaxSetup({ scriptCharset : "utf-8" });
$.post( "http://localhost/wsgi/raspberry/card/update", pc,
function(data){
alert("Hello Update Response: " + data);
},
"json");
}
function ToJSON(h){
h = jq(h);
return {
"id" : h.attr("id"),
"name" : h.get(0).innerText,
"content" : h.find(".Content").get(0).innerText
};
}
作業例:
_import cherrypy
import simplejson
class Root(object):
@cherrypy.expose
def update(self):
cl = cherrypy.request.headers['Content-Length']
rawbody = cherrypy.request.body.read(int(cl))
body = simplejson.loads(rawbody)
# do_something_with(body)
return "Updated %r." % (body,)
@cherrypy.expose
def index(self):
return """
<html>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script type='text/javascript'>
function Update() {
$.ajax({
type: 'POST',
url: "update",
contentType: "application/json",
processData: false,
data: $('#updatebox').val(),
success: function(data) {alert(data);},
dataType: "text"
});
}
</script>
<body>
<input type='textbox' id='updatebox' value='{}' size='20' />
<input type='submit' value='Update' onClick='Update(); return false' />
</body>
</html>
"""
cherrypy.quickstart(Root())
_
リンクしたドキュメントは、バージョン3.2で新しく追加されたいくつかのCherryPyツールについて説明しています。 _json_in
_ツールは基本的に上記を実行しますが、より厳密で、3.2の新しいボディ処理APIを使用します。
注意すべき重要な点の1つは、jQueryのpost
関数は、JSONを送信(受信のみ)できないようです。 dataType
引数は、XmlHTTPRequestが期待するデータのタイプreceiveを指定します。送信するタイプではありません。また、指定できる引数がないようです。送信したいタイプ。代わりにajax()
を使用すると、それを指定できます。
import cherrypy
class Root:
@cherrypy.expose
@cherrypy.tools.json_out()
@cherrypy.tools.json_in()
def my_route(self):
result = {"operation": "request", "result": "success"}
input_json = cherrypy.request.json
value = input_json["my_key"]
# Responses are serialized to JSON (because of the json_out decorator)
return result
//assuming that you're using jQuery
var myObject = { "my_key": "my_value" };
$.ajax({
type: "POST",
url: "my_route",
data: JSON.stringify(myObject),
contentType: 'application/json',
dataType: 'json',
error: function() {
alert("error");
},
success: function() {
alert("success");
}
});
_cherrypy.request.json
_を使用する必要があるため、@cherrypy.tools.json_in()
の方法はあまりクリーンではないことがわかりました。代わりに、次のデコレータはGET
パラメータを模倣しようとします。
以下はこれを助けます。
注:これは、JSONを返すことを前提としています。
_def uses_json(func):
@functools.wraps(func)
@cherrypy.tools.accept(media="application/json")
def wrapper(*args, **kwargs):
cherrypy.serving.response.headers['Content-Type'] = "application/json"
kwargs = dict(kwargs)
try:
body = cherrypy.request.body.read()
kwargs.update(json.loads(body))
except TypeError:
pass
return json.dumps(func(*args, **kwargs)).encode('utf8')
return wrapper
_
例:
_ {"foo": "bar"}
_
に翻訳されます
_ @cherypy.expose
@uses_json
def endpoint(foo):
....
_