前两篇讲解了ROO的一些基本知识,这篇来个实例看看整个的开发过程。

首先进入roo命令行,执行如下的脚本[建工程和必要的设置]

project --topLevelPackage lesson

persistence setup --provider HIBERNATE --database HYPERSONIC_IN_MEMORY

web mvc setup

security setup

entity --class ~.domain.Pet

field string --fieldName name

json add --class ~.domain.Pet

controller scaffold --class ~.web.PetController --entity ~.domain.Pet

建立一个起始框架

使用mvn tomcat:run可以在浏览器 查看默认的界面,已经可以进行增删改了

同时JSON服务也可以访问

加入一个记录

然后模仿JSON的访问

$ curl -i -H "Accept: application/json" http://localhost:8080/lesson/pets

HTTP/1.1 200 OK

Server: Apache-Coyote/1.1

Content-Type: application/text;charset=utf-8

Content-Length: 35

Date: Wed, 12 Oct 2011 06:03:15 GMT

[{"id":1,"name":"dog","version":0}]

增加的步骤:

添加jquery资源

lesson\src\main\webapp\scripts 放入jquery和easyui库和css等

配置apache tiles的布局

lesson\src\main\webapp\WEB-INF\layouts 放入jdefault.jspx ,layouts.xml修改

实现jquery等母板资源的加载

lesson\src\main\webapp\WEB-INF\tags\util 放入jload-scripts.tagx

具体的部分母板页实现页面

lesson\src\main\webapp\WEB-INF\views 放入

jheader.jspx

jindex.jspx

jfooter.jspx

work.jspx

同时修改views.xml

导航

webmvc-config.xml 加入<mvc:view-controller path="/main" view-name="main"/>

<mvc:view-controller path="/work" view-name="work"/>

其中的登录逻辑使用Spring Security,并修改为json服务的步骤:

登录服务LoginController

@RequestMapping(method = RequestMethod.POST)

@ResponseBody

public ResponseEntity<String> login(@RequestParam("j_username") String username,

@RequestParam("j_password") String password) {

LoginStatus s = loginService.login(username, password);

return new ResponseEntity<String>(s.toJson(), headers, HttpStatus.OK);

}

客户端界面

$.ajax({url: "${req}/api/login",

type: "POST",

dataType:"json",

beforeSend: function(xhr) {

xhr.withCredentials = true;

},

data: $("#loginForm").serialize(),

success: loginSucess,

error: loginFailed

});

详细代码参考:

https://skydrive.live.com/?cid=56b433ad3d1871e3&sc=documents&uc=1&id=56B433AD3D1871E3%21274#