自己动手写web框架----2

在上一节,我们自己写的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那就自然没有用户名与密码了。

点提交之后

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

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

时间: 2024-08-08 01:28:27

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

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

本文可作为<<自己动手写struts–构建基于MVC的Web开发框架>>一书的读书笔记. 一个符合Model 2规范的web框架的架构图应该如下: Controller层的Servlet就是一个全局的大管家,它判断各个请求由谁去处理. 而各个BusinessLogic就决定具体做什么. 通过上面的图,我们能看出来核心的组件就是那个servlet,它要处理所有的请求. 那么我们就先在web.xml里配置这个servlet: <?xml version="1.0&quo

《自己动手写开源框架10》:Web界面快速开发实践

下面是一些常用的链接,供大家使用: GIT地址:https://git.oschina.net/tinyframework/tiny问题报告:https://git.oschina.net/tinyframework/tiny/issues更多内容,请看本人博客,不一样的内容,一样的精彩! 在展示过程的同时,会把相关的知识做一个充分的介绍 .一.寻找网站模板 要做网站,不能没有模板,自己不会做网页设计,咋办?问谷歌找百度呗,找了一阵,看到下面这个模板不错,就它了. http://www.toop

gsweb —— 自动动手用golang写WEB框架

最近个人项目需要用到WEB框架,考虑系统其它部分的配合首选开发语言是golang.首先go语言有很多现成WEB框架可用,例如:Beego:看了下Beego发现实现其实挺简单的,抱着学习的态度决定干一次重造轮子的事情.看看在没有任何其它WEB框架开发经验的前提下,只依据WEB应用的特征来重头设计WEB框架会是什么样子.这样的经历一定非常有趣,后续会在BLOG持续更新这个项目的进度以及一些设计上的思考:

《开源框架那点事儿20》:自己动手写前端框架

曾经发表过一篇文章:TinyAdmin前端展现框架.其在线演示路径为:http://www.tinygroup.org/tinyadmin/.应该说有很多人还是感觉兴趣的,可是因为这个是基于SmartAdmin框架改写的,尽管我们自己买了SmartAdmin的授权,可是广大用户假设要用的时候,就会有授权相关的问题,这会大大影响一些人的使用决策--尤其是会再发行的朋友. 再一个原因是SmartAdmin初看不是不错的.可是实际用起来.里面的问题比較多.对IE8基本上能够说是不兼容,尽管我们努力进行

自己动手写RPC框架到dubbo的服务动态注册,服务路由,负载均衡功能实现

RPC即远程过程调用,它的实现方式有很多,比如webservice等.框架调多了,烦了,没激情了,我们就该问自己,这些框架的作用到底是什么,来找回当初的激情. 一般来说,我们写的系统就是一个单机系统,一个web服务器一个数据库服务,但是当这单台服务器的处理能力受硬件成本的限制,是不能无限的提升处理性能的.这个时候我们使用RPC将原来的本地调用转变为调用远端的服务器上的方法,给系统的处理能力和吞吐量带来了提升. RPC的实现包括客户端和服务端,即服务的调用方和服务的提供方.服务调用方发送rpc请求

自己动手写javaEE框架-为jqgrid换换皮肤然后加到我的框架里

软件151 苏垚 今天让我倒腾半天的居然不是写我的javaEE框架,而是更换jqgrid的皮肤.我是相当的讨厌jqgrid的默认皮肤,它总让我想起一直想学而都没学过的EXTJS,看多了那种淡蓝色的皮肤太多了绝对视觉疲劳,所以这篇博文就从jqgrid换肤讲起吧,这个过程在网络上找到的资料比较少,因此我今天的博文还是很有实用价值的.不废话了,下面开始吧! 首先我们在浏览器地址栏里填入地址:http://www.trirand.com/blog/?page_id=6,这是jqgrid的下载界面,如下图

第一招:自己动手写HTTP框架介绍

我相信很多人都会质疑:网上已经有那么多开源的HTTP框架,android-async-http已经很成熟了,Stay你再来讲而且还收费有意义么. Stay在这里统一作答. HTTP作为所有app的必备功能,我觉得有必要来讲. 开源框架授之以鱼,我希望能做到授之以渔. 看看android-async-http里的issues,如果你也碰到变态需求,你是否会改,而不是等待作者帮你解. 每个人的理解能力不一样,可能看不懂源码,我希望把骨架拎出来,一个个讲解,让你弄懂它的设计思想. 可能就算你看懂了代码

自己动手写web服务器一(浏览器的访问信息)

要协议一个web服务器,需要了解http协议,下面我们来看一下当浏览器请求网张的时候向web服务器发送的数据,我使用的是ubuntu 中telent展现一个下过程. 我需要一个简单的网站来演示一下,我装了一个apache.来完成成这个过程.下面为过程展示. 其实,访问一个网站就是浏览器web服务器指定端口发送信息,然后,web服务器向浏览器发送网页的内容, 1.使用telnet连接网站 2.输入请求的页面. GET  /   HTTP/1.0 或者 GET /index.html  HTTP/1

转:自己动手写插件框架(3)

转自:http://www.devbean.net/2012/03/building-your-own-plugin-framework-3/ 编程语言的支持 在前面的章节中,我们已经了解到,如果你能够使用编译器令应用程序和插件的虚表匹配,那么就可以保持 C++ 虚表级别的兼容性:或者你可以使用 C 级别的兼容性,然后就能使用不用的编译器去构建系统,但其限制在于你只能编写纯 C 应用.这样的话,你就不能够使用前面我们在例子 IActor 中看到的那种优雅的 C++ 接口. 纯 C 实现 在纯 C