Ofbiz初探
转:http://xmmartin.blog.51cto.com/2310947/771236
主导建设一个电子商务系统
希望从Ofbiz了解中获得一些借鉴
1.下载ofbiz,目前的版本是10.04,下载地址
readme.txt查看
2.开始
下载后解压,在解压后的目录中找到readme.txt,
系统中需要安装有JDK1.6以上的版本,注意是JDK,不是JRE
3.编译
Linux:./ant run-install
Windows:ant run-install
4. 运行
编译完成后,运行
Unix类系统:startofbiz.sh
Windows:startofbiz.bat
运行完成后
前台查看:http://localhost:8080/ecommerce
后台查看:https://localhost:8443/webtools
用户名;Admin,密码:ofbiz
ant 分析暂时略过,ant不熟悉
startofbiz.sh分析
设备各种参数,运行 ofbiz.jar文件
5 源代码分析
开始运行文件位于 Framework->start->src->org->base->start->Start.java(解压ofbiz.jar就可以知道开始运行此文件)
5.1 Start.java分析
先分析运行
Start.init();
Start.start();// Start是一个线程
//init
读取配置文件
初始化Classpath
初始化LOG路径
初始化listenerthread
初始化StartLoaders
run:启动管理监听线程,监听管理指令
start:
5.2 启用loader,开始loader
读取配置文件,org/ofbiz/base/start/install.properties
启动loader :Framework->base->src->org->base->container->Containerloader.java
Container先load,再start
要启用的Container在 Framework->base->config->install-container.xml中定义
一共启动的Container是 ComponentContainer,ClassLoaderContainer,EntityDataLoadContainer
先init,再start
5.3 componentContainer分析
从 component-load.xml载入component
都是从目录下载入多个component
1)先从framework目录中,根据目录下的component-load.xml载入单个的component
2) 再从theme目录,theme目录中没有component-load.xml.
子目录中有ofbiz-component.xml,
3) 再从application目录
4)再从sepcialpurpose目录
5)再从hotdeploy目录
5.4 从ClassLoaderContainer
5.5 从EntityDataLoadContainer, Start()函数 从DelegatorFactory GetDelegator
entity目录下 META-INF定义了 DelegatorFactoryImpl实例
new GenericDelegator
中间从StringUtil中打印OWASP内容
ModelReader
从EntityEngine.xml中取出DelegatorInfo 取default delegator
载入Entity
entity检查
help
datasource检查
deleagator生成结束
initEntityEcaHandler
Ofbiz初探的更多相关文章
- 初探领域驱动设计(2)Repository在DDD中的应用
概述 上一篇我们算是粗略的介绍了一下DDD,我们提到了实体.值类型和领域服务,也稍微讲到了DDD中的分层结构.但这只能算是一个很简单的介绍,并且我们在上篇的末尾还留下了一些问题,其中大家讨论比较多的, ...
- CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探
CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码 ...
- 从273二手车的M站点初探js模块化编程
前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...
- JavaScript学习(一) —— 环境搭建与JavaScript初探
1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...
- .NET文件并发与RabbitMQ(初探RabbitMQ)
本文版权归博客园和作者吴双本人共同所有.欢迎转载,转载和爬虫请注明原文地址:http://www.cnblogs.com/tdws/p/5860668.html 想必MQ这两个字母对于各位前辈们和老司 ...
- React Native初探
前言 很久之前就想研究React Native了,但是一直没有落地的机会,我一直认为一个技术要有落地的场景才有研究的意义,刚好最近迎来了新的APP,在可控的范围内,我们可以在上面做任何想做的事情. P ...
- 【手把手教你全文检索】Apache Lucene初探
PS: 苦学一周全文检索,由原来的搜索小白,到初次涉猎,感觉每门技术都博大精深,其中精髓亦是不可一日而语.那小博猪就简单介绍一下这一周的学习历程,仅供各位程序猿们参考,这其中不涉及任何私密话题,因此也 ...
- Key/Value之王Memcached初探:三、Memcached解决Session的分布式存储场景的应用
一.高可用的Session服务器场景简介 1.1 应用服务器的无状态特性 应用层服务器(这里一般指Web服务器)处理网站应用的业务逻辑,应用的一个最显著的特点是:应用的无状态性. PS:提到无状态特性 ...
- NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例
一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更复杂,可能包含嵌入对象.消息被发送到队列中,“消息队列”是在消息的传输过程中保存消息的容器 ...
随机推荐
- dnf脚本的研究
[player number] 2 8 [pvp start area]0 0 0 00 0 0 00 0 0 0[dungeon]62[/dungeon][type] `[normal]`[gre ...
- visio
为您的产品密钥: 7DNWX-MRX4G-QCGX2-DG6BP-DC8RP http://technet.microsoft.com/zh-cn/evalcenter/hh973399.aspx ...
- TF/IDF计算方法
FROM:http://blog.csdn.net/pennyliang/article/details/1231028 我们已经谈过了如何自动下载网页.如何建立索引.如何衡量网页的质量(Page R ...
- (转)[C++语法] 关键字typedef用法
转自http://www.cnblogs.com/SweetDream/archive/2006/05/10/395921.html C/C++语言中的typedef相信大家已经不陌生,本文对C/C+ ...
- 在 Windows 8 或 8.1 上安装 .NET Framework 3.5 安装错误:0x800f0906、0x800F081F
昨天给一天新装Windows 8.1的PC装.NET Framework 3.5 发现联网速度很慢,并且在长久等待过后直接报错了:0x800f0906 经过Bing,发现了解决方案: 如果根据需要安装 ...
- springMVC从上传的Excel文件中读取数据
示例:导入客户文件(Excle文件) 一.编辑customer.xlsx 二.在spring的xml文件设置上传文件大小 <!-- 上传文件拦截,设置最大上传文件大小 10M=10*1024*1 ...
- 手工、工具分别实现cookie注入
最开始的判断access类型的网站注入点可以用“1 and 1=1”来判断. 不过现在的网站基本上被挡住了.之后呢,可以考虑cookie注入. Dim Tc_Post,Tc_Get,Tc_In,Tc_ ...
- setTimeout浅析
刚学习javascript的时候,感觉setTimeout很好理解,不就是过n(传入的毫秒数)毫秒,执行以下传入的函数吗?这个理解伴随了我挺长的一段时间,才对setTimeout有了新的认识,请先看下 ...
- ANDROID_MARS学习笔记_S01_012_RatingBar
1.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns: ...
- Oracle学习笔记之数据类型
1. mysql和oracle做数据同步.其中表的一个字段在mysql中设置为varchar(6),Oracle中为varchar2(6) 但mysql中能正常存放的数据同步到oracle中却抱O ...