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

[b]java的web框架[/b]

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

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

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

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

[b]Pure Web Action[/b]

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

[u]1、学习成本几乎为零[/u]
如下编写普通的Java代码有何成本可言?
[code]
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";
}

}
[/code]

[u]2、鼓励Web框架竞争:[/u]

因为如上的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框架使用,这就意味着,他在理论上可在任何一个框架使用。

[u]3、可测试性:[/u]

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

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

public String login(User user) {
User user = this.userBo.auth(user.getLogonName(), user.getPassword());
if (user != null) return "@:1";
return "@:-1";
}
[/code]
即开发者可在返回view对象中加上一些指令,如:
使用重定向的: r:或redirect:或!:指令,如r:register,表示重定向到注册页面
直接指定物理的view的: file:或f:指令, 如file:/page/jsp/error.jsp,表示返回该jsp页面给客户端

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

。。。


[b]我没有看到有所谓知名的web框架采用如上的设计,但是因为它简单,我们没有理由不期待。[/b]

你可能感兴趣的:(Java Web框架标准化必要性探讨)