使用Vaadin和Spring Roo进行敏捷应用开发

2024-01-15 08:48

本文主要是介绍使用Vaadin和Spring Roo进行敏捷应用开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用Vaadin和Spring Roo进行应用敏捷 开发

参考http://vaadin.com/book/-/page/rapid.html

 

一、要点

使用的快速应用开发工具:

(1)Spring Roo

(2)Vaadin插件 for Eclipse

所开发的应用包括:

(1)使用JPAContainer数据库绑定

(2)国际化

(3)使用Vaadin TestBench进行测试

二、概述

通过开发一个简单应用,来展示开发一个典型的实际应用需要的工作步骤:

(1)使用Roo建立业务数据模型

(2)使用JPA和JAPContainer(一个Vaadin add-on)实现数据绑定

(3)使用Spring Roo的Vaadin插件建立CRUD视图

(4)通过Eclipse的Vaadin插件定制自动生成的视图

(5)使用Vaadin的Calendar add-on

(6)通过登陆进行用户认证与授权

(7)国际化

(8)使用Vaadin的TestBench add-on进行测试

(9)将应用发布到Cloud Foundry

 

其中:Spring Roo是一个java应用的快速开发工具。它使用Spring框架、JPA和Maven生成代码,也支持通过add-ons进行扩展,例如spring roo下的Vaadin插件,该插件可以基于在Roo下定义的数据模型生成用户界面视图,这些视图可以使用Eclipse下的vaadin插件提供的可视化编辑器定制修改。

JPAContainer是一个vaadin的container,用于JPA实现与数据库之间的通讯,把一个JPAContainer与一个Vaadin的Table关联,设置为可编辑模式,马上就会得到一个CRUD组件,在table界面编辑的数据被更新到JPAVContainer中,该组件连接一种JPA实现,如EclipseLink或Hibernate,你在界面中所做的一切立即反映到后端数据库中。

通过开发一个简单应用,来展示一个完整的开发过程。该应用是一个工时报告系统,允许员工报告各个项目已经完成的工作。为了完成认证,需要一个登录界面,在用户登录界面中可以选择所使用的语言。业务任务在主界面中完成,其中使用一个典型的布局和菜单条。

三、设置开发环境

1、需要开发工具

(1)Spring Roo,与STS一起

(2)Eclipse下的Vaadin插件

(3)Spring Roo下的Vaadin插件

(4)Vaadin Calendar日历插件

(5)Vaadin TestBench测试插件

2、建立一个Spring Roo项目

3、安装Spring Roo下的Vaadin插件

插件安装之后并不是只针对这一个项目,一旦安装,所有项目都可以使用。但是,Roo shell只能在项目下进入。

在Roo shell界面中输入以下命令:


roo>pgp trust --keyId 0xBF0451C0

roo> download accept terms of use

roo> addoninstall bundle --bundleSymbolicNamecom.vaadin.spring.roo.addon

4、设置Roo的数据层

在Roo下设置基于JPA和数据库的数据模型非常简单,持久化的简单设置如下:

roo> persistencesetup --provider ECLIPSELINK --databaseHYPERSONIC_IN_MEMORY

上述命令设置持久化使用EclipseLink实现和HSQLDB内存数据库。可以使用Ctrl-Space获得可以选择的JpA实现和数据库。

当使用一个实际的数据库时,需要配置数据库链接,在下述文件中:

src/main/resources/META-INF/spring/database.properties

四、建立数据模型

Spring Roo自动创建领域模型。使用简单的命令创建实体类及其属性字段。使用前面设置的项目的持久化,创建实体类的同时也创建领域模型与底层数据库之间的JPA映射。

1、领域模型设计

工时报告系统有三个实体,项目中的员工表示为RapidUser实体,同时也是系统的用户,权限通过admin标志区分。

员工使用系统输入工作实体,表示为WorkEntry类,每个条目有开始和结束日期时间和说明。每个工作条目总是与一个项目关联,项目表示为Project类。一个项目有一个名称和是否结束的标志,该标志决定该项目不再被选择。

2、在Roo下建立数据模型

使用Roo shell建立模型对象。entity命令建立一个新的实体类,使用—class参数指定类名。波折号(~)用于指定项目包名。--testAutomatically选项用于建立实体的集成测试。在Roo shell中,总是可以使用Ctrl-Space获得帮助后自动完成命令。

roo>entity --class ~.domain.RapidUser -–testAutomatically

field命令用于建立实体的属性字段,第一个参数是字段类型,像string、boolean或date。用—fieldName指定字段名称,用—notNull指定字段非空,对于string类型,还可以使用可选的参数:--sizeMin和—sizeMax,用于指定字段的最小最大长度。

roo>fieldstring --fieldName username --notNull --sizeMin 2

前面说明的项目的各个数据模型,使用下述命令创建实体类:

entity --class ~.domain.RapidUser --testAutomatically

field string --fieldName username --notNull --sizeMin 2

field string --fieldName password --notNull --sizeMin 4

field boolean --fieldName admin --primitive

 

entity --class ~.domain.Project --testAutomatically

field string --fieldName name --notNull --sizeMin 2 --sizeMax255

field boolean --fieldName enabled --primitive

 

entity --class ~.domain.WorkEntry --testAutomatically

field string --fieldName comment --sizeMax 255

field reference --fieldName project --type~.domain.Project --notNull

field reference --fieldName employee --type~.domain.RapidUser --notNull

field date --fieldName startTime --type java.util.Date--notNull

field date --fieldName endTime--type java.util.Date –notNull

reference字段类型用于指定该字段引用的其他实体类,使用—type指定具体引用的实体类名。

由于在创建领域对象模型时指定了—testAutomatically参数,Roo自动生成了相关的测试,为了检验领域模型,使用下述命令进行测试:

roo>performtests

五、创建Vaadin应用和CRUD界面

Spring Roo本质上是一个代码生成器。如前所述,在建立领域模型时生成了一大堆JAP实体代码。也可以使用Roo生成围绕领域模型的简单用户界面。

默认情况下,Roo使用JSP页面建立CRUD视图。这里有所不同的是,使用Roo的Vaadin插件生成基于Vaadin的服务器端RIA用户界面。

1、建立应用框架

首先,使用vaadin setup命令建立基本的应用框架,稍后在其中建立用户界面。在Roo shell中输入下述命令:

vaadin setup --applicationPackage ~.web--baseName RapidWorkHours --themeName rapid --useJpaContainer true

该命令建立了开发过程中所有需要的内容:

(1)一个“web”包,所有与vaadin相关的代码放在这里

(2)一个应用类名

(3)一个web.xml文件,用于配置针对servlet容器的vaadin应用

(4)一个外观主题theme

2、生成CRUD视图

下面,生成实际的CRUD界面,在Roo shell中使用如下命令:

vaadin generate all --package ~.web.ui--visuallyComposable true

该命令针对所有的领域模型生成CRUD界面,代码放在web.ui包中。

--visuallyComposabe参数指示Roo的vaadin插件生成可以在eclipse的vaadin插件中的vaadin可视编辑器中修改的代码结构。如果不指定该参数,所生成的代码略有不同,适合于高级vaadin用户手工修改代码。

在添加了新的领域对象后,需要再次使用该命令生成新领域对象的CRUD界面代码。

3、发布到开发服务器

至此,我们已经拥有了一个可以运行的vaadin应用系统。很自然地我们想看看实际的运行效果。

在STS IDE中,选择Run on Server,可以使用任何servlet容器应用服务器。

如果感觉Maven世界比较合适,项目也可以针对测试进行发布,例如:jetty:run。Jetty插件在生成项目时自动按装。

六、在Roo项目中使用Vaadin扩展

复杂的vaadin应用通常需要在vaadin核心的基础上使用某些扩展。在这里,我们需要Calendar和JPAContainer两个Vaadin的扩展插件。

Roo的Vaadin插件支持从vaadin目录中安装vaadin扩展插件,并且编译包括的任何widget。

(1)安装vaadin的Calendar日历扩展插件

(2)编译相关的widget

(3)配置发布装配

Roo的vaadin插件自动按装JPAContainer插件,但是Calendar日历插件需要手工安装。

1、安装Vaadin扩展插件

在Roo shell中:

roo> vaadin addon install --artifactId vaadin-calendar

在键入命令是,使用Ctrl-Space可以获得帮助和自动完成命令,如下图:

2、编译widget

有些vaadin扩展插件包括定制的widget,例如Calendar日历插件,需要编译这些widget。在Roo shell中使用下述命令:

roo>vaadin widgetsetcreate

该命令执行需要相当长的时间,特别是在首次执行时需要下载maven的以来库。大概需要20到60秒的时间。

编译后的widget set放在target/rapid-0.1.0-SNAPSHOT/VAADIN/widgetsets/com.vaadin.rapid.web.RapidWidgetset目录下,并且在web.xml中引用。

如果在以后又增加了vaadin的扩展插件,使用vaadin widgetset update命令。

3、配置发布装配

widget set在target/rapid-0.1.0.BUILD-SNAPSHOT目录下编译,默认没有包括部署路径。

(1)打开项目属性

(2)选择部署装配

(3)点击Add

(4)选择文件夹

(5)选择target/rapid-0.1.0.BUILD-SNAPSHOT目录

(6)点击完成

七、定制用户界面

对于基本应用,Roo生成的实体界面已经很好了。在某些情况下,修改form或者改变table的可见属性来满足最终用户的要求。

1、 修改Roo生成的实体form

在可视化编辑器中修改生成的实体form,例如:WorkEntryForm.java。在文件名上右键打开文件,进入设计视图,修改界面。

2、 在填写工作条目界面中建立日历视图

在这里,我们构建一个基于vaadin Calendar日历插件的WorkEntry实体的非传统界面。以图形化的日历用户界面,最终用户填写工作条目。在一周期间,用户可以得到一个他做了什么的快速概述,它也很容易发现缺少的条目。用户还可以选择和可视化修改日历的时间范围,从而加快了日常工作。

在可视化编辑器中开始绘制界面:

(1)选择file-new-vaadin-composite

(2)填写适当的包名、类名,例如:~web.ui和CalendarView。

(3)进入可视化设计界面

这篇关于使用Vaadin和Spring Roo进行敏捷应用开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/608311

相关文章

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Tomcat版本与Java版本的关系及说明

《Tomcat版本与Java版本的关系及说明》:本文主要介绍Tomcat版本与Java版本的关系及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat版本与Java版本的关系Tomcat历史版本对应的Java版本Tomcat支持哪些版本的pythonJ

springboot security验证码的登录实例

《springbootsecurity验证码的登录实例》:本文主要介绍springbootsecurity验证码的登录实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录前言代码示例引入依赖定义验证码生成器定义获取验证码及认证接口测试获取验证码登录总结前言在spring

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s