OFBIz之旅[结构]
注意:
1
,持久层,在
OFBIZ
中的定义,就是
Model
。
DAO
被划分到业务层中。
OFBIz
已经改名为
OpenTaps
项目发展了。其自身的工作流引擎也已经停止发展。现在改用内嵌式的
shark
工作流引擎作为自己的工作流引擎。而且,实际上并没有使用
shark
制作任何工作流。
Opentaps
的宗旨,还是使用一系列自创的开源技术,开发大规模的企业级应用程序。它的目标,不是工作流,也不是
appfuse
这样一个整合其他开源技术的演示性的网站,而是一个综合的、企业级的电子商务网站。
First, go into your OFBiz directory and take a look inside:
首先,进入
Ofbiz
目录:
[sichen@localhost ofbiz_5010]$ ls -l
total 88
drwxrwxr-x 15 sichen sichen 4096 May 20 07:54 applications
drwxrwxr-x 8 sichen sichen 4096 May 20 07:59 base
-rw-rw-r-- 1 sichen sichen 10173 May 20 07:58 build.xml
drwxrwxr-x 4 sichen sichen 4096 May 20 07:59 data
drwxrwxr-x 24 sichen sichen 4096 May 20 07:58 framework
drwxrwxr-x 3 sichen sichen 4096 May 20 07:52 hot-deploy
-rwxrwxr-x 1 sichen sichen 309 May 20 07:58 ij.ofbiz
drwxrwxr-x 2 sichen sichen 4096 May 20 08:08 logs
-rw-rw-r-- 1 sichen sichen 21167 May 20 08:07 ofbiz.jar
-rw-rw-r-- 1 sichen sichen 2869 May 20 07:58 rc.ofbiz
drwxrwxr-x 6 sichen sichen 4096 May 20 07:55 specialized
-rw-rw-r-- 1 sichen sichen 265 May 20 07:58 startofbiz.bat
-rwxrw-r-- 1 sichen sichen 790 May 20 07:58 startofbiz.sh
-rwxrw-r-- 1 sichen sichen 325 May 20 07:58 stopofbiz.sh
drwxrwxr-x 12 sichen sichen 4096 May 20 07:52 website
Things to note here:
1
,
ofbiz-component.xml
每个组件都有这样一个文件。它们用于定位该组件的
jar
包和
entity
实体等配置文件。
- OFBiz is built around a components-based architecture, which means each application is inside a component. This allows outside or custom applications to be added easily.
OFBIZ
采用了基于组件的架构。这就是说,每一个应用程序在一个组件内。这允许外部的和定制化的应用程序能够很容易的被包含近来。
- The applications/ directory holds the applications components, such as order manager and ecommerce store.
Applications
目录,包含了
OFBIz
核心的应用程序组件,如订单管理,电子商务存储等。
component-load.xml
文件配置需要载入哪几个应用程序组件。
这里的每一个组件,都是一个基于
OFBIZ
构建的
Web
应用程序。
- The framework/ directory holds the components for the OFBiz framework, such as the entity engine, and service engine.
Framework
框架目录,包含
OFBIZ
框架的组件,例如实体引擎和服务引擎。
这是
OFBIZ
框架的核心,其他应用程序都是基于它来构建的。
component-load.xml
文件配置需要载入哪几个框架组件。
- specialized/ contains some other applications which are not part of the OFBiz core.
Specialized
专门目录,包含一些其他的应用程序,不是
OFBIZ
核心的一部分。
- hot-deploy/ is another directory where components can be dropped in and automatically loaded.
hot-deploy
热部署目录,是另一个目录。它的组件能够被删除和自动载入。
金融和
CRM2
个项目在这里。
这里没有
component-load.xml
这个文件。
本目录中所有的组件,都会在
framework
和
application
目录下的组件被导入之后导入。
- base/ contains code for starting up and configuring ofbiz.
base
目录,包含启动和配置
ofbiz
的代码。
- logs/ contains log files. On Unix/Linux, ofbiz runs as a background process, and all console output is in logs/console.log
logs
日志目录,包含日志文件。
- website/ is the contents of ofbiz.org.
website
网站目录,是
ofbiz.org
网站的内容。
另外,
data
目录下是几个内嵌式的数据库。
Now let's go inside framework/ and take a look:
现在,让我们进入
framework
目录看一看:
[sichen@localhost ofbiz_5010]$ cd framework/
[sichen@localhost framework]$ ls -l
total 88
drwxrwxr-x 7 sichen sichen 4096 May 20 08:00 appserver
drwxrwxr-x 8 sichen sichen 4096 May 20 07:59 catalina
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 common
-rw-rw-r-- 1 sichen sichen 2988 May 20 07:58 component-load.xml
drwxrwxr-x 6 sichen sichen 4096 May 20 07:59 datafile
drwxrwxr-x 10 sichen sichen 4096 May 20 07:59 entity
drwxrwxr-x 9 sichen sichen 4096 May 20 07:59 entityext
drwxrwxr-x 12 sichen sichen 4096 May 20 07:55 example
drwxrwxr-x 6 sichen sichen 4096 May 20 08:00 guiapp
drwxrwxr-x 4 sichen sichen 4096 May 20 07:56 images
drwxrwxr-x 6 sichen sichen 4096 May 20 07:59 jetty
drwxrwxr-x 7 sichen sichen 4096 May 20 07:59 jotm
drwxrwxr-x 6 sichen sichen 4096 May 20 07:59 minerva
drwxrwxr-x 7 sichen sichen 4096 May 20 08:00 minilang
drwxrwxr-x 9 sichen sichen 4096 May 20 07:59 security
drwxrwxr-x 11 sichen sichen 4096 May 20 07:59 service
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 shark
drwxrwxr-x 10 sichen sichen 4096 May 20 08:00 tests
drwxrwxr-x 9 sichen sichen 4096 May 20 08:00 webapp
drwxrwxr-x 9 sichen sichen 4096 May 20 08:00 webtools
drwxrwxr-x 6 sichen sichen 4096 May 20 08:00 widget
drwxrwxr-x 9 sichen sichen 4096 May 20 08:00 workflow
These are the components of the OFBiz framework, which is used to develop the OFBiz applications.
这些是用来开发
OFBIZ
应用程序的
OFBIZ
框架组件。
component-load.xml controls which of the components in the current directory are loaded.
component-load.xml
文件控制现在哪些组件被使用。
Now go back and take a look at the applications themselves:
[sichen@localhost framework]$ cd ..
[sichen@localhost ofbiz_5010]$ cd applications/
[sichen@localhost applications]$ ls -l
total 52
drwxrwxr-x 13 sichen sichen 4096 May 20 08:00 accounting
-rw-rw-r-- 1 sichen sichen 2425 May 20 07:54 component-load.xml
drwxrwxr-x 15 sichen sichen 4096 May 20 08:00 content
drwxrwxr-x 11 sichen sichen 4096 May 20 08:00 ecommerce
drwxrwxr-x 5 sichen sichen 4096 May 20 07:53 humanres
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 manufacturing
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 marketing
drwxrwxr-x 13 sichen sichen 4096 May 20 08:00 order
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 party
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 pos
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 product
drwxrwxr-x 10 sichen sichen 4096 May 20 08:00 securityext
drwxrwxr-x 12 sichen sichen 4096 May 20 08:00 workeffort
These are the OFBiz applications themselves. Each application is self-contained with its own data model definitions, business logic, and presentation (web or Swing) tier, although applications may reuse each others' business logic and thus depend on each other.
这些是
OFBIz
应用程序本身。每一个应用程序是自包含的。它们自己有自己的数据定义,业务层和表现层(
Web
或
Swing
)。虽然应用程序之间可以重用业务逻辑(其数据层、数据库是一样的),因而是互相依赖的。
Now let's go inside an application and see what it looks like:
现在,让我们进入一个应用程序,看看里面有什么:
[sichen@localhost applications]$ cd product/
[sichen@localhost product]$ ls -l
total 52
drwxrwxr-x 4 sichen sichen 4096 May 20 08:08 build
-rw-rw-r-- 1 sichen sichen 6413 May 20 07:53 build.xml
drwxrwxr-x 3 sichen sichen 4096 May 20 07:53 config
drwxrwxr-x 3 sichen sichen 4096 May 20 07:53 data
drwxrwxr-x 3 sichen sichen 4096 May 20 07:53 entitydef
-rw-rw-r-- 1 sichen sichen 4202 May 20 07:53 ofbiz-component.xml
drwxrwxr-x 4 sichen sichen 4096 May 20 07:53 script
drwxrwxr-x 3 sichen sichen 4096 May 20 07:53 servicedef
drwxrwxr-x 4 sichen sichen 4096 May 20 07:53 src
drwxrwxr-x 5 sichen sichen 4096 May 20 07:53 webapp
drwxrwxr-x 5 sichen sichen 4096 May 20 07:53 widget
Here is what you are seeing:
- build/ is where the compiled Java code and any libraries for this application go.
Build
目录是已编译的
java
代码和任何
Java
库。它们能够使这个应用程序运行。(但是不能够仅仅靠它们运行。可以仅靠
webapp
目录下的一个或者多个
web
应用程序运行)
- build.xml tells ant how to build this application. It is like a Makefile.
build.xml
文件是
ant
文件,用于测试和构建这个应用程序。
- config/ is for configuration data, such as internationalization (i18n) UI labels in various languages.
Config
目录包含配置文件,例如多语言下的国际化
UI
标签的配置文件。
- data/ is where the seed and demo data, in XML format, are located.
Data
目录包含种籽和演示数据,
xml
格式。
- entitydef/ is where the data model definitions of this application are.
Entitydef
目录,包含这个应用程序的数据模型定义。
- script/ is where scripts for business logic are. Scripts can be written in beanshell, OFBiz minilang, Jython, etc.
script
脚本目录,包含业务逻辑的脚本文件。
- servicedef/ is where the services, which are small, granular pieces of business logic (similar to functions or methods), are defined.
Servicedef
目录,包含
services
服务,它们是细粒度的业务逻辑(类似于方法或函数,它们就是
DAO
方法)。
- src/ is where Java classes for implementing business logic are.
Src
源文件目录,包含实现业务逻辑的
Java
类文件(粗粒度的业务逻辑)。
- webapp/ is where the web interface, or front end, applications are. An OFBiz application can have more than one webapp.
Webapp
目录,是
web
接口,是应用程序的前端。一个
OFBIZ
应用程序能有多个
webapp
应用程序。
- ofbiz-component.xml defines this application by specifying where its data model, business logic, seed data, and web applications are located.
ofbiz-component.xml
文件定义这个应用程序指定的数据模型,业务逻辑,种籽数据和
web
应用程序的定位。包括部署
web
应用在哪里等等。
A look inside the entitydef/ and servicedef/ directories will show the XML files used to define the data model and business logic, respectively:
看一下
entitydef
目录和
servicedef
目录,它将显示被用来定义数据模型文件和业务逻辑(
DAO
)的
xml
文件。
[si@localhost product]$ ls -l entitydef/
total 264
-rw-rw-r-- 1 si si 3094 May 27 08:00 eecas.xml
-rw-rw-r-- 1 si si 16862 May 27 08:00 entitygroup.xml
-rw-rw-r-- 1 si si 62923 May 27 08:00 entitymodel_shipment.xml
-rw-rw-r-- 1 si si 171582 May 27 08:00 entitymodel.xml
[si@localhost product]$ ls -l servicedef/
total 252
-rw-rw-r-- 1 si si 1836 May 27 08:00 groups_shipment.xml
-rw-rw-r-- 1 si si 5217 May 27 08:00 secas_shipment.xml
-rw-rw-r-- 1 si si 3897 May 27 08:00 secas.xml
-rw-rw-r-- 1 si si 42967 May 27 08:00 services_facility.xml
-rw-rw-r-- 1 si si 15516 May 27 08:00 services_feature.xml
-rw-rw-r-- 1 si si 9261 May 27 08:00 services_maint.xml
-rw-rw-r-- 1 si si 9411 May 27 08:00 services_picklist.xml
-rw-rw-r-- 1 si si 19216 May 27 08:00 services_pricepromo.xml
-rw-rw-r-- 1 si si 3374 May 27 08:00 services_shipment_ups.xml
-rw-rw-r-- 1 si si 5844 May 27 08:00 services_shipment_usps.xml
-rw-rw-r-- 1 si si 29717 May 27 08:00 services_shipment.xml
-rw-rw-r-- 1 si si 16205 May 27 08:00 services_store.xml
-rw-rw-r-- 1 si si 9817 May 27 08:00 services_view.xml
-rw-rw-r-- 1 si si 56540 May 27 08:00 services.xml
The webapp/ directory holds the web front end applications. A look inside shows that this application actually has two web applications, catalog and facility:
[si@localhost product]$ ls -l webapp/
total 8
drwxrwxr-x 18 si si 4096 May 27 08:00 catalog
drwxrwxr-x 13 si si 4096 May 27 08:00 facility
catalog/ is the OFBiz Catalog Manager, used to manage product information. facility/ is the OFBiz Facility Manager, used to manage warehouses and inventory.
Catelog
目录是
OFBIZ
的目录管理器,用来管理产品信息。
Facility
设施目录,是
OFBIZ
设施管理器,用来管理仓库和存货。
In most dynamic web pages, there are some page elements, such as page headers, navigation bars, or shopping cart contents, that are repeated on many pages. When a visitor requests the page, the page will usually do some preprocessing, such as retrieving data from a database, and then present it to the user on a display page. In PHP, this is usually done by a SQL query first and then HTML code which presents the results of the query.
在大多数动态
Web
页面中,
With OFBiz, pages are divided into smaller pieces which are re-combined to create the final product. Thus, many pages can share common elements such as page headers, sidebars, and navigation bars. This is called the "decorator pattern." There is a further separation of the activities of a page into "actions," such as getting data from a database, and "presentation," the display of that data to the visitor.
装饰者模式
----
页面被分成很多小片,然后重新组合成最终的产品。
有一个更进一步动态页面的分离技术,“
action
”:例如,从数据库得到数据,并且在表现层把数据显示给参观者。
The "actions" in OFBiz are written in beanshell scripts, while the "presentation" is written in Freemarker template pages. Beanshell (.bsh) is a scripted version of Java, while Freemarker (.ftl) is a templating language that is used in OFBiz to create HTML or XSL:FO pages.
So here are the contents immediately inside a web application. The sub-directories hold the pieces of Freemarker pages:
[si@localhost product]$ ls -l webapp/catalog/
total 80
drwxrwxr-x 3 si si 4096 May 27 08:00 catalog
drwxrwxr-x 3 si si 4096 May 27 08:00 category
-rw-rw-r-- 1 si si 1866 May 27 08:00 ChooseTopCategory.ftl
drwxrwxr-x 3 si si 4096 May 27 08:00 config
drwxrwxr-x 3 si si 4096 May 27 08:00 error
-rw-rw-r-- 1 si si 1552 May 27 08:00 FastLoadCache.ftl
drwxrwxr-x 3 si si 4096 May 27 08:00 feature
drwxrwxr-x 3 si si 4096 May 27 08:00 find
drwxrwxr-x 3 si si 4096 May 27 08:00 includes
-rw-rw-r-- 1 si si 44 May 27 08:00 index.jsp
drwxrwxr-x 3 si si 4096 May 27 08:00 lookup
-rw-rw-r-- 1 si si 4575 May 27 08:00 main.ftl
drwxrwxr-x 3 si si 4096 May 27 08:00 price
drwxrwxr-x 3 si si 4096 May 27 08:00 product
drwxrwxr-x 3 si si 4096 May 27 08:00 promo
drwxrwxr-x 3 si si 4096 May 27 08:00 reviews
drwxrwxr-x 3 si si 4096 May 27 08:00 store
drwxrwxr-x 3 si si 4096 May 27 08:00 thesaurus
drwxrwxr-x 4 si si 4096 May 27 12:21 WEB-INF
Most of the web application's page sections are put into different directories depending on their function. The includes/ directory holds many of the pieces of a web application.
Includes
目录是包含一个应用程序的很多页面片。
The WEB-INF directory is a "private" directory for files which should not be viewed directly by visitors. It holds files for controlling the flow logic and actions of this web application:
[si@localhost product]$ ls -l webapp/catalog/WEB-INF/
total 132
drwxrwxr-x 13 si si 4096 May 27 08:00 actions
-rw-rw-r-- 1 si si 117202 May 27 08:00 controller.xml
-rw-rw-r-- 1 si si 4442 May 27 08:00 web.xml
- controller.xml is a very important file that directs the flow of the web application. It maps URI requests from the visitor's browser to events, services, and pages.
- web.xml contains supplemental information for the web application.
- actions/ directory has beanshell scripts that are used to process and gather data for the pages.
The beanshell scripts in the WEB-INF/actions/ directory often mirror the Freemarker pages in the other directories. For example:
[si@localhost product]$ ls -l webapp/catalog/product/
total 240
-rw-rw-r-- 1 si si 6886 May 27 08:00 ApplyFeaturesFromCategory.ftl
-rw-rw-r-- 1 si si 2099 May 27 08:00 CreateVirtualWithVariantsForm.ftl
-rw-rw-r-- 1 si si 16552 May 27 08:00 EditProductAssoc.ftl
-rw-rw-r-- 1 si si 3813 May 27 08:00 EditProductAttributes.ftl
-rw-rw-r-- 1 si si 1407 May 27 08:00 EditProductContentContent.ftl
-rw-rw-r-- 1 si si 14132 May 27 08:00 EditProductContent.ftl
-rw-rw-r-- 1 si si 6126 May 27 08:00 EditProductDupForm.ftl
-rw-rw-r-- 1 si si 4519 May 27 08:00 EditProductFacilities.ftl
-rw-rw-r-- 1 si si 5273 May 27 08:00 EditProductFacilityLocations.ftl
-rw-rw-r-- 1 si si 13625 May 27 08:00 EditProductFeatures.ftl
-rw-rw-r-- 1 si si 5008 May 27 08:00 EditProductGlAccounts.ftl
-rw-rw-r-- 1 si si 4200 May 27 08:00 EditProductGoodIdentifications.ftl
-rw-rw-r-- 1 si si 13207 May 27 08:00 EditProductInventoryItems.ftl
-rw-rw-r-- 1 si si 6358 May 27 08:00 EditProductKeyword.ftl
-rw-rw-r-- 1 si si 23480 May 27 08:00 EditProductQuickAdmin.ftl
-rw-rw-r-- 1 si si 60917 May 27 08:00 ProductForms.xml
-rw-rw-r-- 1 si si 5721 May 27 08:00 ProductTabBar.ftl
-rw-rw-r-- 1 si si 6380 May 27 08:00 QuickAddVariants.ftl
[si@localhost product]$ ls -l webapp/catalog/WEB-INF/actions/product/
total 72
-rw-rw-r-- 1 si si 5862 May 27 08:00 ApplyFeaturesFromCategory.bsh
-rw-rw-r-- 1 si si 2489 May 27 08:00 ApplyFeaturesFromGroup.bsh
-rw-rw-r-- 1 si si 3548 May 27 08:00 EditProductAssoc.bsh
-rw-rw-r-- 1 si si 7490 May 27 08:00 EditProductContent.bsh
-rw-rw-r-- 1 si si 6920 May 27 08:00 EditProductContentContent.bsh
-rw-rw-r-- 1 si si 2574 May 27 08:00 EditProductFeatures.bsh
-rw-rw-r-- 1 si si 11386 May 27 12:27 EditProductInventoryItems.bsh
-rw-rw-r-- 1 si si 17166 May 27 08:00 EditProductQuickAdmin.bsh
-rw-rw-r-- 1 si si 1890 May 27 08:00 QuickAddVariants.bsh
There is not a one-to-one correspondence because the same beanshell script in actions/ can be reused for multiple pages, and also because some pages are pieced together from multiple Freemarker templates but require only one beanshell script.
Finally, there is one more component of an OFBiz application: the widgets/ directory:
[si@localhost product]$ ls -l widget/
total 8
drwxrwxr-x 3 si si 4096 May 27 08:00 catalog
drwxrwxr-x 3 si si 4096 May 27 08:00 facility
As you can see, this mirrors the contents of webapp/ from above. This is not an accident. The widgets/ directory holds "widgets" for rendering user interface screens. OFBiz allows user interface designs to be created as "generic screens" rather than just web pages, so they could be reused eventually for some other platform. The widgets/ directory's contents mirror those of the webapp/, so there are widgets for the catalog/ webapp and the facility/ webapp.
Now let's take a look at what's in a widgets directory:
[si@localhost product]$ ls -l widget/catalog/
total 176
-rwxrwxr-x 1 si si 11824 May 27 08:00 CatalogScreens.xml
-rwxrwxr-x 1 si si 19862 May 27 08:00 CategoryScreens.xml
-rw-rw-r-- 1 si si 9986 May 27 08:00 CommonScreens.xml
-rwxrwxr-x 1 si si 11122 May 27 08:00 ConfigScreens.xml
-rw-rw-r-- 1 si si 10961 May 27 08:00 FeatureScreens.xml
-rwxrwxr-x 1 si si 5937 May 27 08:00 FindScreens.xml
-rw-rw-r-- 1 si si 6695 May 27 08:00 LookupScreens.xml
-rwxrwxr-x 1 si si 4440 May 27 08:00 PriceScreens.xml
-rw-rw-r-- 1 si si 39740 May 27 08:00 ProductScreens.xml
-rwxrwxr-x 1 si si 14900 May 27 08:00 PromoScreens.xml
-rwxrwxr-x 1 si si 3682 May 27 08:00 ReviewScreens.xml
-rwxrwxr-x 1 si si 19802 May 27 08:00 StoreScreens.xml
-rwxrwxr-x 1 si si 3588 May 27 08:00 ThesaurusScreens.xml
What you see are XML definitions for various screens here. The screens tell OFBiz how to create a screen: what pieces of common navigation elements, Freemarker page sections, and actions are required to create a particular page.
Now you've seen how an OFBiz application is put together. Future tutorials will show you how to develop one from scratch and customize an existing one.