`

《研磨struts2》 第二章 Struts2的HelloWorld 之从Servlet+JSP+JavaBean实现MVC开始

阅读更多

2.3.Struts2的HelloWorld 之从Servlet+JSP+JavaBean实现MVC开始

2.3.1  起点概述

考虑到大部分朋友都是有一定经验的web开发者,因此从Servlet+JSP+JavaBean实现MVC开始,再过渡到Struts2的开发,这样能让大家把以前的知识自然迁移到Struts2上,使得学习曲线变得平滑。

说明一下,由于本机的8080端口被别的软件占用了,所以把tomcat改到了9080端口,以后在程序里出现的时候,也将是9080。

       注意:如果要修改Tomcat的端口,需要修改Tomcat中的server.xml配置文件,并且应该在创建动态工程之前进行修改。请找到Tomcat的安装目录下的conf子目录,找到其中的server.xml,在这个文件中搜索8080,会找到相应的配置部分:

java代码:
  1. <Connector port="8080" protocol="HTTP/1.1"   
  2.                connectionTimeout="20000"   
  3.                redirectPort="8443" />  

把上面配置中的8080改为9080即可。

比如Tomcat安装在E:\Struts2\server\apache-tomcat-6.0.29,因此需要修改的配置文件在E:\Struts2\server\apache-tomcat-6.0.29\conf\server.xml

2.3.2  建立动态的web工程

为了使用eclipse-jee-europa中各种与Web开发相关的功能,先来建立一个动态的web工程。

(1)在Package Expolorer视图中的空白处点右键,选择【New】->【Project】,在弹出页面选中web文件夹下的Dynamic Web Project选项,如下界面。

 

图2.10 选择新建动态web工程

(2)选择其中的”Dynamic Web Project”,点击Next。会跳转到如下界面。

图2.11 建立web工程的配置1

(3)输入项目名HelloWorld之后,然后选择Target Runtime的值为Apache Tomcat v6.0 ,这样eclipse会帮你导入tomcat下所有的jar包,然后点击Next,得到如下界面:

图2.12 建立web工程的配置2

(4)使用默认的配置,点击Next,得到如下界面:

图2.13 建立web工程的配置3

(5)修改Context Root的值为小写的helloworld,默认是工程名字,是“HelloWorld”。至于WebContent改不改,就看你的习惯了,用默认的就好了。

       点击Finish,一个动态的Web工程就创建好了。

2.3.3  配置工程运行环境

在Servers视图中空白处点击右键,选择【New】->【Server】,得到如下界面。

 

图2.14 选择新建服务器

       选择“Tomcat v6.0 Server”选项,点击Next,得到如下界面:

图2.15 选择web工程

选择HelloWorld工程,点击Add按钮,把工程添加到右边的列表,然后点击Finish,就完成了配置。这时候,在Package Explorer里会增加一个叫Servers的工程,这是eclipse自动管理的,暂时不需要修改这个工程中的任何文件。

2.3.4  编写JavaBean

用Model2来实现MVC,模型部分是使用JavaBean来实现的,而且视图和控制器之间的数据交互也是通过JavaBean来实现的,因此先来把JavaBean编写好。

这里不需要实现什么复杂的业务逻辑,只是一个简单的数据封装model,有三个属性,分别是account、password和submitFlag,其中的submitFlag是用来封装提交请求的标记,为他们提供相应的getter和setter方法,示例代码如下:

 

java代码:
  1. package cn.javass.hello.servletimpl.vo;  
  2. public class HelloWorldModel {  
  3.     private String account;  
  4.     private String password;  
  5.     private String submitFlag;  
  6.     public String getAccount() {  
  7.         return account;  
  8.     }  
  9.     public void setAccount(String account) {  
  10.         this.account = account;  
  11.     }  
  12.     public String getPassword() {  
  13.         return password;  
  14.     }  
  15.     public void setPassword(String password) {  
  16.         this.password = password;  
  17.     }  
  18.     public String getSubmitFlag() {  
  19.         return submitFlag;  
  20.     }  
  21.     public void setSubmitFlag(String submitFlag) {  
  22.         this.submitFlag = submitFlag;  
  23.     }  
  24.     public String toString(){  
  25.         return "account="+account+",password="+password  
  26.                              +",submitFlag="+submitFlag;  
  27.     }  
  28.     /** 
  29.      * 示例方法,表示可以执行业务逻辑处理的方法, 
  30.      * 比如对数据进行增删改查的操作等等 
  31.      */  
  32.     public void businessExecute(){  
  33.         System.out.println("正在进行业务处理=======>");  
  34.     }  
  35. }  

2.3.5  编写Servlet

Servlet在Model2中的作用相当于MVC中的控制器,这里只是一个简单的实现,基本的实现主要有如下工作:

  • 收集request传递过来的参数。
  • 把这些参数组织成为模型需要的类型
  • 调用模型进行逻辑功能处理
  • 选择下一个页面,先准备好下一个页面需要的数据,然后转向下一个页面。

       先来建立Servlet,在src下面先建包cn.javass.hello.servletimpl.servlet,然后在这个包下新建一个类HelloWorldServlet,这个类继承HttpServlet,并重写父类的doPost和doGet方法,其中doGet方法只是转调一下自己的doPost方法即可。在Servlet的doPost方法中,完成上面提到的工作。代码示例如下:

 

java代码:
  1. package cn.javass.hello.servletimpl.servlet;  
  2. import java.io.IOException;  
  3. import javax.servlet.ServletException;  
  4. import javax.servlet.http.HttpServlet;  
  5. import javax.servlet.http.HttpServletRequest;  
  6. import javax.servlet.http.HttpServletResponse;  
  7. import cn.javass.hello.servletimpl.vo.HelloWorldModel;  
  8.   
  9. public class HelloWorldServlet extends HttpServlet {  
  10.     protected void doGet(HttpServletRequest request, HttpServletResponse response)  
  11.             throws ServletException, IOException {  
  12.         doPost(request, response);  
  13.     }  
  14.     protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{  
  15.         //1:收集参数,不用做了,通过JavaBean传入  
  16.         //2:组织参数,也不用作了,已经组织好了,把数据封装成了JavaBean  
  17.         //这里只需要获取封装好的JavaBean即可  
  18.         HelloWorldModel hwm = (HelloWorldModel)request.getAttribute("helloModel");  
  19.           
  20.         //3:调用模型的逻辑功能处理  
  21.         hwm.businessExecute();  
  22.         //这里简单的输出一下传入的参数  
  23.         System.out.println("用户输入的参数为==="+hwm);  
  24.           
  25.         //4:根据逻辑处理的结果来选择下一个页面,这里直接选择转向欢迎页面  
  26.         //4.1:先把需要欢迎页面显示的数据准备好  
  27.         request.setAttribute("hwm",hwm);  
  28.         //4.2:转向欢迎页面  
  29.         request.getRequestDispatcher("/servletimpl/welcome.jsp").forward(request,response);  
  30.     }  
  31. }  

非常简单,对吧,接下来看看如何配置这个Servlet。

2.3.6  配置web.xml

在web.xml中,配置上面做好的Servlet,配置示例如下:


java代码:
  1. <servlet>  
  2.         <servlet-name>hello</servlet-name>  
  3.         <servlet-class>cn.javass.hello.servletimpl.servlet.HelloWorldServlet</servlet-class>  
  4.     </servlet>  
  5.         
  6.     <servlet-mapping>  
  7.         <servlet-name>hello</servlet-name>  
  8.         <url-pattern>/hello</url-pattern>  
  9.     </servlet-mapping>  

配置分为<servlet>元素和<servlet-mapping>元素,它们都有一个子元素<servlet-name>,而<servlet>元素和<servlet-mapping>元素的<servlet-name>子元素里面注册的名字必须一样。<servlet>元素的子元素<servlet-class>用来注册Servlet类的全类名,也就是包的全路径再加上类名称,而<servlet-mapping>元素的<url-pattern>元素指明了这个Servlet响应哪些URL对应的请求。

2.3.7  编写登录页面

在项目的WebContent文件夹下创建一个servletimpl的文件夹,然后在servletimpl文件夹上右击,选择【New】->【Other】->【JSP】,创建一个名称为login的jsp页面,然后修改里面的“ISO-8859-1”为“gb2312”。

       登录页面提供让用户填写用户名和密码的表单,用户填写好过后,可以点击提交按钮来向Servlet发出登录请求,示例代码如下。

 

java代码:
  1. <%@ page language="java" contentType="text/html; charset=gb2312"  
  2.     pageEncoding="gb2312"%>  
  3. <html>  
  4. <head>  
  5. <meta http-equiv="Content-Type" content="text/html; charset=gb2312">  
  6. <title>Insert title here</title>  
  7. </head>  
  8. <body>  
  9. <jsp:useBean id="helloModel" class="cn.javass.hello.servletimpl.vo.HelloWorldModel" scope="request"></jsp:useBean>  
  10. <jsp:setProperty name="helloModel" property="*"/>  
  11.   
  12. <%  
  13.     if("login".equals(helloModel.getSubmitFlag())){  
  14. %>  
  15.     <jsp:forward page="/hello"></jsp:forward>  
  16. <%         
  17.     }  
  18. %>  
  19.   
  20. <form action="/helloworld/servletimpl/login.jsp" method="post">  
  21.     <input type="hidden" name="submitFlag" value="login"/>  
  22.     账号:<input type="text" name="account"><br>  
  23.     密码:<input type="password" name="password"><br>  
  24.     <input type="submit" value="提交">  
  25. </form>  
  26.   
  27. </body>  
  28. </html>  

说明一下:<form>元素的action属性用来指定由谁来进行响应,由于这里使用JavaBean来收集页面的数据,因此需要先提交到本页面,然后再转向相应的servlet进行处理,其中的“/helloworld”为这个工程的web上下文名,而“/login”是这个Servlet在这个web工程中的资源名,和web.xml中的配置要对应(就是<servlet-mapping>元素的子元素<url-parttern>中的值)。

提示:为了方便中文的处理,在今后的学习中统一采用gb2312编码,有些朋友可能习惯统一采用utf-8,都没有问题,只要全部统一起来,处理中文的时候就会比较方便。

2.3.8  编写欢迎页面

欢迎页面是完成登录功能过后跳转到的页面,用来显示欢迎信息,非常简单,只是简单的把需要展示的信息输出到页面上。

 

java代码:
  1. <%@ page language="java" contentType="text/html; charset=gb2312"  
  2.     pageEncoding="gb2312"%>  
  3. <html>  
  4. <head>  
  5. <meta http-equiv="Content-Type" content="text/html; charset=gb2312">  
  6. <title>Insert title here</title>  
  7. </head>  
  8. <body>  
  9. <jsp:useBean id="hwm" class="cn.javass.hello.servletimpl.vo.HelloWorldModel" scope="request"></jsp:useBean>  
  10.   
  11. 欢迎账号为<%=hwm.getAccount() %>的朋友来访  
  12. </body>  
  13. </html>  

2.3.9  测试示例

       要测试上面写的示例,需要先启动tomacat服务器,先选中Servers视图的里面的“Tomcat v6.0 Server at localhost”选项,然后点击start的按钮,则会启动tomcat6.0,如下图所示:

 

图2.16 启动tomcat

等几秒钟,tomcat启动的信息输出会出现在Console视图中,这就表示tomcat启动成功了。

       当Tomcat正常启动后,在浏览器窗口中输入如下地址并运行:http://localhost:9080/helloworld/servletimpl/login.jsp,会出现登录页面。如下所示:

图2.17 访问登录页面

在登录页面输入账号和密码,点击提交,则会跳转到相应的HelloWorldServlet。 HelloWorldServlet会先接收请求中的参数,然后在后台输出你刚刚输入的数据,后台输出如下所示:

 

java代码:
  1. 正在进行业务处理=======>  
  2. 用户输入的参数为===account=test,password=test,submitFlag=login  

接着HelloWorldServlet会把这些数据设置到request中,作为共享的数据传递给下一个页面,接下来就该跳转到下一个页面welcome.jsp,也就是欢迎页面了。欢迎页面会把HelloWorldServlet中传递过来的数据,输出到页面上。如下图所示:

 

2.3.10  中文处理

示例做到这里,好像已经可以很好的工作了,但是,如果在账号里输入“中文”,会发现后台输出的信息和欢迎页面接收到的参数都是乱码,如下所示:

 

java代码:
  1. 正在进行业务处理=======>  
  2. 用户输入的参数为===account=????,password=test,submitFlag=login  

后台输出接收到的参数是乱码,再看看页面上的表现,如下图所示:

图2.19 欢迎页面接收到的参数也是乱码

遇到中文问题了,该怎么处理呢?

在实际项目里会使用一个Filter来解决Tomcat的中文问题,这里不去讨论Filter的写法,在Tomcat的包中就有一个写好的处理字符集的filter,位置在下载的Tomcatd的zip包下\webapps\examples\WEB-INF\classes\filters文件夹下面,名称是SetCharacterEncodingFilter.java。

为了示例简单,去掉了所有的注释,代码如下:

 

java代码:
  1. public class SetCharacterEncodingFilter implements Filter {  
  2.     protected String encoding = null;  
  3.     protected FilterConfig filterConfig = null;  
  4.     protected boolean ignore = true;  
  5.   
  6.     public void destroy() {  
  7.         this.encoding = null;  
  8.         this.filterConfig = null;  
  9.     }  
  10.   
  11.     public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain)    throws IOException, ServletException {  
  12.         if (ignore || (request.getCharacterEncoding() == null)) {  
  13.             String encoding = selectEncoding(request);  
  14.             if (encoding != null)  
  15.                 request.setCharacterEncoding(encoding);  
  16.         }  
  17.         chain.doFilter(request, response);  
  18.     }  
  19.   
  20.     public void init(FilterConfig filterConfig) throws ServletException {  
  21.                 this.filterConfig = filterConfig;  
  22.         this.encoding = filterConfig.getInitParameter("encoding");  

 

java代码:
  1. String value = filterConfig.getInitParameter("ignore");  
  2.        if (value == null)  
  3.            this.ignore = true;  
  4.        else if (value.equalsIgnoreCase("true"))  
  5.            this.ignore = true;  
  6.        else if (value.equalsIgnoreCase("yes"))  
  7.            this.ignore = true;  
  8.        else  
  9.            this.ignore = false;  
  10.    }  
  11.    protected String selectEncoding(ServletRequest request) {  
  12.        return (this.encoding);  
  13.    }  
  14.    

然后在web.xml中进行配置,示例如下:

 

java代码:
  1. <filter>  
  2.     <filter-name>encoding</filter-name>  
  3.     <filter-class>filters.SetCharacterEncodingFilter</filter-class>  
  4.     <init-param>  
  5.         <param-name>encoding</param-name>  
  6.         <param-value>gb2312</param-value>  
  7.     </init-param>  
  8.   </filter>  
  9.     
  10.   <filter-mapping>  
  11.     <filter-name>encoding</filter-name>  
  12.     <url-pattern>/*</url-pattern>  
  13.   </filter-mapping>  

 

再次运行示例,会发现已经可以正常使用中文了。

私塾在线网站原创《研磨struts2》系列

转自请注明出处:【http://sishuok.com/forum/blogPost/list/0/4012.html

欢迎访问http://sishuok.com获取更多内容

7
1
分享到:
评论
12 楼 dexuter 2013-08-09  
妈蛋,什么代码
11 楼 ekian 2012-12-27  
这篇太误导了。。。
10 楼 黑伤魂 2012-07-26  
liguocai2009 写道
非常烂的代码。连续访问两次login.jsp居然只是为了封装请求参数!封装请求参数应该在filter那里做,或者在C那里做,而不是VIEW,楼主懂?

而且用forward导致登陆后的地址还是login.jsp,非常不友好,这里该用sendRedirect


楼主这段代码的确有点怪异……
9 楼 黑伤魂 2012-07-26  
liguocai2009 写道
更让人匪夷所思的是,为什么要加个servletimpl目录?难道servlet接口是你写的?莫名其妙


有点较真了吧……只不过是个名字而已……况且,好像也没什么命名的问题吧……
一般实现接口是在后面加impl的。虽然这里其实是继承,但是意思就这么个意思。。。
8 楼 liguocai2009 2012-07-21  
还有乱码的问题没有分析清楚。TOMCAT默认把所有字码编码后的字节都当做是ISO8859-1,所以会出现乱码。如果不用编码过滤器,用new String(str.getBytes("ISO8859-1"),"gbk")也可以正确显示。
7 楼 liguocai2009 2012-07-21  
楼主对与概念的把握还是很到位的,但是我还是强烈建议把这样这一章的代码重写,免得误导新人
6 楼 liguocai2009 2012-07-21  
更让人匪夷所思的是,为什么要加个servletimpl目录?难道servlet接口是你写的?莫名其妙
5 楼 liguocai2009 2012-07-21  
非常烂的代码。连续访问两次login.jsp居然只是为了封装请求参数!封装请求参数应该在filter那里做,或者在C那里做,而不是VIEW,楼主懂?

而且用forward导致登陆后的地址还是login.jsp,非常不友好,这里该用sendRedirect
4 楼 hml988 2012-07-20  
very good!
3 楼 ezwuhai 2012-06-24  
补充一下,我运行了代码一直都停留在login.jsp 页面,没有变化,是什么情况?
2 楼 ezwuhai 2012-06-24  
我弱弱的问下,第一次在login.jsp页面点击 “提交”按钮时, submitFlag 的值为login,通过post方式传值,传给谁了? 页面还是跳转login.jsp ,那么helloModel.getSumbitFlag()的值是怎么来滴呢? 为什么不直接通过getAttribute转给 servlet呢?
1 楼 ezwuhai 2012-06-24  

相关推荐

    jsp+servlet+javaBean实现MVC源码

    jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+...

    jsp+servlet+javaBean实现MVC-jspmvc.zip

    jsp+servlet+javaBean实现MVC_jspmvcjsp+servlet+javaBean实现MVC_jspmvcjsp+servlet+javaBean实现MVC_jspmvcjsp+servlet+javaBean实现MVC_jspmvcjsp+servlet+javaBean实现MVC_jspmvcjsp+servlet+javaBean实现MVC_...

    [其他类别]jsp+servlet+javaBean实现MVC_jspmvc.zip

    [其他类别]jsp+servlet+javaBean实现MVC_jspmvc [其他类别]jsp+servlet+...[其他类别]jsp+servlet+javaBean实现MVC_jspmvc[其他类别]jsp+servlet+javaBean实现MVC_jspmvc[其他类别]jsp+servlet+javaBean实现MVC_jspmvc

    jsp+servlet+javaBean实现MVC

    jsp+servlet+javaBean实现MVC jsp+servlet+javaBean实现MVCjsp+servlet+javaBean实现MVCjsp+servlet+javaBean实现MVCjsp+servlet+javaBean实现MVCjsp+servlet+javaBean实现MVCjsp+servlet+javaBean实现MVCjsp+...

    其他类别jsp+servlet+javaBean实现MVC-jspmvc

    [其他类别]jsp+servlet+javaBean实现MVC_jspmvc[其他类别]jsp+servlet+javaBean实现MVC_jspmvc[其他类别]jsp+servlet+javaBean实现MVC_jspmvc[其他类别]jsp+servlet+javaBean实现MVC_jspmvc[其他类别]jsp+servlet+...

    JSP源码——jsp+servlet+javaBean实现MVC_jspmvc.zip

    JSP源码——jsp+servlet+javaBean实现MVC_jspmvc.zip

    其他类别jsp+servlet+javaBean实现MVC-jspmvc.rar

    [其他类别]jsp+servlet+javaBean实现MVC_jspmvc.rar[其他类别]jsp+servlet+javaBean实现MVC_jspmvc.rar[其他类别]jsp+servlet+javaBean实现MVC_jspmvc.rar[其他类别]jsp+servlet+javaBean实现MVC_jspmvc.rar[其他...

    (Servlet+JSP+JavaBean实现)用户注册和登陆

    Servlet+JSP+JavaBean(MVC)模式适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp负责数据显示,javabean负责封装数据。 Servlet+JSP、JavaBean模式程序各个模块之间层次清晰,web开发推荐采用此...

    基于Servlet+JSP+JavaBean开发模式(MVC) 用户注册登陆模式.7z

    (基于MVC模式下web端的开发,servlet负责处理用户请求,jsp负责数据显示,javabean负责封装数据。 Servlet+JSP+JavaBean模式程序各个模块之间层次清晰) 仅供初学者参考,内有文档注释,部分细节不懂者,留言即可

    javaWEB项目:新生管理系统(Servlet+JSP+JavaBean).zip

    javaWEB项目:新生管理系统(Servlet+JSP+JavaBean) javaWEB项目:新生管理系统(Servlet+JSP+JavaBean) javaWEB项目:新生管理系统(Servlet+JSP+JavaBean) javaWEB项目:新生管理系统(Servlet+JSP+JavaBean) ...

    Jsp+Servlet+JavaBean 实现MVC模式的留言本

    Jsp+Servlet+JavaBean 实现MVC模式的留言本 声明:本留言本所有源代码开源,使用者可以自由修改和传播,但仅限于非商业用途。 作者:梁龙 博客:http://www.lianglong.net.cn 由于这是本人学习JAVA的第一个项目,...

    JSP+Servlet+JavaBean制作简单留言板

    JSP+Servlet+JavaBean制作简单留言板

    登录和注册的jsp页面+servlet+javaBean

    登录和注册的jsp页面+servlet+javaBean登录和注册的jsp页面+servlet+javaBean登录和注册的jsp页面+servlet+javaBean登录和注册的jsp页面+servlet+javaBean登录和注册的jsp页面+servlet+javaBean登录和注册的jsp页面+...

    超市管理系统 完整版(MVC:JSP+Servlet+javaBean)

    Servlet, JSP 本系统实现了商品管理、员工管理、供应商管理和管理员管理,管理员可以对上架商品、库存商品、新增商品、员工信息、员工、供应商、供应商分类进行的添加、删除、修改、查询操作。 超级管理员对...

    MODEL 2 的登录功能实现 (servlet+jsp+javabean)

    MEDEL 2 servlet+jsp+javabean 实际上view并没有使用jsp,只是简单是使用了html 可以把这个看做是struts的入门教程 理解起来较为容易 由于使用JDBC native bridge,使用请先安装MSSQL 2000 SP3或SP4;并下载驱动...

    JAVA 语言 使用 jsp+servlet+javaBean实现MVC源码

    jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+servlet+javaBean实现MVC源码 jsp+...

Global site tag (gtag.js) - Google Analytics