日期:2014-05-19  浏览次数:20676 次

J2EE学习的反思【转】

原文出处: http://www.blogjava.net/lujie2012/archive/2011/11/25/j2ee.html

?

?现在许许多多的初学者和程序员,都在趋之若鹜地学习Web开发的宝典级框架:Struts2,Spring,Hibernate。似乎这些框架成为了一个人是否精通Java,是否会写J2EE程序的唯一事实标准和找工作的必备基础。

AD:
现在许许多多的初学者和程序员,都在趋之若鹜地学习Web开发的宝典级框架:Struts2,
Spring,Hibernate。似乎这些框架成为了一个人是否精通Java,是否会写J2EE程序的唯一事实标准和找工作的必备基础。
然而,如果在面试的时候问这些程序员,你们为什么要学习这些框架?这些框架的本质到底是什么?似乎很少很少有人能够给我非常满意的答复。因为他们都 在为了学习而学习,为了工作而学习,而不是在真正去深入了解一个框架。其实所有的人都应该思考这样的问题:为什么要学习框架?框架到底给我带来了什么?接 下来,我们以登录作为一个最简单的例子,来看看不同的年代,我们是怎么写Web程序的。
后来,我们放弃了在页面上写逻辑。
后来,程序写得越来越多,我们发现,这种在HTML代码中编写Java代码来完成逻辑的方式存在着不少问题:
1. Java代码由于混杂在一个HTML环境中而显得混乱不堪,可读性非常差。一个JSP文件有时候会变成几十K,甚至上百K。要找一段逻辑,经常无法定位。
2. 编写代码时非常困惑,不知道代码到底应该写在哪里,也不知道别人是不是已经曾经实现过类似的功能,到哪里去引用。
3. 突然之间,某个需求发生了变化。于是,每个人蒙头开始全程替换,还要小心翼翼的,生怕把别人的逻辑改了。
4. 逻辑处理程序需要自己来维护生命周期,对于类似数据库事务、日志等众多模块无法统一支持。
在这个时候,如果有一个产品,它能够将页面上的那些Java代码抽取出来,让页面上尽量少出现Java代码,该有多好。于是许多人开始使用servlet来处理那些业务逻辑。
  1. public?class?LoginServlet?extends?HttpServlet?{????
  2. ????
  3. ????/*?(non-Javadoc)???
  4. ?????*?@see?javax.servlet.http.HttpServlet#doPost(javax.servlet.http.HttpServletRequest,?javax.servlet.http.HttpServletResponse)???
  5. ?????*/????
  6. ????@Override????
  7. ????protected?void?doPost(HttpServletRequest?req,?HttpServletResponse?resp)?throws?ServletException,?IOException?{????
  8. ????????String?message?=?null;????
  9. ????????RequestDispatcher?dispatcher?=?req.getRequestDispatcher("/result.jsp");????
  10. ????????String?name?=?req.getParameter("name");????
  11. ????????String?password?=?req.getParameter("password");????
  12. ????????????
  13. ????????UserHandler?userHandler?=?new?UserHandler();????
  14. ????????if(userHandler.authenticate(name,?password))?{????
  15. ????????????message?=?"恭喜你,登录成功";????
  16. ????????}?else?{????
  17. ????????????message?=?"对不起,登录失败";????
  18. ????????}????
  19. ????????????
  20. ????????req.setAttribute("message",?message);????
  21. ????????dispatcher.forward(req,?resp);????
  22. ????}????
  23. }????
在这里,我们需要在web.xml中为这个servlet配置url的请求关系。
  1. <servlet>????
  2. ??<servlet-name>Login</servlet-name>????
  3. ????<servlet-class>????
  4. ??????com.demo2do.servlet.LoginServlet????
  5. ??</servlet-class>????
  6. </servlet>????
  7. <servlet-mapping>????
  8. ??<servlet-name>Login</servlet-name>????
  9. ??<url-pattern>????
  10. ????/Login????
  11. ??</url-pattern>????
  12. </servlet-mapping>????
代码重构到这里,我们发现,其实我们的工作量本身并没有减少,只是代码从JSP移动到了Servlet,使得整个流程看上去稍微清楚了一些。然而,为了这么点干净,我们付出的代价是什么?为每个servlet都在web.xml里面去做一个url的请求配置! 
在很多年前,我们这么写程序的。
很多年前,那是一个贫苦的年代,如果我们要使用Java在网页上做一些动态的交互功能。很多人会告诉你一个技术,叫做JSP。在我还对Java非常困惑的时候,就有人告诉我,JSP是个好东西,它可以在HTML代码里面写Java代码来完成逻辑。
  1. <%????
  2. ?????String?name?=?request.getParameter("name");????
  3. ?????String?password?=?request.getParameter("password");????
  4. ????
  5. ?????UserHandler?userHandler?=?new?UserHandler();????
  6. ?????if(userHandler.authenticate(name,?password))?{????
  7. %>????
  8. <p>恭喜你,登录成功</