我正在使用cherrypy的独立服务器(cherrypy.quickstart())和sqlite3作为数据库。
我想知道如何在使用cherrypy时对数据库进行ajax / jquery异步调用?
答案 0 :(得分:9)
如果您使用的是CherryPy 3.2.0-rc1,那么您可以使用装饰器@json_in
和@json_out
(see here)。
因此:
@cherrypy.expose
@tools.json_in(on = True)
@tools.json_out(on = True)
def json_test(self):
return { 'message':'Hello, world!' }
会将JSON返回给浏览器,例如
$(document).ready(function() {
$.getJSON('/json_test', function(data) {
alert(data.message);
}
}
您需要记住,CherryPy希望JSON帖子的内容类型为application/json
,使用jQuery执行此操作,使用$.ajax
和manaully设置contentType
,或者您可以使用以下便利功能:
$.postJSON = function(url, data, callback) {
$.ajaxSetup({ scriptCharset:"utf-8",
contentType:"application/json; charset=utf-8" });
$.post(url, $.toJSON(data), callback, "json");
}
此函数使用jquery-json插件,但您可以使用其他方法转换为JSON。
答案 1 :(得分:2)
使用任何其他网络服务器进行操作的方式相同 - 通过让您的javascript调用由服务器端应用程序处理的URL。