Ajax的MVC架构设计

前端之家收集整理的这篇文章主要介绍了Ajax的MVC架构设计前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

利用Ajax实现MVC模式

1)实现View层

创建index.jsp页,在其中放置一个用于收集用户输入会员名和密码的表单。

并将存放在该表单单元格的ID属性设置为login

<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
<html>
<head>
<Meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title> 利用Ajax实现MVC模式</title>
<link href="Css/style.css" rel="stylesheet">
<script language="javascript" src="JS/fun.js"></script>
</head>

<body>

<table width="793" height="829" border="0" align="center" cellpadding="0" cellspacing="0" background="images/bg.jpg">
  <tr>
    <td valign="top"><table width="100%" height="309" border="0" cellpadding="0" cellspacing="0">
      <tr>
        <td width="3%" height="206"></td>
        <td width="20%"></td>
        <td width="77%"></td>
      </tr>
      <tr>
        <td height="103"></td>
        <td valign="top" id="login">
<form name="form1" action="" onSubmit="checkU(form1);return false">
			  <table width="100%"  border="0" cellpadding="0" cellspacing="0">
                <tr>
                  <td height="24">会员名
                    <input name="username" type="text" class="txt_grey" id="username" size="16"></td>
                </tr>
                <tr>
                  <td height="24">密码
                    <input name="PWD" type="password" class="txt_grey" id="PWD" size="16" onKeydown="if(event.keyCode==13) form1.submit();"></td>
                </tr>
                <tr>
                  <td height="31">
                    <input name="Button" type="button" class="btn_grey" value="注册">
                    
                    <input name="Submit2" type="submit" class="btn_grey" value="登录"> 
					<input name="Submit3" type="reset" class="btn_grey" value="重置"></td>
                </tr>
              </table>
		    </form>		
		</td>
        <td></td>
      </tr>
    </table></td>
  </tr>
</table>
</body>
</html>

编写javascript文件fun.js ,用于通过XMLHttpResult对象以一部方式发送请求并通过XMLHttpRequest对象的onreadystatechange属性监听更新数据,然后更具实际情况显示赶回的结果
/**
 * Ajax框架
 */    
	var http_request = false;
    function createRequest(url) {
        http_request = false;
        if (window.XMLHttpRequest) {     // Mozilla浏览器
            http_request = new XMLHttpRequest();
            if (http_request.overrideMimeType) {
                http_request.overrideMimeType('text/xml');     //设置MIME类别
            }
        } else if (window.ActiveXObject) {     // IE浏览器
            try {
                http_request = new ActiveXObject("Msxml2.XMLHTTP");
            } catch (e) {
                try {
                    http_request = new ActiveXObject("Microsoft.XMLHTTP");
               } catch (e) {}
            }
        }
        if (!http_request) {
            alert("不能创建XMLHttpRequest对象实例!");
            return false;
        }
        http_request.onreadystatechange = getResult;     //调用返回结果处理函数
        http_request.open('POST',url,true);
		http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
		var formData ="";
		var elem = "";
		for(var i=0;i<form1.elements.length;i++){
			element = form1.elements[i];
			if(formData != ''){
				formData += '&';
			}
			formData += element.name+"="+element.value;
		}
        http_request.send(formData);
    }
    function getResult() {
        if (http_request.readyState == 4) {     // 判断请求状态
            if (http_request.status == 200) {     // 请求成功,开始处理返回结果
                deal(http_request.responseText);      //调用deal()方法处理返回结果
            } else {     //请求页面错误
                alert("您所请求的页面错误!");
            }
        }
    }
	function deal(result){
			if(result=="err"){
				alert("您输入的会员名称或密码错误,请重新输入!");
			}else{
				login.innerHTML=result;
			}
	}

	//表单验证
	function checkU(myform){
	if(myform.username.value==""){
		alert("请输入会员名!");myform.username.focus();return false;
	}
	if(myform.PWD.value==""){
		alert("请输入密码!");myform.PWD.focus();return false;
	}
	createRequest("loginservlet");
	}

2)实现control层

创建一个类LoginServlet,该类继承HttpServlet类,在其中编写doGet()和doPost()方法,用于调用Model层中的编写check()方法

package com.xhd;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class LoginServlet extends HttpServlet {

	public void doGet(HttpServletRequest request,HttpServletResponse response)
			throws ServletException,IOException {
		String username=new String(request.getParameter("username").getBytes("iso-8859-1"),"utf-8");   //此处需要进行转码,否则将产生中文乱码
		String pwd=new String(request.getParameter("PWD").getBytes("iso-8859-1"),"utf-8");
		DealModel dealModel=new DealModel();
		String result=dealModel.check(username,pwd);
		response.setContentType("text/html");
		response.setCharacterEncoding("utf-8");
		System.out.println("返回结果:"+result);
		PrintWriter out = response.getWriter();
		out.print(result);
		out.flush();
		out.close();
	}
	public void doPost(HttpServletRequest request,IOException {
		doGet(request,response);
	}
}

3)创建web.xml
<?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>com.xhd.LoginServlet</servlet-class>
  </servlet>

  <servlet-mapping>
    <servlet-name>LoginServlet</servlet-name>
    <url-pattern>/loginservlet</url-pattern>
  </servlet-mapping>
</web-app>

4)实现Model层

创建一个类DealModel,在其中编写用于验证会员身份的方法check().

package com.xhd;

public class DealModel {
	public String check(String username,String pwd){
		String result="";
		System.out.println(username);
		if(username.equals("mr")){
			if(pwd.equals("mrsoft")){
				result="登录成功!<br>当前登录会员:<br>"+username;
			}else{
				result="err";
			}
		}else{
			result="err";
		}
		return result;
	}

}




猜你在找的Ajax相关文章