RESTful的一个样例

后台代码:
1 @RequestMapping(value = { "queues" })
2 @ResponseBody
3 public List<ResourcePool> list(Model model) {
4 List<ResourcePool> lst = Lists.newArrayList();
5 ......
6 return lst;
7 }
前台处理:
 1 $(function() {
 2 $.getJSON("${ctx}/v1/resourcepool/queues/", function(data){
 3 $.each(data, function(key, queue){
 4 var tr = "<tr>"
 5 tr = tr + "<td>" + queue.queueName + "</td>";
 6 ... ...
 7 tr = tr + "</tr>";
 8 $("#contentTable").append(tr);//向table中追加tr
 9 })
10 })
11 });
12  

 

即使后台返回的是一个list,前台处理的也是一个Map,key是0,1,2..,value才是List里面的对象;
异常信息
页面不存在(503):请求controller(资源)的路径是没问题,但是controller返回的路径是有问题的。
路径不存在(403):Forbitten(禁止)访问资源;服务器网站存在,但是资源可能不存在;URL写错了
400 Bad Request:调试了半天,终于调通了原来是因为;@PathVariable里面的参数名称和@RequestMapping里面的参数不一致造成的。
@RequestMapping(value = { "queues/{queueName}" }, method = RequestMethod.POST)
public String removeTenant(@PathVariable("queueName") String userName, Model model) throws Throwable {
RESTful要搞清楚是请求;之前纠结于一个问题,就是会页面显示的${},我想要把${}给干掉, RESTful嘛;但是你要知道你在JSP页面搞这个东西没有问题;因为页面都是在服务器上面处理;包括页面你也可以搞addModel,这都是没有问题;
你要考虑的是如果别人是第三方,你放心别人第三方是不可能去请求你的页面的,能请求的只是你的 数据;请求的你的数据,请求你的数据;所以页面需要和请求数据,提交数据分离开来。页面扮演第三方的角色;页面本身是可以有${};但是你要注意不能使用spring的那种自动绑定数据,和数据相关的都不能使用spring了;数据相关只能通过RESTful的接口去获取,然后通过js进行赋值。
状态可以通过${}形式来获取,所以对于index,获取页面的请求,你可以使用addmodel,addAttribute;但是对于提交的方法API,返回数据的方法API,是不能使用这种的。只能通过json去返回。
 
对于PUT和POST写法,只能通过下面的方式来进行提交:
 1 var data = {
 2 'queueName' : queueName,
 3 'coreNum' : coreNum,
 4 'mem' : mem,
 5 'appCount' : appCount,
 6 'aclForSubmit' : aclForSubmit
 7 };
 8 var type = "${mode}" == "add" ? "PUT" : "POST";
 9 $.ajax({
10 url : '${ctx}/v1/resourcepool/queues',
11 type : type,
12 data : JSON.stringify(data),
13 success : function(result) {
14 alert(result);
15 }
16 });

 

 
注意data需要进行json的string化处理。
 关于调试
调试RESTful真的是要各种工具齐上阵,包括firefox的html节点查看器;还有js的调试器以及Network工具用来查看网络请求情况(包括url,动作,参数,后台相应)
 

posted on 2018-03-18 21:12  下士闻道  阅读(1017)  评论(0编辑  收藏  举报

导航