RestyGWT简介
定义: RestyGWT是一个REST服务GWT生成器和Java Object JSON数据格式转换引擎。它能够生成基于JSON的异步Restful服务代理,提供易于使用的REST API。
REST Services
RestyGWT的 Rest Services能够生成基于JSON的异步Restful服务,和GWT中的异步类似:
public interface PizzaService extends RestService {
@POST
public void order(PizzaOrder request,
MethodCallback<OrderConfirmation> callback);
}
@POST:表示以POST方式向Server端发送数据,server端的servlet具体实现时应该是doPost()。
Java beans可以通过JSON的编码和解码向Server端发送和从server端返回,以PizzaOrder为例:
public class PizzaOrder {
public String phone_number;
public boolean delivery;
public List<String> delivery_address = new ArrayList<String>(4);
public List<Pizza> pizzas = new ArrayList<Pizza>(10);
}
JSON形式:
{
"phone_number":null,
"delivery":true,
"delivery_address":[
"3434 Pinerun Ave.",
"Wesley Chapel, FL 33734"
],
"pizzas":[
{"quantity":1,"size":16,"crust":"thin","toppings":["ham","pineapple"]},
{"quantity":1,"size":16,"crust":"thin","toppings":["extra cheese"]}
]
}
在GWT的客户端调用server端服务:
1. 创建一个REST service 的实例,并和HTTP URL关联起来。示例代码如下:
Resource resource = new Resource( GWT.getModuleBaseURL() + "pizza-service");
PizzaService service = GWT.create(PizzaService.class);
((RestServiceProxy)service).setResource(resource);
service.order(order, callback);
2. 使用Rest API
Resource resource = new Resource("http://search.yahooapis.com/WebSearchService/V1/webSearch?appid=YahooDemo&query=finances&format=pdf&output=json&callback=callback");
resource.jsonp().send(new JsonCallback() {
public void onSuccess(Method method, JSONValue response) {
JSONObject obj = (JSONObject) ((JSONObject) response).get("ResultSet");
RootPanel.get().add(new Label("Search Results Available: " + obj.get("totalResultsAvailable")));
}
public void onFailure(Method method, Throwable exception) {
Window.alert("Error x: " + exception);
}
});
JSON Encoder/Decoders
要实现Java Object与JSON数据格式转换,必须定义一个接口来继承JsonEncoderDecoder接口,这样RestyGWT就可以实现Java Object与JSON数据的转换了,使用encode和decode方法即可。 示例:
1. 首先,定义接口:
public interface PizzaOrderCodec extends JsonEncoderDecoder<PizzaOrder> {
}
2. 使用encode和decode方法:
// GWT will implement the interface for you
PizzaOrderCodec codec = GWT.create(PizzaOrderCodec.class);
// Encoding an object to json
PizzaOrder order = ...
JSONValue json = codec.encode(order);
// decoding an object to from json
PizzaOrder other = codec.decode(json);
REST API
RestyGWT提供了易于使用的REST API,支持所有的HTTP methods,在调用过程中用参数来设置HTTP Accept 和 Content-Type header,并且可以设置response code和request timeout。 示例:
Resource resource = new Resource( GWT.getModuleBaseURL() + "pizza-service");
JSONValue request = ...
resource.post().json(request).send(new JsonCallback() {
public void onSuccess(Method method, JSONValue response) {
System.out.println(response);
}
public void onFailure(Method method, Throwable exception) {
Window.alert("Error: "+exception);
}
});
每次请求时必须创建一个新的Method 对象,由下面的HTTP methods产生:
resource.head(); resource.get(); resource.put(); resource.post(); resource.delete()
可以通过下面的方法来设置Content-Type header:
method.text(String data) // HTTP request body为text
method.xml(Document data) // HTTP request body为xml
method.json(JSONValue data) // HTTP request body为json
可以通过下面的方法来设置Accept header(与Content-Type 类似):
method.send(TextCallback callback)
method.send(JsonCallback callback)
method.send(XmlCallback callback)