`
xianbin
  • 浏览: 212649 次
  • 来自: ...
社区版块
存档分类
最新评论

让你的Play framework 1.2 支持Ajax!

阅读更多
相信正在使用Play Framework 1.2的朋友一定会碰到使用Ajax在Play中做异步请求是碰到的困惑。

Play Framework 1.2版本是不支持原生的Javascript的Ajax请求的,如果你使用JQuery.Ajax去发送JSON数据,在Play的Controller内是无法获得JSON对象字符串的,今天通过搜索,终于找到了一个非常好的解决方案,可以让你的Play更好的支持Ajax请求。

在加入下面代码之前,需要你的Play中包含有GSON(Google的json库)。

首先在Play项目中添加一个类:
@Global
public class JsonObjectBinder implements TypeBinder<JsonObject> {

	@Override
	public Object bind(String name, Annotation[] annotations, String value,
			Class actualClass, Type genericType) throws Exception {
		return new JsonParser().parse(value);
	}

}


Controller中接收Ajax请求的方法:
	public static void auditPass(JsonObject body) {
		String msgId = body.get("id").toString();
		String content = body.get("content").toString();
		
		HashMap<String, String> result = new HashMap<String, String>();
		result.put("result", "true");
		renderJSON(result);
	}


Ajax请求发送代码:
var params = {
    id : "12",
    content: "test"
};

var jsonString= $.toJSON(params);

$.post('/Controller/auditPass', jsonString, function(data) {
   alert(data.result);
});


怎么样?是不是有限像Spring MVC中的Restful风格呢?
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics