`
Qieqie
  • 浏览: 340075 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Java Web框架标准化必要性探讨

阅读更多
java的web框架

java的web框架众多的原因在于java的web框架只在servlet一层提供了标准,没有进而再往上作标准。因此,每个web框架都建立自己基于servlet之上的各种不同标准。

struts1使用Struts制订的Action接口
webwork,struts2使用Model和Action同一Action接口
Spring的Controller...
Cetia4的RestServlet...
...
这些web框架有一个基本的假设:开发者编写的Action要必须继承于各自框架的基类。
到此就完了,如果各自的框架要求开发者要继承自己的基类,这还不会出现“百花齐放”那才奇怪了。

这样的Web框架最后都会被抛弃(隐藏在底层):

开发者就应该像开发中间层业务逻辑那样开发Web Action,Pure Web Action,不需要继承Servlet,不需要继承特有的Action对象。

Pure Web Action

web处理对象应该不需要显示继承Servlet,不需要继承框架特有基类,我将这样的web对象称为Pure Web Action,或POJO Action,它的好处是:

1、学习成本几乎为零
如下编写普通的Java代码有何成本可言?
public class UserAction {
	private UserBo userBo;
	public void setUserBo(UserBo userBo) {
		this.userBo = userBo;
	}
	//获取一个指定用户id的用户信息
	public String get(String id, HttpServletRequest request) {
		User user = this.userBo.loadUser(id);
		request.setAttribute("user", user);
		return "user_profile_info";
	}

}


2、鼓励Web框架竞争:

因为如上的UserAction是Pure Web Action,理论上不同的Web框架都能够支持运行它。

编写同样的Action,如果能在竞争的Web框架中使用这才是标准的意义。

有人认为JSF是标准,这是狗屁不通,没有理解“标准”2个字的意思。
JSF是它自己的标准,但不是web框架的标准。
就像hibernate只是他的标准,而不是j2ee的标准,ejb3才是他们的标准,hibernate,jdo只是他的实现。

web框架也应该如此,开发者按Pure Web Action的标准编写了web处理接口对象,这些pure web action没有限制要在那个web框架使用,这就意味着,他在理论上可在任何一个框架使用。

3、可测试性:

UserAction的get()好测试这是不言而喻的,提供了HttpServletRequest等Servlet要求的对象的Mock对象后,该Action就不需要别的了。

将来的java web framework“标准”的额外要求
1、学习其他语言上web框架的的好思想、好做法,大量使用默认或惯例
2、采纳REST:支持丰富的http语义,支持uri的意义
3、透明连接业务逻辑层的AO或BO
4、支持一句话声明或配置,使就可使用想要的view技术,如velocity, freemark, jsp,...
(view技术不一定要是真的view,"假的"view可能只是:(不通过模板而)将对象转化为xml,返回给请求着)
5、action方法支持指令式格式:

	public String login(User user) {
		User user = this.userBo.auth(user.getLogonName(), user.getPassword());
		if (user != null) return "@:1";
		return "@:-1";
	}

即开发者可在返回view对象中加上一些指令,如:
使用重定向的:  r:或redirect:或!:指令,如r:register,表示重定向到注册页面
直接指定物理的view的:  file:或f:指令, 如file:/page/jsp/error.jsp,表示返回该jsp页面给客户端

更多的指令可以在标准中统一规定,并有具体的Web框架实现者来完成以上解析。

。。。


我没有看到有所谓知名的web框架采用如上的设计,但是因为它简单,我们没有理由不期待。
分享到:
评论
33 楼 neptune 2007-12-05  
spring 2.5提供新的基于源注释的mvc框架,与你提出的要求基本吻合。
32 楼 gof95 2007-11-29  
并非一切都能隐藏在底层,定义出这个标准Action层往往就意味着已经有选择了
比如例子中的action,如果把user作为类变量,在struts2下没有问题,在struts1 without spring有问题
31 楼 javafarseer 2007-11-29  
框架只是软件的半成品,半成品到成品还是有很多路要走的,
我就看到williamy的whitesand不错,struts1都很方便
30 楼 cbhyk 2007-11-28  
Qieqie 写道
cbhyk 写道
其实我们全部界面都是用的AJAX,我们的Action是这样:
public class UserAction {  
    public User loadUser(Integer id){...}  
    public Integer save(Map params){...}  
    public void delete(Integer id){...}  
    public List<User> friends(Integer id){...}  
}  

这样是不是更爽快



问题是,
1、你如何将返回的List<User>给客户端,这不成了RCP?
2、我们在哪里指定返回的页面名称,还需要什么配置?插件?
3、一个method根据情况返回不同时,比如成功返回某某具体对象,
失败返回errorCode,这如何做到(或者说没有必要做,交给拦截器去做?)
4、。。。




是的,RCP,客户端这样的:
var ds = new RemoteDataSet("xxxAction.friends");
var list = new XXXList(ds);
ds.load();

除在spring context中配置action外,没有别的配置了。
29 楼 Qieqie 2007-11-28  
cbhyk 写道
其实我们全部界面都是用的AJAX,我们的Action是这样:
public class UserAction {  
    public User loadUser(Integer id){...}  
    public Integer save(Map params){...}  
    public void delete(Integer id){...}  
    public List<User> friends(Integer id){...}  
}  

这样是不是更爽快



问题是,
1、你如何将返回的List<User>给客户端,这不成了RPC?
2、我们在哪里指定返回的页面名称,还需要什么配置?插件?
3、一个method根据情况返回不同时,比如成功返回某某具体对象,
失败返回errorCode,这如何做到(或者说没有必要做,交给拦截器去做?)
4、。。。

28 楼 timerri 2007-11-28  
哈哈,不打击qieqie的积极性了,毕竟出发点还是很不错的...仅仅是没抓到主要矛盾而已....

另:有一句话需要认真体会:
看山是山,看山不是山,看山还是山.....
个人认为是境界的最佳表达.....

27 楼 cbhyk 2007-11-28  
其实我们全部界面都是用的AJAX,我们的Action是这样:
public class UserAction {  
    public User loadUser(Integer id){...}  
    public Integer save(Map params){...}  
    public void delete(Integer id){...}  
    public List<User> friends(Integer id){...}  
}  

这样是不是更爽快
26 楼 Qieqie 2007-11-28  
timerri 写道
Qieqie 写道
LS的,达到“简单”的目标,一个是Action要pure化,以及还有其他方面的要求,请回头再阅读一下。

就只从Action的考虑,Struts2下载后就可以如下开发程序?

public class UserAction {

    public String get(User user){...}
    public String post(User user){...}
    public String delete(String id){...}
    public String put(User user)
    public String friends(String id){...}

}


一个Action的功能能这么丰富

除了编写Action,你不需要N多配置才能把Struts2跑起来? Struts2简单吗?


你可以写
userget.jsp
userpost.jsp
userdelete.jsp
。。。。

是不是连框架都不要了?连servlet都没有了...呵呵,说你钻牛角尖就是钻在这里,自由到了一定程度,就回到了起点。REST其实也是这样返祖的产物.....


汗。。。
(平生第一次使用‘汗’这个字)
25 楼 cbhyk 2007-11-28  
当你用YYY语言时,又会感叹:为什么其他语言的XXX让人这么舒心?而YYY却是痛苦?
24 楼 timerri 2007-11-28  
Qieqie 写道
LS的,达到“简单”的目标,一个是Action要pure化,以及还有其他方面的要求,请回头再阅读一下。

就只从Action的考虑,Struts2下载后就可以如下开发程序?

public class UserAction {

    public String get(User user){...}
    public String post(User user){...}
    public String delete(String id){...}
    public String put(User user)
    public String friends(String id){...}

}


一个Action的功能能这么丰富

除了编写Action,你不需要N多配置才能把Struts2跑起来? Struts2简单吗?


你可以写
userget.jsp
userpost.jsp
userdelete.jsp
。。。。

是不是连框架都不要了?连servlet都没有了...呵呵,说你钻牛角尖就是钻在这里,自由到了一定程度,就回到了起点。REST其实也是这样返祖的产物.....
23 楼 Qieqie 2007-11-28  
cbhyk 写道
Qieqie 写道
LS的,达到“简单”的目标,一个是Action要pure化,以及还有其他方面的要求,请回头再阅读一下。

就只从Action的考虑,Struts2下载后就可以如下开发程序?

public class UserAction {

    public String get(User user){...}
    public String post(User user){...}
    public String delete(String id){...}
    public String put(User user)
    public String friends(String id){...}

}


一个Action的功能能这么丰富

除了编写Action,你不需要N多配置才能把Struts2跑起来? Struts2简单吗?


你描述的framework里面这个action要做些什么配置?恐怕不会少到哪里去吧。

struts对于普通的写界面的程序员来说难么?了解几个规则即可。


如果如此,为什么其他语言的web框架让人这么舒心? 而Java却是痛苦?(虽然还有其他方面,但java web是一个很重要的方面)


〉你描述的framework里面这个action要做些什么配置?恐怕不会少到哪里去吧。

不需要无聊的配置,以下的配置就是ProductAction的所有内容(viewTransfer是公用的),
仅此而已,而且已经是具体的IoC(Spring)的配置,可以这样说,我理想的Web 框架没有多少配置了,默认就可以跑出漂亮的程序了。

<bean name="viewTransfer"
	class="net.paoding.rest.SimpleViewTransfer">
	<property name="prefix" value="/page/shopping/" />
	<property name="suffix" value=".vm" />
</bean>

<bean name="product" 
class="net.paoding.rest.examples.shopping.action.ProductAction" autowire="byName" />


这是ProductAction的代码,它只和Servlet相关,我们看不出它采用什么Web框架:


 package net.paoding.rest.examples.shopping.action;

import java.util.List;

import javax.servlet.http.HttpServletRequest;

import net.paoding.rest.examples.shopping.bo.ProductBo;
import net.paoding.rest.examples.shopping.domain.Product;

public class ProductAction {
	private ProductBo productBo;

	public void setProductBo(ProductBo productBo) {
		this.productBo = productBo;
	}

	public String list(String category, HttpServletRequest request) {
		List products = productBo.findProducts();
		request.setAttribute("products", products);
		return "product-list";
	}

	public String get(String id, HttpServletRequest request) {
		Product product = productBo.getProduct(id);
		request.setAttribute("product", product);
		return "product";
	}
}
22 楼 cbhyk 2007-11-28  
Qieqie 写道
LS的,达到“简单”的目标,一个是Action要pure化,以及还有其他方面的要求,请回头再阅读一下。

就只从Action的考虑,Struts2下载后就可以如下开发程序?

public class UserAction {

    public String get(User user){...}
    public String post(User user){...}
    public String delete(String id){...}
    public String put(User user)
    public String friends(String id){...}

}


一个Action的功能能这么丰富

除了编写Action,你不需要N多配置才能把Struts2跑起来? Struts2简单吗?


你描述的framework里面这个action要做些什么配置?恐怕不会少到哪里去吧。

struts对于普通的写界面的程序员来说难么?了解几个规则即可。在项目中作硬性规定,添加界面时:
第1步.写一个继承BaseAction的类
第2步.在XXX配置文件加一项配置

21 楼 Qieqie 2007-11-28  
cbhyk 写道
pure的目的是什么?为了pure而pure?


那是形而上。

20 楼 cbhyk 2007-11-28  
pure的目的是什么?为了pure而pure?
19 楼 Qieqie 2007-11-28  
LS的,达到“简单”的目标,一个是Action要pure化,以及还有其他方面的要求,请回头再阅读一下。

就只从Action的考虑,Struts2下载后就可以如下开发程序?

public class UserAction {

    public String get(User user){...}
    public String post(User user){...}
    public String delete(String id){...}
    public String put(User user)
    public String friends(String id){...}

}


一个Action的功能能这么丰富

除了编写Action,你不需要N多配置才能把Struts2跑起来? Struts2简单吗?
18 楼 cbhyk 2007-11-28  
public class UserAction {  
    private UserBo userBo;  

    public void setUserBo(UserBo userBo) {  
        this.userBo = userBo;  
    }  

    public String get(String id, HttpServletRequest request) {  
        User user = this.userBo.loadUser(id);  
        request.setAttribute("user", user);  
        return "user_profile_info";  
    }  
  
}  


import com.opensymphony.xwork.Action; 

public class HelloWebWorldAction implements Action { 
   private User user; 
   private UserBo userBo;  

   public void setUserBo(UserBo userBo) {  
     this.userBo = userBo;  
   }  

   public User getUser() { 
	return user; 
   }

   public String execute() throws Exception { 
	user = this.userBo.loadUser(id);  
	return SUCCESS; 
   } 
}


哪一个简单?
这是你需要的POJO Action?
17 楼 Qieqie 2007-11-28  
downpour 写道
Qieqie 写道

市面上的 MockHttpServletRequest等可以使Action脱离容器进行测试。

没有说Action要脱离Servlet容器,Action运行总是脱离不了Servlet容器的,但(如果可以的话)不应该让Action过多依赖具体web框架的实现。
我的表述是:也让Action只依赖标准的Servlet吧,因为Servlet的类很多人做了Mock套件了,很容易脱离容器测试。让后使Action够pure,以可轻松编写


早说了,不喜欢现有的框架,就自己按照自己喜欢的方式写,没有人强迫你依赖Struts的jar包。但是你不要强调现在的框架这个不能做那个不能做。能不能做是框架的事情,用不用是你的事情。更何况实在不是人家不能做,而是你喜欢钻牛角尖。



1、你真是没有贡献精神。当你看到不爽的开发方式时为什么仅仅是“不喜欢现有的框架,就自己按照自己喜欢的方式写”,
是否在做这件事的时候,可以表述出来让人讨论,是否可以改进。

2、>更何况实在不是人家不能做,而是你喜欢钻牛角尖。
我问你,有什么事现在的程序不能做?都可以做,关键是:简单不简单,方便不方便,傻瓜不傻瓜

当你花上高超的技术耗动一个物件时,别人轻轻一挑就起来,你的感觉怎么样?
为什么Java这么让人头疼,我们做何思考,我们可以做些什么?


16 楼 timerri 2007-11-28  
Qieqie 写道
timerri 写道
唉,qieqie钻牛角尖了....

先要明白一句话,自由是建立在不自由的基础之上的。

pojo型的action看似很自由,其实却隐含了更多的规则,隐含的规则相对于现成的implement和extend,确是更加难以掌握。这样的框架,写给自己用可以,写给别人用还得让人家背好规则再开始。还是前面的话,新程序员你就算把接口都给他定好了,他还不一定能写对,这次连接口都没了,你期望他们能出什么像样的代码??
维护上也会是自找麻烦,10个人写pojo就会有10个样,起名起的那更是五花八门,用拼音的,用英语的,还能有直接用中文的。你还真打算去掌握每个人的写代码的习惯??或许还是更“硬”点的框架能让人对手下更放心吧

所以,pojo型的框架,我对其前途并不看好......



pojo=java,以上问题同样存在java之中


没错,所以我经常用c写本地代码解决性能问题,还不得不研究jvm的具体实现.....都是被java的隐含规则给害的。

不过,java在实现方面的接口可是非常的"硬"了,j2ee基本上就是一堆你没办法改的接口。java就像强 奸,既然不能反抗,那就只有享受了....
15 楼 downpour 2007-11-28  
Qieqie 写道

市面上的 MockHttpServletRequest等可以使Action脱离容器进行测试。

没有说Action要脱离Servlet容器,Action运行总是脱离不了Servlet容器的,但(如果可以的话)不应该让Action过多依赖具体web框架的实现。
我的表述是:也让Action只依赖标准的Servlet吧,因为Servlet的类很多人做了Mock套件了,很容易脱离容器测试。让后使Action够pure,以可轻松编写


早说了,不喜欢现有的框架,就自己按照自己喜欢的方式写,没有人强迫你依赖Struts的jar包。但是你不要强调现在的框架这个不能做那个不能做。能不能做是框架的事情,用不用是你的事情。更何况实在不是人家不能做,而是你喜欢钻牛角尖。
14 楼 Qieqie 2007-11-28  
timerri 写道
唉,qieqie钻牛角尖了....

先要明白一句话,自由是建立在不自由的基础之上的。

pojo型的action看似很自由,其实却隐含了更多的规则,隐含的规则相对于现成的implement和extend,确是更加难以掌握。这样的框架,写给自己用可以,写给别人用还得让人家背好规则再开始。还是前面的话,新程序员你就算把接口都给他定好了,他还不一定能写对,这次连接口都没了,你期望他们能出什么像样的代码??
维护上也会是自找麻烦,10个人写pojo就会有10个样,起名起的那更是五花八门,用拼音的,用英语的,还能有直接用中文的。你还真打算去掌握每个人的写代码的习惯??或许还是更“硬”点的框架能让人对手下更放心吧

所以,pojo型的框架,我对其前途并不看好......



pojo=java,以上问题同样存在java之中

相关推荐

    Java Web开发实战经典.rar

    同时,理解异常处理、集合框架(如ArrayList、LinkedList、HashMap等)以及IO流等核心Java特性也是必要的。 2. **Servlet与JSP**:Servlet是Java Web开发的基础,用于处理HTTP请求。学习如何创建Servlet,配置web....

    用java web start来发布jbpm(三)

    这个框架基于Java技术,支持BPMN 2.0标准,可以实现复杂的业务流程自动化。 在本文中,我们可以预期博主将介绍以下内容: 1. **环境准备**:首先,我们需要安装Java Development Kit (JDK) 和设置好Java环境变量,...

    XFire Java Web Service 客户端

    本文将深入探讨XFire Java Web Service客户端的使用和相关知识点。 一、XFire简介 XFire是Apache CXF项目的一个前身,它是一款高效的、开源的Java Web Service实现。XFire的目标是提供一个轻量级、快速且易于使用...

    各种JAVA基础及框架

    - **设计模式**: 如单例模式、工厂模式等,为解决常见问题提供了一套标准化的方法。 通过上述内容,我们可以看到Java不仅仅是一种编程语言,它还涉及到了操作系统层面的操作、数据库管理以及Web开发等多个方面。...

    Java Web Service教程

    教程的第一部分将引导你了解如何设置开发环境,包括安装必要的工具,如Java Development Kit (JDK)、Eclipse IDE(或者你喜欢的任何其他IDE)以及Apache CXF等Web服务框架。然后,我们将通过一个简单的示例教你如何...

    Java Web轻量级开发全体验15 代码

    在Java Web开发领域,轻量级框架已经成为主流,它们提供了高效、灵活且易于维护的解决方案。本主题聚焦于“Java Web轻量级开发全体验15”,这可能是指一系列教程或项目的第15个部分,重点是通过代码实践来学习和理解...

    java调用java web service

    - 使用Java的JAX-WS(Java API for XML Web Services)框架,开发者可以创建Java Web Service。例如,通过`@WebService`注解定义服务接口,`@WebMethod`注解定义服务方法,然后使用`wsimport`工具生成客户端存根类...

    Tomcat与Java.Web开发技术详解附书光盘1

    《Tomcat与Java.Web开发技术详解》是一本深入探讨Java Web应用服务器——Tomcat以及相关开发技术的专业书籍。光盘附带的"sourcecode1"文件可能是书中示例代码或练习项目的源码,旨在帮助读者更好地理解和实践所学...

    基于token验证的Java Web权限控制框架,使用jjwt,支持redis和db多种存储方式,可用于前后端分离项.zip

    本文将深入探讨基于token验证的Java Web权限控制框架,它使用jjwt库,并且支持Redis和数据库(DB)作为存储机制。这个框架适用于需要安全、高效地管理用户访问权限的项目。 首先,JWT(JSON Web Token)是一种轻量...

    Soa Using Java WebService

    3. **标准化**:SOA强调使用开放标准和技术,如XML、SOAP、WSDL等,以确保不同服务之间的互操作性。 4. **服务抽象**:服务的实现细节对外部隐藏,只暴露必要的接口供其他服务调用。 ### Java Web服务 Java Web...

    ssi框架简单搭建。。。

    在Java环境下,我们可以使用各种框架来实现SSI功能,以提高网站的开发效率和可维护性。下面我们将详细探讨Java中的SSI框架搭建及其应用。 首先,理解SSI的基本概念是必要的。SSI主要通过在HTML文件中使用特定的指令...

    学习资料&项目源码基于java技术实现web系统构建

    3. **MVC设计模式**: Model-View-Controller模式是Web开发中常用的设计模式,Java Web框架如Spring MVC遵循这一模式。理解模型、视图和控制器的职责有助于构建模块化、可维护的Web应用。 4. **JDBC与数据库交互**: ...

    JAVA WEB 项目 Oracle数据库技术

    本教程将深入探讨如何在JAVA WEB项目中有效地利用Oracle技术。 首先,了解Oracle数据库的基本概念至关重要。Oracle数据库是一个关系型数据库管理系统(RDBMS),它支持SQL标准,并提供了一套丰富的功能,包括事务...

    JAVA调用.NETWeb Service完整代码

    而Java作为开源且跨平台的编程语言,与.NET的互操作性是通过标准的Web服务协议实现的,如SOAP和WS-I(Web Services Interoperability)规范。 描述中的"试验了网上N个例子,都没有成功,最后自己调试出来的,绝对能...

    基于 Spring Boot 构建 的 Java Web 平台企业级单体应用快速开发框架,适合中小型项目的应用和开发.zip

    【标题】中的“基于 Spring Boot 构建的 Java Web 平台企业级单体应用快速开发框架”指的是一种利用Spring Boot技术构建的用于开发企业级Web应用程序的框架。Spring Boot是Spring框架的一个扩展,旨在简化Java Web...

    Web项目Demo(不基于任何框架)

    在本项目"Web项目Demo(不基于任何框架)"中,我们关注的是一个纯原生的Web应用程序开发,没有依赖任何特定的框架,如Spring、Angular或React等。这样的项目可以帮助开发者深入理解Web项目的底层机制,为以后学习和...

    java 调用 web seervice 方法

    Java 调用 Web Service 是一个常见的任务,用于实现不同系统间的互操作性。Web Service 提供了一种标准的方式让应用程序能够通过网络交换数据。在Java中,有多种库可以帮助我们实现这一目标,如 HttpClient、Xfire ...

    java调用C#接口及所涉及到的架包

    C#可以通过ASP.NET Web API框架创建REST服务,Java则可以使用JAX-RS(Java API for RESTful Web Services)来消费这些服务。 3. **Java调用C#的步骤** - **创建C#接口**:在C#中定义接口,封装所需功能,并部署为...

    精选_基于JAVA EE框架的在线考试系统平台的设计与实现_源码打包

    1. **JAVA EE框架**:JAVA EE(Java Platform, Enterprise Edition),以前称为J2EE,是用于构建企业级Web应用的标准框架。它包括一系列服务、API和协议,如Servlet、JSP、EJB、JPA、JMS等,为开发人员提供了处理...

Global site tag (gtag.js) - Google Analytics