1、我们需要在ofbiz主目录下的hot-deploy目录下建立一个hello1文件夹,
文章对hot-deploy的说明如下:
The advantage of the hot-deploy/ directory is that components here are loaded automatically when OFBiz starts
我的理解是hot-deploy就是用来放我们写的网站/网页的地方
在我们建的hello文件夹中建立一个ofbiz-component.xml的文件,如图:
向里面写入这些内容:
?xml version="1.0" encoding="UTF-8"? ofbiz-component name="hello1" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="http://www.ofbiz.org/dtds/ofbiz-component.xsd" resource-loader name="main" type="component"/ webapp name="hello1" title="My First OFBiz Application" server="default-server" location="webapp/hello1" mount-point="/hello1" app-bar-display="false"/ /ofbiz-component
文章中对这个文件的作用做了如下的描述:
ofbiz-component.xml file to tell OFBiz about your applicaton component: its data model (tables), business logic (services) and workflow, UI layer (web or GUI applications), any seed data it may have, and what other resources it requires.
我们来分析一下这段代码说明了什么:
l 我们的组件名叫做"hello1“
这个hello1的组件名在我们最后访问网址的时候表现如下:
+[http://localhost:8080/+hello1{+}/control/main|http://localhost:8080/hello1/control/main]+
l resource-loader的名字叫做main
l 只有一个web应用,名字也叫“hello1”
l 这个叫hello1的web应用使用的是“default-server”这个服务器
l 这个应用Component的位置在webapp/hello1目录下
l 这个应用Component在使用url访问的时候应该用“/hello1”来访问
2、在这个hello1目录中,我们建立一个webapp目录,如图所示
以后我们的代码就放在里面.进入到webapp目录中,我们还要再新建一个hello1目录,这里hello的名字是要对应之前写的
webapp name="hello1"
这一句代码
一个Component里面可以包含很多个app, A component can have multiple webapps attached to it. e.g. In the "marketing" component there are two webapps "marketing" and "sfa".
3、进入到这个hello1目录中,我们建立一个WEB-INF文件夹以及一个叫做main.ftl的文件,如图所示:
这个main.ftl的作用我的理解是它定义了显示给用户看的页面是什么样子的。他
是一个Freemarker的template file。Freemarker是什么可以查看这个网址
http://www.zzbaike.com/wiki/FreeMarker
简单来说它是用来设计HTML web页面的,特别适用于基于MVC模式的应用程序。
我们在这个文件中输入以下内容:
html head titleHello World/title /head body h1HELLO/h1 pHello world\!/p /body /html
对于目前我们的程序来说,main.ftl就是一个简单的html文件。
在https://cwiki.apache.org/OFBIZ/ofbiz-tutorial-a-beginners-development-guide.html的part2中,我们可以看到,可以在.ftl中进行判断,来决定显示什么内容。
4、我们进入到WEB-INF这个目录中,创建两个xml文件,一个是web.xml,另一个是controller.xml,如图所示:
需要知道的是,每一个OFBiz的web应用,都至少需要这两个文件。
l controller.xml告诉OFBiz如何处理访问者不同的请求,针对不同的请求采取什么样的动作,返回什么样的界面。
l web.xml则告诉OFBiz对于这个web应用,可以使用那些资源,如数据库之类的。
我们在controller.xml中写入如下内容:
?xml version="1.0" encoding="UTF-8" ? site-conf xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="http://www.ofbiz.org/dtds/site-conf.xsd" descriptionFirst Hello World Site Configuration File/description ownerOpen For Business Project (c) 2005 /owner errorpage/error/error.jsp/errorpage handler name="java" type="request"/ handler name="soap" type="request"/ handler name="service" type="request"/ handler name="service-multi" type="request"/ handler name="simple" type="request"/ handler name="ftl" type="view"/ handler name="jsp" type="view"/ handler name="screen" type="view"/ handler name="http" type="view"/ preprocessor \!-\- Events to run on every request before security (chains exempt) \-- \!-\- event type="java" path="org.ofbiz.webapp.event.TestEvent" invoke="test"/ \-- event type="java" path="org.ofbiz.securityext.login.LoginEvents" invoke="checkExternalLoginKey"/ /preprocessor postprocessor \!-\- Events to run on every request after all other processing (chains exempt) \-- \!-\- event type="java" path="org.ofbiz.webapp.event.TestEvent" invoke="test"/ \-- /postprocessor \!-\- Request Mappings \-- request-map uri="main" response name="success" type="view" value="main"/ /request-map \!-\- end of request mappings \-- \!-\- View Mappings \-- view-map name="error" page="/error/error.jsp"/ view-map name="main" type="ftl" page="main.ftl"/ \!-\- end of view mappings \-- /site-conf
可以对此做一下简单的分析:
l 可以看出有9个handler。这些hanlder用于处理请求或者提供界面。他们都是Java的类来着。
handler name="java" type="request"/
这个对应servlet的请求
handler name="service" type="request"/
这个对应service engine的请求
至于那些type为view的,用于针对browser based on Freemarker templates, velocity, JSP, or the OFBiz screen widget.提供不同的界面
l pre-和post-processors。他们是servlet,将会在每一个web请求操作的之前和之后运行。对于我们写的这个web应用,只有pre-processor,
event type="java" path="org.ofbiz.securityext.login.LoginEvents" invoke="checkExternalLoginKey"/
至于它做了什么我现在不是很清楚。
l request mappings。用于将URI(统一资源标识符,是一个用于标识某一互联网资源名称的字符串。 该种标识允许用户对网络中(一般指万维网)的资源通过特定的协议进行交互操作。URI由包括确定语法和相关协议的方案所定义。)请求映射到具体的 request handler或者view handler。
对于我们这个web应用,只有一个请求,就是”/mian”
l view mappings。我的理解是用于将某一个变量映射到具体的页面文件。如:
view-map name="main" type="ftl" page="main.ftl"/
我们就吧main映射到了之前写的main.ftl文件。
对于web.xml,我们写入如下的内容:
?xml version="1.0"? !DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" web-app display-nameHello 1/display-name descriptionThe First Hello World Application/description context-param param-nameentityDelegatorName/param-name param-valuedefault/param-value descriptionThe Name of the Entity Delegator to use, defined in entityengine.xml/description /context-param context-param param-namelocalDispatcherName/param-name param-valuehello1/param-value descriptionA unique name used to identify/recognize the local dispatcher for the Service Engine/description /context-param context-param param-nameserviceReaderUrls/param-name param-value/WEB-INF/services.xml/param-value descriptionConfiguration File(s) For The Service Dispatcher/description /context-param filter filter-nameContextFilter/filter-name display-nameContextFilter/display-name filter-classorg.ofbiz.webapp.control.ContextFilter/filter-class init-param param-namedisableContextSecurity/param-name param-valueN/param-value /init-param init-param param-nameallowedPaths/param-name param-value/control:/select:/index.html:/index.jsp:/default.html: /default.jsp:/images:/includes/maincss.css/param-value /init-param init-param param-nameerrorCode/param-name param-value403/param-value /init-param init-param param-nameredirectPath/param-name param-value/control/main/param-value /init-param /filter filter-mapping filter-nameContextFilter/filter-name url-pattern/*/url-pattern /filter-mapping listenerlistener-class org.ofbiz.webapp.control.ControlEventListener/listener-class/listener listenerlistener-class org.ofbiz.webapp.control.LoginEventListener/listener-class/listener !-- NOTE: not all app servers support mounting implementations of the HttpSessionActivationListener interface -- !-- listenerlistener-class org.ofbiz.webapp.control.ControlActivationEventListener/listener-class/listener -- servlet servlet-nameControlServlet/servlet-name display-nameControlServlet/display-name descriptionMain Control Servlet/description servlet-classorg.ofbiz.webapp.control.ControlServlet/servlet-class load-on-startup1/load-on-startup /servlet servlet-mapping servlet-nameControlServlet/servlet-name url-pattern/control/*/url-pattern /servlet-mapping session-config session-timeout60/session-timeout !-- in minutes -- /session-config welcome-file-list welcome-fileindex.jsp/welcome-file welcome-fileindex.html/welcome-file welcome-fileindex.htm/welcome-file /welcome-file-list /web-app
至于做了什么,我现在还无法分析。
5、最后,就是启动startofbiz.bat这个脚本,然后访问
http://localhost:8080/hello1/control/main
当你看到如下的显示:
那么恭喜你,成功地写了第一个OFBiz的helloworld程序啦!