注册的实现与ajax(第五天)

第五天;
今天实现注册与ajax提示
ajax是一种应用技术的缩写,它的英文全称为(Asynchronous JavaScript and XML)。第一次提出这个概念的是 jesse james Garrett,在他的文章AJAX:A New Approach to Web Applications一文中收次提出了这个概念。此技术改变了传统的客户端与服务端交互的方式,使用户在浏览Web页时

无需等待数据而继续执行其他的操作,所有的数据处理将在后台进行

我们需要知道

  • ajax的用法

构思
1.进入注册页,输入要注册的用户名,如果该注册名在数据库已经有了,返回error,否则不返回
2.注册时获取到用户名,密码,姓名进行保存

1.如下图,红框中的代码规定了点击这个链接会去struts.xml寻找一个answer包下一个名叫preRegister的action;

image.png

2.所以接着我们打开struts.xml添加对应代码

    <package name="default" namespace="/answer" extends="struts-default">
       <action name="login" class="userinfoAction" method="login">
                <result name="success">/homepage/onepage.jsp</result>
                <result name="error">/error.jsp</result>
        </action>
        <action name="preRegister">
                 <result name="success">/userinfo/register.jsp</result>
        </action>
    </package>

3.按照代码,我们需要在根目录(WebRoot)新建一个文件夹userinfo同时在里面新建一个register.jsp,register.jsp的代码如下

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'index.jsp' starting page</title>
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">    
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <style type="text/css">
    #login {
        width: 400px;
        height: 250px;
        background-color: #f2f2f2;
        border:1px solid #DDDDDD;
        padding: 5px;
    }
    #login fieldset {
        border: none;
        margin-top: 10px;
    }
    #login fieldset legend {
        font-weight: bold;
    }
    #login fieldset p {
        display: block;
        height: 30px;
    }
    #login fieldset p label {
        display: block;
        float:left;
        text-align: right;
        font-size: 12px;
        width: 90px;
        height: 30px;
        line-height: 30px;
    }
    #login fieldset p input {
        display: block;
        float:left;
        border: 1px solid #999;
        width: 250px;
        height: 30px;
        line-height: 30px;
    }
    #login fieldset p input.code {
        width: 60px;
    }
    #login fieldset p img {
        margin-left: 10px;
    }
    #login fieldset p a {
        color: #057BD2;
        font-size: 12px;
        text-decoration: none;
        margin: 10px;
    }
    #login fieldset p input.btn {
        background: url("./images/login.gif") no-repeat;
        width: 98px;
        height: 32px;
        margin-left: 60px;
        color: #ffffff;
    }
    #login fieldset p input.input_focus {
        background-color: #BEE7FC;
    }
</style>
<script type="text/javascript" src="js/jquery-1.8.3.js"></script>
    <script type="text/javascript">
        $(function(){
            $("#check_registername").keyup(function(){
                $.ajax({
                        type: "get",
                        url: "answer/check_registername.action",
                        data:{//传参
                                checkregistername:$("#check_registername").val()
                            },
                        success:function(data){
                                                $("#msg").html(data);
                                            }
                        })
            });
        });
    </script>
  </head>
  
  <body>
    <form action="answer/register.action">
    <div align="center">    
        <div id="login" >
          <fieldset>
            <legend><p align="center">用户注册</p></legend>
            <p>
              <label>用户名:</label>
              <input id="check_registername" name="userinfo.uame"  type="text"  />
              <span id="msg"></span>
            </p>
            <p>
              <label>密码:</label>
              <input name="userinfo.upsw" type="password"/>
            </p>
            <p>
              <label>姓名:</label>
              <input name="userinfo.urealname" type="text"/>
            </p>
              <input name="" type="submit" class="btn"  value="注册" />
          </fieldset>
        </div>
    </div>
    </form>
  </body>
</html>

现在我么已经能跳转到注册页了
在注册页我们要完成两件事
1.对注册的用户名进行重名验证
2.完成注册功能
为完成以上功能我们需要在struts.xml添加两个action

<action name="register" class="userinfoAction" method="register">
                 <result name="success">/index.jsp</result>
</action>
<action name="checkregistername" class="userinfoAction" method="checkregistername"/>

对应action的java类也发生了变化

UserinfoAction里面要添加
    //接受注册页传来的用户名
    String checkregistername;
    public String getCheckregistername() {
        return checkregistername;
    }

    public void setCheckregistername(String checkregistername) {
        this.checkregistername = checkregistername;
    }
    /**
     * 注册
     * @return
     */
    public String register(){
        userinfoService.register(userinfo);
        return "success";
    }
    
    /**
     * 注册检测
     * @return
     */
    public void checkregistername() throws IOException {
        boolean um = userinfoService.findByUsername(checkregistername);
        PrintWriter out = ServletActionContext.getResponse().getWriter();
        if (um == false) {
            out.write("<b> error </b>");
        }
        out.flush();
        out.close();
    }
UserinfoService里面要添加
    /**
     * 进行注册
     * @param userinfo
     */
    public void register(Userinfo userinfo) {
        userinfoDAO.save(userinfo);
    }
    /**
     * 检测用户名是否存在于数据库
     * @param checkregistername
     * @return
     */
    public boolean findByUsername(String checkregistername) {
        // TODO Auto-generated method stub
        return userinfoDAO.findByUsername(checkregistername);
    }
UserinfoDAO里面要添加
    /**
     * 异步注册验证数据
     * @param uame
     * @return
     */
    public boolean findByUsername(String checkuame) {
        String hql = "from Userinfo where uame = ?";
        List<Userinfo> list = this.getHibernateTemplate().find(hql, checkuame);
        if (list != null && list.size() > 0) {
            return false;
        }else{
            return true;
        }
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,587评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,562评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 3,785评论 0 11
  • 身边人身边事,听起来觉得不可思议,见到后才发现原来更加的厉害。骚年,你认为不可能的事情实际上别人正在做着。...
    王二道阅读 418评论 0 1
  • 异国他乡的三月清晨,有点冷,有点雾,有点让人多愁善感。 这时,太阳还未完全的升起,村庄里有几户的烟囱里,就腾起了烟...
    致一阅读 301评论 0 0