<o:p> </o:p>
关于项目框架设计的一点学习<o:p></o:p>
<o:p> </o:p>
这两天又在接触一个新项目,对于如何设计一个项目的框架有了点概念,关于web项目(对于oa系统来说)的主体感觉比较需要设计的几部分为:<o:p></o:p>
1. 页面模板定义:关于view层展示,无论对于top(顶层菜单)+left(左边树状菜单)+right(主体内容)结构还是left+right结构,都需要首先定制一些模板,如struts中可使用tiles定义。<o:p></o:p>
2. 分页标签:自定义一个比较通用的分页标签或者使用一些框架中自带的(如struts-menu或者JSF中的t:dataScroller),不过比较好的做法是基于其源码编写自己的分页标签。<o:p></o:p>
3. DB 设计:可使用Power Deisign等设计数据库表结构,产生相关的表。<o:p></o:p>
4. 代码自动生成:编写代码生成脚本如build.xml文件的编写(根据DB生成代码,也可以忽略3,先建model,再从model生成代码和数据库schema),生成Struts、Spring、Hibernate相关文件。<o:p></o:p>
<o:p> </o:p>
关于代码的整体架构如下:<o:p></o:p>
<v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" filled="f" stroked="f" path="m@4@5l@4@11@9@11@9@5xe"><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600 pixelWidth"></v:f><v:f eqn="sum @8 21600 0"></v:f><v:f eqn="prod @7 21600 pixelHeight"></v:f><v:f eqn="sum @10 21600 0"></v:f></v:formulas><v:path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect"></v:path><o:lock v:ext="edit" aspectratio="t"></o:lock></v:shapetype><o:p></o:p>
<o:p>
</o:p>
action 层:处理从view层传递过来的数据。<o:p></o:p>
service 层:封装业务逻辑,一般同时在spring中声明事务代理。<o:p></o:p>
dao 层:进行事务中的原子操作,同时在spring中注入相应的sessionFactory。<o:p></o:p>
<o:p> </o:p>
Spring + Struts 取得spring的bean的两种常用方法:<o:p></o:p>
1. DelegatingActionProxy :将所有action标签中type属性设为org.springframework.web.struts.DelegatingActionProxy 也就是将action委托给了spring,同时在 action-servlets.xml 中配置一个于action标签path属性对应的bean(也就是bean的name值等于action的path值),如:<o:p></o:p>
struts-config.xml 中,以struts的plugin的方式,让spring接管struts的action:<o:p></o:p>
< action name = "portalForm" parameter = "method" path = "/portalAction" type = "org.springframework.web.struts.DelegatingActionProxy" scope = "request" > <o:p></o:p>
< forward name = "portalEdit" path = " pages/portalEdit.jsp" /> <o:p></o:p>
< forward name = "portalList" path = " pages/portalList.jsp " /> <o:p></o:p>
</ action > <o:p></o:p>
< plug-in className = "org.springframework.web.struts.ContextLoaderPlugIn" > <o:p></o:p>
< set-property property = "contextConfigLocation" <o:p></o:p>
value = "/WEB-INF/action-servlets.xml" /> <o:p></o:p>
</ plug-in > <o:p></o:p>
<o:p> </o:p>
action-servlets.xml (配置文件格式和spring配置一样)中:<o:p></o:p>
< beans > <o:p></o:p>
< bean name = "/portalAction" <o:p></o:p>
class = "com.cn.lively.action.PortalMainAction" > <o:p></o:p>
< property name = "portalService" > <o:p></o:p>
< ref bean = "portalService" /> <o:p></o:p>
</ property > <o:p></o:p>
</ bean > <o:p></o:p>
</ beans > <o:p></o:p>
<o:p> </o:p>
2. WebApplicationContextUtils.getRequiredWebApplicationContext :在action中获得spring的bean,<o:p></o:p>
public Object getService (String name) { <o:p></o:p>
ApplicationContext wac = WebApplicationContextUtils.getRequiredWebApplicationContext(servlet.getServletContext()); <o:p></o:p>
return wac .getBean(name); <o:p></o:p>
} <o:p></o:p>
这种方式没有在struts里边加入spring的plugin,实际上是使用了依赖查找来获得对象,并且在servlet代码中硬编码了应用对象的bean名字。<o:p></o:p>
<o:p> </o:p>
附:<o:p></o:p>
感觉一个国内小型项目(周期半年左右)的开发,完美的团队大概四个人左右就够了,<o:p></o:p>
A :前期框架设计 + 开发过程中不断改进完美整个框架,角色——架构师<o:p></o:p>
B :前期需求调研 + 开发过程中负责技术难度比较大的模块开发,角色——程序员<o:p></o:p>
C :前期需求调研负责人 + 开发过程中负责业务逻辑复杂的模块开发,角色——项目负责人<o:p></o:p>
D :前期需求调研 + 开发过程中负责模块开发,角色——程序员<o:p></o:p>
同时B、C负责共同解决开发中出现的技术和业务问题,C负责控制项目进度,<o:p></o:p>
项目后期,B、C、D进行交叉测试,A负责review代码。<o:p></o:p>
<o:p> </o:p>
如果公司已经比较成熟的框架(即基本系统管理模块 + 代码自动生成),那么角色A可以省略,只需要B、C、D三个人即可进行项目开发,其中角色B在开发中担当一部分A的角色。<o:p></o:p>
甚至可以只由B、C两个人进行开发,把角色D的工作分担到B、C身上,B侧重技术,C侧重业务逻辑。<o:p></o:p>
分享到:
相关推荐
《软件框架设计的艺术》这本书,英文原版名为"Practical API Design",是关于软件框架设计的宝贵资源,尤其适合那些寻求提升API设计能力和实践的IT专业人士。API(Application Programming Interface)是软件系统间...
《若依RuoYi框架剖析笔记》是基于江南一点雨的课程并结合个人理解整理而成,涵盖了项目改造、框架结构分析以及多个关键功能模块的深入探讨。以下将逐一解析这些知识点。 1、**项目改造**:首先,从源代码仓库获取...
### 开发框架学习——深入理解MVC框架 ...通过以上分析可以看出,MVC框架的学习不仅涉及基础知识的理解,还需要掌握如何在实际项目中运用这些知识。希望以上的总结能够帮助大家更好地理解和掌握MVC框架的相关知识点。
本文将针对“情境四家居空间施工图设计项目原始平面框架图PPT教案”的教案内容展开深入讨论,以帮助室内设计师和学习者全面理解原始平面框架图的绘制要点和重要性。 一、原始平面框架图的主要内容 原始平面框架图...
E-Learning系统的框架设计不应过度依赖技术,而应平衡技术、内容和学习过程。学习管理系统虽然重要,但仅靠它是不够的。系统设计应考虑用户参与度,提供个性化学习路径,支持自我导向学习,并结合实际工作情境,以...
项目介绍文件通常包含框架的总体设计、主要特点和使用场景,帮助新开发者快速熟悉项目。快速了解文档则提供了快速入门的教程,包括创建新项目、编写基本的CRUD操作、设置权限等,使开发者能迅速上手开发。 总结,...
设计师通常会遵循“少即是多”的原则,通过合理的布局和色彩搭配来实现这一点。使用清晰的字体、对比色和适当的留白,可以增强可读性和视觉吸引力。同时,漂亮的界面并不单指美观,而是与品牌形象和用户需求相协调,...
"Java学习,一点就通,你还在等什么"这个标题暗示了通过深入学习Java,你可以快速掌握其核心概念并应用于实际项目。对于那些对Java感兴趣或者想要提升自己编程技能的人来说,这是一个鼓励和召唤。 描述中提到的“最...
在整个blog进行开发之前,要确定出整个项目的整体架构,包括系统的选型、运行环境的确定及系统结构设计。下面对这进行详细介绍。 在进行软件系统开发的最初环节,一般都需要进行系统的选型,即根据系统功能的实际...
针对这一点,教师会特别关注学生在色彩构成、平面构成等基础课程中的学习情况,因为这些是广告设计不可或缺的基础。面对学生在创意上遇到的难题时,教师会分享个人的设计经验,鼓励学生多画草图,探索不同的设计思路...
《驾考一点通APP项目》是一款专为驾驶考试学习者设计的应用程序,它结合了Java后端技术和Android前端技术,提供了全面的驾驶理论学习及模拟考试功能。此项目包含数据库设计、系统架构以及完整的开发思路,是学习和...
基于Java的SMART系统框架设计通常会遵循以下几个关键原则: 1. **模块化**:SMART系统强调模块化的结构,这意味着每个功能单元都封装在一个独立的模块中,便于重用和独立开发。Java的包(Package)和接口...
### PyTorch:开源机器学习框架的关键特性与功能 #### 动态图机制:灵活性与高效性的完美结合 PyTorch作为一个开源的机器学习框架,其显著的特点之一就是支持动态图机制。相比于TensorFlow等其他框架所采用的静态...
本文将详细探讨《企业内部分布式机器学习系统设计与实现》这篇论文的核心内容,深入解析企业构建分布式机器学习系统的关键技术与实践步骤。 首先,论文强调了机器学习在企业中的重要性,并指出企业需要一个能够支持...
1. **说明.txt**:这个文件很可能包含了关于VB学习的基本指导,包括如何安装开发环境、启动新项目,以及如何利用提供的教程进行学习。 2. **教程阅读器下载.url**:这是一个链接,可能指向一个在线VB教程或阅读器,...
在如今数字化日益发展的时代,UI设计师的...利用这个模板可以更快、更好地展示自己的才华,同时,对于前端开发者而言,这也是一个极佳的学习资源,可以了解和掌握如何将多种技术完美结合来构建一个专业级的设计师官网。
作者在设计实践中意识到,理论学习虽然为我们提供了基础框架,但在实际操作中,很多情况是难以预测和控制的。例如,作者在设计一个可以根据环境温度自动调节风扇转速的系统时,就遇到了单片机控制技术与机械知识不足...
该系统基于Laravel框架进行设计与实现,目的是为博主提供一个更加方便的写作和管理环境。 Markdown作为一种轻量级标记语言,其最大特点是易于书写和阅读,且能够通过简单的标记实现丰富的排版效果。它允许用户使用...
标题提到的“css框架 可以幫你很簡單的设计div+css的布局”强调了这一点,它表明存在一个框架可以帮助设计师更轻松地创建基于div和CSS的网页结构。 CSS框架通常包含一组预定义的样式、布局网格系统、响应式设计组件...
要如何完整地设计一套硬件电路设计,下面为大家分享我的几点个人经验:1)总体思路设计硬件电路,大的框架和架构要搞清楚,但要做到这一点还真不容易。有些大框架也许自己的老板、老师已经想好,自己只是把思路具体...