在上一节,我们自己写的web框架,只能运行显示一个HelloWorld。现在我们对其进行一次加工,让他至少能运行一个登陆程序。

首先看login.jsp

<%@ page contentType="text/html; charset=UTF-8" language="java" import="java.sql.*" errorPage="" %>
<%@ page import="
    java.util.*,
    javax.servlet.*,
    javax.servlet.http.*,
    com.gc.action.User"%>
<%!public static final String _AppId = "login";%>
<%

    HashMap<String,Object> infoOut=null;
    if(request.getAttribute("infoOut") == null)
        infoOut=new HashMap<String,Object>();
    else
        infoOut=(HashMap<String,Object>)request.getAttribute("infoOut");

    String msg = infoOut.get("msg") == null ? "" : (String) infoOut
            .get("msg");
    User user = infoOut.get("user") == null ? new User()
            : (User) infoOut.get("user");
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>采用新的框架实现用户登录验证</title>

<script language=Javascript>
function submit(target, action) {
    form1.target = target;
    form1.action.value = action;
    form1.submit();
}

function check() {
    form1.forwardJsp.value="login"; //再次跳转回来
    form1.logicName.value="LoginAction";
    submit('<%="login_" + session.getId()%>','login');
}
</script>
</head>
<body leftmargin="0" topmargin="0">
               <%-- 这个action 目前没有用 我们可以随意写 --%>
    <form name="form1" action="xx.do"  method="post">
        <H3>
            <font color='red'><%=msg%></font>
        </H3>

                用户名:<input type="text" name="username"><br> <br>
                密码: <input type="text" name="password">
                    <br>
                <input type="button" name="button" value="提交" onClick="return check()">
                <input type="reset" name="button" value="重置"> 

                <%-- 这一次我们要从jsp端发起请求,设置三个参数 --%>
                <input type="hidden" name="action" value="">
                <input type="hidden" name="forwardJsp" value="">
                <input type="hidden" name="logicName"   value="">
    </form>

<script language=Javascript>
    window.name = "<%="login_"+session.getId()%>";
</script>

</body>
</html>

表现层有了,控制层我们可以复用第一节的GdServlet,现在就差模型层了。

package com.gc.action;

import java.util.HashMap;

import com.gd.action.Action;

public class LoginAction implements Action{

    public HashMap<String, Object> doAction(HashMap<String, Object> infoIn) {
        String action = (infoIn.get("action") == null) ? "" : (String) infoIn
                .get("action");
        HashMap<String, Object> infoOut = infoIn;
        if (action.equals(""))
            infoOut = this.doInit(infoIn);
        else if (action.equals("login"))
            infoOut = this.doLogin(infoIn);
        return infoOut;
    }
    /**该方法用来实现没有传入动作时要处理的内容
    * @param infoIn
    * @return HashMap
    */

    private HashMap<String, Object> doInit(HashMap<String, Object> infoIn) {
        HashMap<String, Object> infoOut = infoIn;
        infoOut.put("msg", "请输入用户名和密码");
        return infoOut;
    }

    /**该方法用来实现输出HelloWorld
    * @param infoIn
    * @return HashMap
    */

    public HashMap<String, Object> doLogin(HashMap<String, Object> infoIn){
        HashMap<String, Object> infoOut = infoIn;
        String username = (infoIn.get("username") == null) ? "" : (String)infoIn.get("username");
        String password = (infoIn.get("password") == null) ? "" : (String)infoIn.get("password");

            if ("gd".equals(username) && "123456".equals(password)) {
                infoOut.put("forwardJsp", "success");
                infoOut.put("msg", "登录成功");
            } else if ("gd".equals(username) && !"123456".equals(password)) {
                infoOut.put("msg", "密码错误");
            } else if (!"gd".equals(username) && "123456".equals(password)) {
                infoOut.put("msg", "用户名错误");
            }  else if (!"gd".equals(username) && !"123456".equals(password)) {
                infoOut.put("msg", "用户名和密码都输入错误");
            } else if ("".equals(username) && "".equals(password)) {
                infoOut.put("msg", "请输入用户名和密码");
            }

            return infoOut;

    }
}

infoOut.put(“forwardJsp”, “success”);

如果登陆成功,就返回success.jsp。

注意:本来forwardJsp在login.jsp里就设置了,是login。这里的逻辑是一旦成功登陆,就返回success。

success.jsp

<%@ page contentType="text/html; charset=GBK" language="java" import="java.sql.*" errorPage="" %>
<%@ page import="java.sql.*,java.util.*,javax.servlet.*,
         javax.servlet.http.*,java.text.*,java.math.*,com.gd.mvc.io.InfoInAndOut,com.gd.mvc.io.impl.GdInfoInAndOut"
%>
<%! public static final String _AppId = "login"; %>
<%
HashMap<String,Object> infoOut=null;
if(request.getAttribute("infoOut") == null)
    infoOut=new HashMap<String,Object>();
else
    infoOut=(HashMap<String,Object>)request.getAttribute("infoOut");
    String msg = infoOut.get("msg") == null ? "" : (String)infoOut.get("msg");
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>采用新的框架实现用户注册验证</title>

</head>
<body leftmargin="0" topmargin="0">
<form name="form1" action="/myApp/do" method="post">
<H3><font color='red'><%=msg%></font><H3>

    <input type="hidden" name="action" value="">
</form>
<script language=Javascript>
    window.name = "<%="login_"+session.getId()%>";
</script>
</body>
</html>

咱们看看效果:



我直接访问了servlet,没有经过jsp那就自然没有用户名与密码了。



点提交之后



别的效果,我就不贴图了,大家应该都能想出来。

在上面的基础上,我们输入下面的地址:

http://localhost:8700/Struts2Demo/gc/df/index.do

肯定是404notfind。

其实也很容易理解

Action action=null;
    String servletPath=req.getServletPath();
    String systemPath=servletPath.split("/")[1];  //systemPath 就是gc
    String logicActionName=req.getParameter("logicName");  // logicActionName 就是HelloWorldAction
    String actionPath=getActionPath(systemPath, logicActionName);
    action=(Action) Class.forName(actionPath).newInstance();
    Map<String, Object> infoOut=action.doAction(infoIn);   

    private String getActionPath(String systemPath,String actionName){
        String actionPath="";
        if (systemPath!=null)
            actionPath="com."+systemPath+".action."+actionName;

        return actionPath;
    }

在上例中getActionPath返回的是com.gc.action.null。肯定报错ClassNotFound。

其实我们可以把getActionPath改成如下的样子:

private String getActionPath(String systemPath,String actionName){
        String actionPath="";
        if (actionName!=null) {
            actionPath="com."+systemPath+".action."+actionName;
        }else {
            actionPath="com.gd.action.GdAction";
        }
        return actionPath;
    }

在这个GdAction里我们放置一个默认的访问路径。

GdAction.java
    public HashMap<String, Object> doAction(HashMap<String, Object> infoIn) {
        String action = (infoIn.get("action") == null) ? "" : (String) infoIn
                .get("action");
        HashMap<String, Object> infoOut = new HashMap<String, Object>();
        if (action.equals(""))
            infoOut = this.doInit(infoIn);
        return infoOut;
    }

    /**
     * 该方法设置用户登录时页面的初始信息
     *
     * @param infoIn
     * @return HashMap
     */

    private HashMap<String, Object> doInit(HashMap<String, Object> infoIn) {
        HashMap<String, Object> infoOut = infoIn;

        infoOut.put("forwardJsp", "../../jsp/welcome");
        return infoOut;
    }
OK搞定。

我们的welcom.jsp内容很简单,就是一个欢迎页面嘛:

<%@ page contentType="text/html; charset=GBK" language="java" import="java.sql.*" errorPage="" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>欢迎您使用gf的Web框架</title>
</head>

<body center>
<H1><font color='red'>
欢迎您使用gf的Web框架
</font>
</H1>
</body>
</html>

集腋成裘,聚沙成塔。慢慢来,在下一节,我们继续完善我们的框架。

自己动手写web框架----2的更多相关文章

  1. 自己动手写web框架----1

    本文可作为<<自己动手写struts–构建基于MVC的Web开发框架>>一书的读书笔记. 一个符合Model 2规范的web框架的架构图应该如下: Controller层的Se ...

  2. (新)自己动手写ORM框架(1)-增删查改的使用

    之前写过一个系列文章自己动手写ORM框架,经过在多个项目的中的使用,对这套代码进行了许多改进,下面是使用方法: 新增学员信息代码预览: DBHelper db = DBHelper.getInstan ...

  3. 自己动手写Spring框架--IOC、MVC

    对于一名Java开发人员,我相信没有人不知道 Spring 框架,而且也能够轻松就说出 Spring 的特性-- IOC.MVC.AOP.ORM(batis). 下面我想简单介绍一下我写的轻量级的 S ...

  4. 自己动手写Android框架-数据库框架

    大家在工作中基本上都有使用到数据库框架 关系型:ORMLite,GreenDao 对象型:DB4O,Perst 这些数据库用起来都非常的简单,对于我们Android上来说这些数据库足够我们使用了,但是 ...

  5. 自己动手做Web框架—MVC+Front Controller

    在我前面一篇博文<逃脱Asp.Net MVC框架的枷锁,使用Razor视图引擎>发表之后,很多人关心,脱离了之后怎么办?那么这可以说是它的续篇了. 同时,这也是eLiteWeb开源软件的一 ...

  6. 手写web框架之加载Controller,初始化框架

    1,加载Controller     我们需要创建 一个ControllerHelper类,让它来处理下面的逻辑:      通过ClassHelper我们可以获取所有定义了Controller注解的 ...

  7. 手写web框架之实现依赖注入功能

    我们在Controller中定义了Service成员变量,然后在Controller的Action方法中调用Service成员变量的方法,那么如果实现Service的成员变量? 之前定义了@Injec ...

  8. 自己动手写ORM框架

    提起ORM框架,大家都很熟悉,网上流行的ORM框架有很多,其中出名的有一些,不出名的更是数不胜数. 下面是自己实现的一个简单的ORM框架,实现了常用的增删查改功能,供大家研究ORM实现原理. 功能描述 ...

  9. [置顶] 自己动手写Web容器之TomJetty之六:动态页面引入

    传送门 ☞ 1.Web服务内功经脉 传送门 ☞ 2.让服务动起来 传送门 ☞ 3.掀起请求盖头来 传送门 ☞ 4.静态页面起步 传送门 ☞ 5.包装请求参数 在上一节,我们已经完成了TomJetty服 ...

随机推荐

  1. 安卓高级9 shareSDK 第三方登陆和分享Mob

    ShareSDK推荐此官网地址 官网注册和申请key流程 注册 略 进入后台创建应用得到可以 下载SDK 解压下载的压缩包 第三方平台申请key 如果你想申请QQ登陆或者分享需要去腾讯开发者申请,申请 ...

  2. UDP单播和组播使用SO_REUSEADDR 测试结果

    UDP单播通信 一. 预置条件 A.B在同一台机器,网络中存在往A.B所在的机器的8888端口发送单播UDP数据 A:端口复用绑定在端口8888上 B:端口复用绑定在端口8888上操作步骤:(1)先启 ...

  3. IntelliJ Idea 设置 Dialyzer

    IntelliJ Idea 设置 Dialyzer(金庆的专栏)Erlang开发使用IDEA IDE可以设置外部工具Dialyzer, 然后就可以直接Tools->External Tools ...

  4. pdflush的工作原理

    大家知道,在linux操作系统中,写操作是异步的,即写操作返回的时候数据并没有真正写到磁盘上,而是先写到了系统cache里,随后由pdflush内核线程将系统中的脏页写到磁盘上,在下面几种情况下,系统 ...

  5. Android中的语言和字符串资源

    在任何情况下,从您的应用代码中提取 UI 字符串并将其存放在外部文件中都是个好办法.Android 在每个 Android 项目中都提供一个资源目录,从而简化了这一过程. 如果您是使用 Android ...

  6. 安卓Toast自定义及防止重复显示

    Toast是安卓系统中,用户误操作时或某功能执行完毕时,对用户的一种提示,它没有焦点,并在一定时间内会消失,但用户连续误操作(如登录时,密码错误)多次时,则会有多个Toast被创建,系统会把这些toa ...

  7. Android判断当前系统语言

    Android获取当前系统语言 getResources().getConfiguration().locale.getCountry() 国际化常用语言 中文: getResources().get ...

  8. Latex居中

    居中文本 环境:\begin{center} 第一行\\第二行\\...第n行 \end{center}.可以用\\[长度]来插入可以省略的额外行间距.在一个环境内部,可以用命令\centering来 ...

  9. C语言与java语言中数据类型的差别总结

    在学习java的时候,看到char ch =  '男' ; 我就觉得很奇怪,char类型不是占用一个字节吗?为什么定义成一个汉字被说成是一个字符了? 原来,在C语言中,char在32位操作系统下占用1 ...

  10. [ExtJS5学习笔记]第九节 Extjs5的mvc与mvvm框架结构简介

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/38537431 本文作者:sushengmiyan ------------------ ...