博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MyEclipse for Spring 10.0: GWT 2.1 and Spring Scaffolding
阅读量:6402 次
发布时间:2019-06-23

本文共 17742 字,大约阅读时间需要 59 分钟。

http://www.myeclipseide.com/documentation/quickstarts/ME4STutorialScaffoldingGWT/scaffoldinggwtarticle.html#N1031B

MyEclipse Logo

MyEclipse for Spring 10.0: GWT 2.1 and Spring Scaffolding

Scaffolding a Google Web Toolkit (GWT) 2.1 and Spring CRUD application in minutes

Niel Eyde

Skyway Software, Inc.


Table of Contents

1. Introduction

One of the goals of MyEclipse for Spring (ME4S) is to help developers write less code from scratch and use code generation more broadly, and ME4S offers the richest set of code generation options available anywhere. ME4S can generate software components for Spring MVC, Spring Web Flow, Spring Security, REST, JAX-WS, Adobe Flex, Google Web Toolkit (GWT), JPA, DAO and JSF 2.0/Primefaces. As an alternative to writing software components from scratch, ME4S helps developers generate software components that are specific to their project. In many cases the software components may be used as-is, or they may be used as a starting point for further development. Furthermore the developer can edit the ME4S templates to further customize how the software components are generated.

Scaffolding refers to the superset of ME4S's broad code generation functions, from generating a specific set of requested software components to generating fully implemented ready-to-run applications. Besides the obvious benefits of reducing application development effort and sparing developers from some of the chores of development, scaffolding is also frequently used for rapidly developing functional prototypes, learning new technologies, and application modernization projects. The ability to quickly generate a full application is very beneficial to prototyping because you can iterate on a domain model and regenerate a functional prototype in minutes. The prototype can be used with business analysts as a tool for elaborating requirements and as the starting point for development. ME4S helps many developers learn new technologies by generating contextual reference projects, which are personalized projects that are based on their own data model. This is a considerably better approach than hunting for sample projects that are often incomplete, don't follow modern best practices, and are based on trivial data models. ME4S can also be used to jumpstart an application modernization effort by leveraging application artifacts from the current system for generating a significant portion of the application components for the new system.

The objective of this tutorial is to walk you through the generation of software components for Google Web Toolkit (GWT), a software development kit for building rich internet applications that run inside a html/javascript browser. The goals of GWT are to simplify the development of rich AJAX applications by using Java to implement the applications, which ultimately is compiled into javascript applications. In addition to generating the GWT software components, this tutorial will also generate the software components for the service, domain, and data access layers. This will result in a fully implemented ready-to-run GWT application that can be immediately used for validating and testing the generated GWT components, and it will also serve a reference implementation for how the generated GWT components integrate with the other components of an application.

The MyEclipse for Spring scaffolding capabilities support two GWT recipes.

  • GWT 2.0 - based on best practices prescribed in ’s and GWT reference implementations, including Model-View-Presenter, UI Binder and GWT RPC

  • GWT 2.1+ - based on best practices prescribed in ’s and GWT reference implementations, including Places & Activities (Model-View-Presenter enhancements), UI Binder, and Request Factory (alternative to GWT RPC)

This tutorial will focus on the GWT 2.1 implementation.

Figure 1. Application Layers - GWT 2.1


Application Architecture:

  • Web Layer - GWT 2.1

  • Service Layer - Spring (@Service)

  • Domain Layer - JPA (@Entity)

  • Data Access Layer - Spring (@Repository)

MyEclipse for Spring uses the Create-Read-Update-Delete (CRUD) application pattern for generating applications that allows the end-user to manage application data. While CRUD isn't the only application pattern, it's a fairly typical application pattern. While not all web applications are satisfied solely by the CRUD application pattern, developers find that the resulting generated application artifacts lend themselves to being easily re-used, customized and extended. CRUD applications are tied to an application domain model that is used as the input into the scaffolding engine. The domain model can exist in many forms, and the MyEclipse for Spring scaffolding functionality supports the use of Java beans, JPA entities, or database tables as inputs.

2. Goal

This tutorial is going to walk you through producing a ready-to-run GWT 2.1 and Spring 3.0 application that implements the CRUD application pattern for a domain model.

  • Domain model: CUSTOMERS table from the MyEclipse Derby database.

  • Target Container: MyEclipse Tomcat

  • Target Database: MyEclipse Derby

MyEclipse for Spring will be used to generate the entire JSF 2.0, Primefaces and Spring 3.0 application within a matter of minutes that includes:

  • A JPA entity corresponding to domain model (CUSTOMERS)

  • A DAO for managing the JPA entity,

  • Finder methods (JPA named queries) in the DAO based on domain model fields,

  • A Service with fully implemented CRUD operations for managing domain model,

  • GWT 2.1 UI components using UIBinder

  • GWT Activities and Places classes to support GWT UI flow

  • GWT RequestFactory classes for integrating with remote data services

  • Service and data access adapters for GWT

  • CSS for UI styling

  • JUnits for every Service and Controller,

  • SpringSource certified code and configuration files,

  • Generated code that follows Spring Recipes,

3. Prerequisites

The prerequisites needed to complete this tutorial are:

  • Download

4. Install Google Eclipse Plugins

If you're going to do GWT development in MyEclipse (or Eclipse), then you will need the Google Eclipse Plugins (GEP). GEP includes the GWT SDK and some tools for GWT development. Among other things GEP will be used to compile the GWT application that is generated by MyEclipse for Spring.

GEP is available in the Pulse catalog, and it can be easily added to your installation using the MyEclipse Configuration Center.

  1. Open the MyEclipse Configuration Center from the Help-->MyEclipse Configuration Center menu

    Figure 3. MyEclipse Configuration Center


  2. Switch to the Software tab. Search for "Google" to find the Google Plugin for Eclipse software in the Pulse catalog. Follow the standard process for adding software from the Pulse catalog, right-click on the entry and select Add to Profile.

    Figure 4. Add to Profile: Google Plugin for Eclipse


  3. Verify the the Google Plugin for Eclipse is shown as a pending software update, and click the Apply Change button.

    Figure 5. Apply change to profile


    When the installation is complete, you will be prompted to restart MyEclipse for Spring.

5. Create Web Project

  1. Create a MyEclipse Web Project (or Eclipse Dynamic Web Project) called CustomersGwtApp.

    Figure 6. New Web Project


6. Configure web project for GWT

Before we start generating the GWT application, the project requires some basic GWT setup using some of the tools provided by the Google Eclipse Plugin.

  1. To setup the project for GWT, right-click on the CustomersGwtApp and select Google-->Web Toolkit Settings...

    Figure 7. Web Toolkit Settings


  2. The first thing to do is to specify that this project will use GWT. From the Google-->Web Toolkit group, check the Use Google Web Toolkit checkbox.

    Figure 8. Use Google Web Toolkit


  3. The next step is to specify that the current project has a WAR directory. From the Google-->Web Application group, check the This project has a WAR directory checkbox. The WAR directory should be automatically configured. If not, specify the WAR directory. The Launch and deploy from this directory checkbox should also be checked.

    Figure 9. Web Application - WAR directory


7. Scaffold from Database Tables

It's now time to generate all the software components and configuration files required to implement the CRUD application.

  1. Right-click on the CustomersGwtApp project, and choose MyEclipse > Scaffold Spring CRUD application...

    Figure 10. Scaffolding Wizard


  2. The first step is to select the type of artifact you want to scaffold from. As mentioned in the there are a variety of possible inputs into scaffolding. For this tutorial we're going to scaffold from a pre-existing database table that comes with the MyEclipse Derby database. Choose the Database Schema option on the Select Artifact Type(s) panel. Click the Next button.

    Figure 11. Select Artifact Type(s)


  3. The next step is to select the DB connection for accessing the MyEclipse Derby database. This panel will show you all configured DB connections in the MyEclipse workspace, and you must select the MyEclipse Derby connection, which is a preconfigured DB connection in MyEclipse. Click the Next button.

    Figure 12. Specify Persistence Connection Properties


  4. The next step is to specify which database table(s) to scaffold an application from. Start by selecting the desired schema, and the select the database table(s) that should be used for scaffolding. When the CLASSICCARS schema is selected, the tables list will be populated with a list of tables. The CUSTOMER table should be added to the scaffolding list. Click the Next button.

    Figure 13. Select Database Tables


  5. The next panel will prompt you to select parent objects. This panel also lets you override the derived name of the Java Object that will be created from the database table. Since we're only scaffolding from a single database table, the Customer Java object must be the parent. For GWT scaffolding ALL tables must be selected as parent objects. This is because the GWT client assumes that the CRUD services have been generated for all tables. Making an object a parent causes the back-end services to be generated for that table. For this tutorial there's nothing that needs to be changed on this panel so just click the Next button.

    Figure 14. Database Scaffolding Options


  6. The next step is to specify which layers of the application should be scaffolded and which package names should be used for each layer. All the layers are enabled by default. Enter org.customerapp as the base package. The package names for the different layers will be automatically derived from the base package. A sub-package (i.e. web, service, DAO, and domain) will be added to the end of the base package.

    Figure 15. Application Layers and Packages


  7. The next step is to specify which web clients should be generated for the web layer. As you can see, there are a variety of different web clients available, including Spring MVC, Spring Web Flow, JavaServer Faces (JSF), Adobe Flex, GWT, and iPhone. This tutorial is focused on GWT, so click on the Generate checkbox for Google Web Toolkit.

    Figure 16. Select Web Client


  8. The next step is to select the GWT recipe that should be used. As explained in the , MyEclipse for Spring supports two different GWT scaffolding recipes. For this tutorial we'll be generating using the GWT 2.1 recipe which encompasses the latest GWT technology and best practices from the Google GWT team.

    Figure 17. Select GWT Options


  9. The next step is an optional step to specify the REST scaffolding options. Since REST scaffolding is beyond the scope of this tutorial, we'll just skip to the next step of the wizard.

    Figure 18. REST options


  10. The next step is in an optional step to customize the UI. For this tutorial we'll go with the defaults.

    Figure 19. Customize UI


  11. The next step is to specify where the application (source code, configuration files, JSP, etc...) should be generated to in the current project and a few additional scaffolding options. For this panel the defaults are fine. Click the Next button.

    Figure 20. Select Target Folders


  12. The final configuration step is to specify the libraries that should be added to the current project, how they should be added (classpath containers or copied into project), and the version of Spring to use. For this panel the defaults are fine. Click the Next button.

    Figure 21. Runtime Dependencies


  13. The final panel will give you a summary of everything that will be generated for you. Click the Finish button to scaffold the application from the information you provided in the wizard.

    Figure 22. Summary


That's it. Once the wizard is complete you have a generrated a GWT 2.1 and Spring application that implements the CRUD application pattern for the domain model (CUSTOMERS DB table).

8. GWT Compile

The GWT code that was generated by MyEclipse for Spring needs to be compiled into Javascript using the GWT SDK

  1. Right-click on the CustomersGwtApp project, and select Google-->GWT Compile

    Figure 23. Google-->GWT Compile


  2. The GWT Compile window should be preset with valid compile options. To initiate the compile, click the Compile button.

    Figure 24. GWT Compile


  3. The compile will take approximately one minute to complete. You can monitor the progress using the Eclipse Console view. When the compile is complete, you will see a "Compilation succeeded " message in the console.

 

9. Deploy the App

The next step is to see the application in operation by deploying it to Tomcat. The running application can be used for validating the generated GWT components and observing the integration with the other components of the application

  1. To deploy the application, right-click on the CustomersGwtApp project and select Run As --> MyEclipse Server Application.

    Figure 25. Run As --> MyEclipse Server Application


  2. MyEclipse Tomcat will start up. The first page will be a dashboard for accessing all scaffolded web clients. Since this tutorial only scaffolded a single database table for GWT, the only option under Google Web Toolkit is View GWT Scaffolding. Click on it to see the generated GWT application in operation.

    Figure 26. Dashboard


  3. The GWT application can be used to (a) list all customers, (b) view customer details, (c) edit customer details, (d) delete customers and (e) add new customers. The following screen shots show some of the views.

    Figure 27. CustomersGwtApp - List


    Figure 28. CustomersGwtApp - Edit Details


10. What's generated?

The scaffolded application is compromised of many integrated software components, and the following diagrams provide an overview of which software components were generated and where they can be found in the project. Understanding what gets generated (and where) will help you find the individual or set of software components that you want use in your own developent projects.

Figure 29. What's generated with GWT Scaffolding


The GWT 2.1 scaffolding blueprint provides a snapshot of what gets generated during scaffolding. The GWT blueprint and the blueprints for the other ME4S code generations capabilities are covered in more detail in the MyEclipse for Spring reference guide. (see ).

Figure 30. GWT 2.1 Scaffolding Blueprint


11. Conclusion

Now that you have a running GWT application, you may want re-run the tutorial and scaffold different web clients, including Spring MVC, Spring Web Flow, Adobe Flex, JavaServer Faces 2.0, and iPhone.

You may also want to try the Spring Annotator, JAX-WS Annotator and JPA annotator tutorials which are available in the Eclipse help system and online (see ).

What was your experience with this tutorial? Share your experience with us by completing a .

12. Additional Developer Resources

Thank you for you interest in MyEclipse for Spring. If you are interested in learning more, the following developer resources are available:

  • Reference - Eclipse Help (MyEclipse for Spring 10.0 --> MyEclipse for Spring Reference) or (online)

  • Tutorials - Eclipse Help (MyEclipse for Spring 10.0 --> Tutorials) or (online)

  • Screencasts - (online)

  • Support Forums - (online)

  • Blog - (online)

转载地址:http://bnnea.baihongyu.com/

你可能感兴趣的文章
在Angular中操作DOM:意料之外的结果及优化技术
查看>>
编写一个webpack的loader(1)
查看>>
《金三银四面试系列》— jvm与性能优化
查看>>
iOS K线三方库 - ZXKLine
查看>>
必须明白的浏览器渲染机制
查看>>
Linux 内核101:异步IO
查看>>
UINavigationBar 的详解 (基于 API)
查看>>
太坊智能合约开发第一篇:IDE对solidity语法的支持
查看>>
web-audio-api可视化音乐播放器,实现暂停切换歌曲功能,粉色系专场~
查看>>
Fiddler抓包和修改WebSocket数据,支持wss
查看>>
Python知识点总结篇(五)
查看>>
戴老师的学习验收(一,二)
查看>>
站在巨人的肩膀上:原生JS实现基于Promise/a+规范的Promise(篇一)
查看>>
MySQL数据库优化分析
查看>>
jQuery源码解析之width()
查看>>
【从蛋壳到满天飞】JS 数据结构解析和算法实现-红黑树(二)
查看>>
总结Spring Cloud各个组件配套使用
查看>>
highcharts中漏斗图和金字塔图的对比
查看>>
数据结构之「哈希表」
查看>>
小白学Java之Java简介及应用场景
查看>>