mvc结合web应用实例分析

Mvcweb应用实例分析

Login.jsp——视图部分的输入文件
success.jsp——视图部分的输出文件
failure.jsp——视图部分的输出文件
LoginBean.java——模型部分
LoginServlet.java——控制器部分
web.xml——web应用的配置文件

下面分别介绍:

1login.jsp

该功能的输入文件,用户首先访问这个文件。主要用于输入用户名和口令。
代码如下:

<%@ page contentType="text/html;charset=gb2312"%>

<script language="JavaScript">

 function isValidate(form)

 {

   // 得到用户输入的信息

   username = form.username.value;

   userpass = form.userpass.value;

   // 判断用户名长度

   if(!minLength(username,6))

   {

     alert("用户名长度小于6位!");

     form.username.focus();

     return false;

   }

   if(!maxLength(username,8))

   {

     alert("用户名长度大于8位!");

     form.username.focus();

     return false;

   }

   // 判断口令长度

  if(!minLength(userpass,6))

   {

     alert("口令长度小于6位!");

     form.userpass.focus();

     return false;

   }

   if(!maxLength(userpass,8))

   {

     alert("口令长度大于8位!");

     form.userpass.focus();

     return false;

   }

   return true;

 }

 // 验证是否满足最小长度

 function minLength(str,length)

 {

   if(str.length>=length)

     return true;

   else

     return false;

 }

 // 判断是否满足最大长度

 function maxLength(str,length)

 {

   if(str.length<=length)

     return true;

   else

     return false;

 }

</script>

<html>

 <head>

  <title>用户登陆</title>

 </head>

 <body>

  <h2>用户登录</h2>

  <form name="form1" action="login" method="post"

    onsubmit="return isValidate(form1)">

    用户名:<input type="text" name="username"> <br>

    口令:<input type="password" name="userpass"><br>

    <input type="reset" value="重置">

    <input type="submit" value="提交"><br>

  </form>

 </body>

</html>

代码中提供了客户端验证功能(用户名和口令的长度为6-8位)。验证通过之后会把请求提交给控制器Servlet

2success.jsp

登录成功之后会跳转到这个界面,界面的代码如下:

%@ page contentType="text/html;charset=gb2312"%>

<html>

 <head>

  <title>登录成功</title>

 </head>

 <body>

  <h2>${sessionScope.username}您好,欢迎登录网上书店!</h2>

 </body>

</html>

代码中使用表达式语言把登录后的用户信息显示在街面上。

3failure.jsp

登录失败后会跳转到这个界面,界面的代码如下:

<%@ page contentType="text/html;charset=gb2312"%>

<html>

 <head>

  <title>登录失败</title>

 </head>

 <body>

  <h2>用户名或者口令不正确,请<a href="login.jsp">重新登录! </a></h2>

 </body>

</html>

代码中提供了一个超链接,能够链接到登录界面。

4LoginBean.java

完成登录功能,这里假设用户名和口令相等表示登录成功。

package beans;

public class LoginBean {

  public boolean validate(String username,String userpass){

    return username.equals(userpass);

  }

}

5LoginServlet.java

该文件完成控制,主要功能可以描述如下:

①. login.jsp获取用户输入的用户名和口令;
②. 创建LoginBean的对象,调用LoginBean的方法validate
③. 根据方法返回的结果,选择success.jsp或者failure.jsp对用户响应。

完整的代码如下:

package servlets;

import java.io.IOException;

import java.io.PrintWriter;

import javax.servlet.*;

import javax.servlet.http.*;

import beans.*;

public class LoginServlet extends HttpServlet {

  public void doGet(HttpServletRequest request, HttpServletResponse response)

      throws ServletException, IOException {

    doPost(request,response);

  }

  public void doPost(HttpServletRequest request, HttpServletResponse response)

      throws ServletException, IOException {

    // 获取用户输入的用户ID和口令

    String username = request.getParameter("username");

    String userpass = request.getParameter("userpass");

    // 创建模型对象

    LoginBean loginBean = new LoginBean();

    // 调用业务方法进行验证

    boolean b = loginBean.validate(username,userpass);

    // 要转向的文件

    String forward;

    // 如果登陆成功,把用户名写入session中,并且转向success.jsp,

    // 否则转向failure.jsp

    if(b){

    // 获取session

    HttpSession session = (HttpSession)request.getSession(true);

    // 把用户名保存到session中

    session.setAttribute("username",username);

    // 目标转向文件是success.jsp

    forward = "success.jsp";

    }else{

    // 目标转向文件是failure.jsp

    forward = "failure.jsp";

    }

    // 获取Dispatcher对象

    RequestDispatcher dispatcher = request.getRequestDispatcher(forward);

    // 完成跳转

    dispatcher.forward(request,response);

  }

}

代码中把登录用户的用户信息保存在了session中,在实际应用中同样也是这样处理的。

6web.xml

主要代码是Servlet的配置,代码如下:

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.4"

  xmlns="http://java.sun.com/xml/ns/j2ee"

  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

  xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee

  http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

 <servlet>

 <description>This is the description of my J2EE component</description>

 <display-name>This is the display name of my J2EE component</display-name>

 <servlet-name>LoginServlet</servlet-name>

 <servlet-class>servlets.LoginServlet</servlet-class>

 </servlet>

 <servlet-mapping>

 <servlet-name>LoginServlet</servlet-name>

 <url-pattern>login</url-pattern>

 </servlet-mapping>

</web-app>