`
triu
  • 浏览: 10456 次
  • 来自: 成都
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

JSP is no longer required.

阅读更多

历经一个半月的努力,框架终于在200712月上旬完成了改造,目前框架已支持热部署。

 

框架采用XSLT格式化XMLXHTML的方式来展现所有内容,内容管理采用入口参数来控制,浏览器请求的地址会被引擎转换到相应入口,引擎根据入口定义调用方法获得特定格式的XML内容,然后根据入口定义找到对应的XSTL文件,使用XSLT文件将XML内容格式化成XHTML

 

这样做的目的就是要把管理、逻辑、内容、风格分离,使得任务可分配给擅长某方面技术的人员,他们不再需要熟悉其它方面,使得开发工作可同步进行。

 

内容根据系统设计时定义的数据库或XML来制作,入门了的Java工程师即可胜任此工作。

 

逻辑根据入口定义从内容中获取数据并生成特定格式的XML内容,只要有一定基础的Java工程师即可胜任此工作。

 

风格根据UI设计时定义的界面来制作,需要具有XSLJavaScriptCSSHTML技术特点的Web工程师来完成这部分工作,明显的,这里多了一个XSL

 

管理根据入口定义配置逻辑与风格的关联,这部分需要有相当功底的架构工程师来完成。

 

此外,UI工程师和测试工程师肯定也少不了。

 

开发流程可以这样控制:

 

UI工程师制作格式为HTML的效果页面,并将制作好的文件提交到CVS

 

架构工程师根据效果页面定义格式为XSD的页面数据,并将制作好的文件提交到CVS

 

Web工程师根据效果页面和页面数据制作格式为XSL的数据格式,以及相应的格式为JSJavaScript脚本和格式为CSS样式,经过测试将制作好的文件提交到CVS

 

Java工程师根据页面数据制作生成数据的业务逻辑和数据存储,经过测试将制作好的文件提交到CVS

 

架构工程师定义功能目录入口,把Web工程师和Java工程师制作的文件整合起来;

 

架构工程师把完整的应用软件打包并发布到网络中;

 

测试工程师对应用软件进行功能测试,并填写测试报告;

 

修改BUG后重新发布应用软件;

 

如此将不再需要再嵌入Java代码,JSPHTML中嵌入代码,XSPXML中嵌入代码,这样做意味着样式的修改不会影响到逻辑和内容,逻辑或内容的修改不会影响到风格,前提是只要定义XML内容的XSD不改变,因此,系统的开发效率、稳定性将得到很大提升。

 

此外,使用入口匹配XSLTXML的方法使得不同的使用者可以选择不同的风格,体验变得更有趣。

 

框架新近开始支持热部署,包括框架系统配置部分以及所有发布到框架中的应用软件。同时,框架还支持数据同步,以适应集群服务器部署。

分享到:
评论
64 楼 triu 2008-01-11  
stevenwang 写道
个人愚见,越清晰的 架构,复杂度 越高,时间 成本 越高。
为了 实现 层之间的通信 需要 定义 各种标准 接口。
松耦合不见的好用。


这要看从什么角度来看了,如果开发上了一定规模了,还是清晰比较好,因为,那个
时候管理成本是大头了。

凡事都有个度,看怎么把握了,对于松偶合嘛,眼光要放长远一点,开始可能花费不
菲,可大家公认的真理是:变化才是永恒的,所以,如果需求变化造成的影响能被限
制在一定范围,而不会波及到系统的其他部分,那就值了。
63 楼 stevenwang 2008-01-11  
个人愚见,越清晰的 架构,复杂度 越高,时间 成本 越高。
为了 实现 层之间的通信 需要 定义 各种标准 接口。
松耦合不见的好用。
62 楼 triu 2008-01-11  
Transformers 写道
建议做一些code generator,我现在的项目也是基于XML+XSLT,在没有任何ide的情况下,开发一个功能挺费劲的,而且后来发现大部分的功能都差不多,用ruby做了code generator解决一些很繁琐的工作。


很对呵,我也发现了“大部分的功能都差不多”,呵呵,我现在是用复制加替换变量的方法。

genereator的工作正在考虑中,如果能的话,就放到Eclipse插件里一起做了。
61 楼 Transformers 2008-01-11  
建议做一些code generator,我现在的项目也是基于XML+XSLT,在没有任何ide的情况下,开发一个功能挺费劲的,而且后来发现大部分的功能都差不多,用ruby做了code generator解决一些很繁琐的工作。
60 楼 triu 2008-01-11  
ray_linn 写道
XSL一下类似docbook这样复杂的DTD就知道爽了.


不是纯粹地用XSL,在框架里XSL的地位只相当与CSS,况且,DTD的语法不符合XML定义,
应该使用XSD。
59 楼 triu 2008-01-11  
对于前面几位批评的朋友,甚为感谢,诚挚地感谢你们对在下的关心。

我这么做正是基于自己在多年的开发工作中感受到的痛苦,努力地想简化
开发过程,让开发工作能准确定位,能更精确地预测项目的开发周期,我
知道CMMI的目标是什么,所以,我不能同意各位的说法,当把它进行到底。

再次感谢。
58 楼 triu 2008-01-11  
myyate 写道
triu 写道
如你所说,XSLT的开发效率体现在两个方面:1。掌握的人不多;2。缺乏相应的工具。

针对这两个方面可以采取如下方法,1。培训;2。使用浏览器本身对XSLT的支持。


确实掌握的人不多,因为用这个做项目的本来就少,一般也只有国外个把项目是用这个技术的。
工具你可以考虑Altova XMLSpy,这个足以满足项目的开发。不过是收费的,网上有key,但是注册了还是过期。


谢谢你的建议,当然将来能做出Eclipse的插件来做开发是最好的了。
57 楼 triu 2008-01-11  
myyate 写道
楼主这个也做出来了框架,不简单。其实应用也有,csdn就是。
上学的时候写小论文就是写XSLT+XML做web层的适用性研究,虽然论文是那样写的,但是我感觉不太实际,至少目前,说这些并没有打击楼主的意思,只是就技术论技术
XSLT+XML做Web层用过一次,做国外的一个在线优惠券兑现系统,真的很痛苦,其实我写几个模块没有什么,就是把读出来的数据生成规定的XML,但是我觉得在很多国内系统中不太现实,代价或者周期有点高,估计国内用这种技术的公司寥寥无几,这个是现实问题。
我想问楼主一下,你们对于大于1M的XML文件如何处理的?是分解?

PS:我觉得有点奇怪,这个帖子为什么投隐藏呢?技术嘛,终究是讨论讨论嘛


不会有大于1M的文件,XML内容只是页面上的动态数据,而不是描述整个页面及其布局的,
举个例子就是数据库结果集,且这个内容会采用分页。而对于需要文件上传和下载时使用
单独的文件服务器,XML只提供文件地址。
56 楼 Qieqie 2008-01-11  
myyate 写道
PS:我觉得有点奇怪,这个帖子为什么投隐藏呢?技术嘛,终究是讨论讨论嘛


有人投隐藏,那在那个人看来就有一定的道理。

当然这个隐藏是我投的,光明正大,我来说道理:
这个帖子 1)犯了标题党,2)这里是海阔天空,不是Java版。
转到Java版,我投隐藏的机率会很低,但不排除因为“标题”原因也来一次。
(我是很懒很懒投隐藏、入门的)

看不惯,那就互相扯皮或只好忍者。这就是网络!
55 楼 weizh 2008-01-11  
XSLT是很容易掌握的技术,无非就是xpath等语法。不要强调掌握的人多,就当是都已经掌握了,这样的项目还是后患无穷。
54 楼 atianchen 2008-01-11  
裹脚布已经够厚老,还非要套上几双棉袜!!!何苦了,何必了?
53 楼 ray_linn 2008-01-11  
XSL一下类似docbook这样复杂的DTD就知道爽了.
52 楼 weizh 2008-01-10  
LZ把当前页面做个XSD看看呢,明显没有经验么,这个过程居然理想化到这种程度!
这样的结构的失败项目就摆在我面前,可以说是后患无穷。不过话说回来,没有切肤之痛,实难有感触的。
再多说一句,以这样的结构做复杂业务系统,可是说是没事找抽,做做简单网站兴许。
51 楼 myy 2008-01-10  
我也曾经对 XSLT 狂热研究过一阵,不过如今对他也不再感冒了。

原因嘛,前面人都说完了。对楼主不撞南腔不回头的执着表示佩服。
50 楼 myyate 2008-01-10  
triu 写道
如你所说,XSLT的开发效率体现在两个方面:1。掌握的人不多;2。缺乏相应的工具。

针对这两个方面可以采取如下方法,1。培训;2。使用浏览器本身对XSLT的支持。


确实掌握的人不多,因为用这个做项目的本来就少,一般也只有国外个把项目是用这个技术的。
工具你可以考虑Altova XMLSpy,这个足以满足项目的开发。不过是收费的,网上有key,但是注册了还是过期。
49 楼 mingo 2008-01-10  
感觉就像GWT一样,技术花哨而不实用。
48 楼 myyate 2008-01-10  
楼主这个也做出来了框架,不简单。其实应用也有,csdn就是。
上学的时候写小论文就是写XSLT+XML做web层的适用性研究,虽然论文是那样写的,但是我感觉不太实际,至少目前,说这些并没有打击楼主的意思,只是就技术论技术
XSLT+XML做Web层用过一次,做国外的一个在线优惠券兑现系统,真的很痛苦,其实我写几个模块没有什么,就是把读出来的数据生成规定的XML,但是我觉得在很多国内系统中不太现实,代价或者周期有点高,估计国内用这种技术的公司寥寥无几,这个是现实问题。
我想问楼主一下,你们对于大于1M的XML文件如何处理的?是分解?

PS:我觉得有点奇怪,这个帖子为什么投隐藏呢?技术嘛,终究是讨论讨论嘛
47 楼 triu 2008-01-10  
一蓑烟雨任平生 写道
项目验收后一年就进入运维期,跟项目大小没有关系。

流程和框架的价值在于QCD(质量、成本、交付期)指标的改善。


说得很好,谢谢你,这就是我做这个框架的出发点。
46 楼 triu 2008-01-10  
目前,已经实现了系统配置部分的插件,能动态部署到框架中。

下一步是,找到合适的项目,将项目做成插件发布到框架中。

计划就这么简单。
45 楼 一蓑烟雨任平生 2008-01-10  
项目验收后一年就进入运维期,跟项目大小没有关系。

流程和框架的价值在于QCD(质量、成本、交付期)指标的改善。

相关推荐

    jsp-api-2.1.jar

    jsp-api-2.1.jar jspAPI文档欢迎下载

    login.jsp用户登录界面

    login.jsp用户登录界面login.jsp用户登录界面login.jsp用户登录界面login.jsp用户登录界面

    javax.servlet.jsp.jar

    javax.servlet.jsp_2.0.0.v201101211617.jar,javax.,servlet,jsp

    jsp-api-2.1.jar.zip

    jsp-api-2.1.jar.zip jsp-api-2.1.jar.zip jsp-api-2.1.jar.zip jsp-api-2.1.jar.zip jsp-api-2.1.jar.zip jsp-api-2.1.jar.zip

    jsp-api.jar

    jsp-api.jar 好东西,需要的下载,好东西,需要的下载。

    jakarta.servlet.jsp.jstl-api-2.0.0.jar

    jakarta.servlet.jsp.jstl-api-2.0.0.jar

    jsp-api-2.1 jar 和 jsp-api-2.0 jar

    import javax.servlet.jsp.JspException; import javax.servlet.jsp.tagext.TagSupport; 所导致的无包报错解决jar包 注意导入jar包时应注意Servlet的版本,如果是Servlet 2.4 对应的应该是JSP 2.0 的jar包,如果是...

    jsp使用vue资源包.zip

    在IT行业中,Web开发是至关重要的一环,而JavaServer Pages(JSP)和Vue.js都是这一领域的关键技术。本资源包“jsp使用vue资源包.zip”聚焦于如何在JSP项目中集成Vue.js,特别是利用ElementUI这个流行的前端组件库。...

    login_jsp.zip_login. jsp代码_login.jsp_login.jsp代码_military753

    在"login_jsp.zip"这个压缩包中,包含了一个名为"login.jsp"的文件,这是一个用于处理用户登录请求的页面。 首先,"login.jsp"通常会包含一个HTML表单,用于接收用户的用户名和密码输入。表单通过POST方法提交到同...

    jsp-api-2.2.1.jar

    javax.servlet.jsp-api-2.2.1 java 开发web 工程不可缺少包

    基于jsp的教学管理系统

    ............\.......\addClass_confirm.jsp ............\.......\Addcourse.jsp ............\.......\addcourse_confirm.jsp ............\.......\addstudent.jsp ............\.......\addstudent_confirm...

    JSP影院售票系统,能学习也能用

    基于JSP技术,包含了售票,查找座位等其他主要功能 部分文件浏览: jsp-dianying\Audio.jsp jsp-dianying\Bottom.jsp jsp-dianying\error.jsp jsp-dianying\index.jsp jsp-dianying\Index1.jsp jsp-dianying\Left....

    JSP内置对象实验报告.doc

    %><p>This is a JSP page demonstrating the usage of the Response object.</p><form action="" method="post"><input type="text" name="txtInput"><input type="submit" value="Submit"></form><% if(request....

    Head.First.Servlets.and.JSP.2nd.Edition.Mar.2008

    Head.First.Servlets.and.JSP.2nd.Edition.Mar.2008 第二部分

    掌握自定义JSP标签(html).

    - 标签处理类(Tag Handler Class):这是实现自定义标签功能的Java类,它继承自`javax.servlet.jsp.tagext.TagSupport`或其子类。 3. 创建自定义标签的步骤: 1) 编写TLD文件:首先,我们需要创建一个TLD文件,...

    JSP 火车票售票系统.zip

    设计利用JSP 开发工具和SQL Server 2000数据库来开发这个火车票售票系统。该系统要解决的是火车站网上售票工作所要解决的问题,可以满足火车站网上售票的基本要求,包括查询、售票、退票等三个方面的功能。该系统能...

    JSP标签,采用web.xml引入标签库描述文件

    2. **实现标签处理类(Tag Handler Class)**:自定义标签的核心是Java类,它实现了`javax.servlet.jsp.tagext.Tag`接口或其子接口。这个类负责处理标签的行为,如`doStartTag()`和`doEndTag()`方法。 3. **在JSP...

    JSP课程设计系统打包.zip

    **JSP技术基础** JSP(JavaServer Pages)是Java平台上的一个重要技术,它是一种用于创建动态网页的服务器端技术。JSP的核心理念是将HTML(或XML)模板与Java代码分离,使得开发者可以专注于页面的外观设计和业务...

Global site tag (gtag.js) - Google Analytics