ssh整合问题总结--使用struts2+Ajax+jquery验证用户名是否已被注册

简介:   在用户模块中的用户注册需求上,通常要进行用户名是否已被注册的验证,今天正好写了这个需求,把详细代码和所遇到的问题贴过来.在使用struts2+ajax时候,通常我们会返回json类型的数据,但是像上面的例子,我们只希望返回一个1和0有助于进行后续判断即可,没必要返回json类型,返回一个text字符串就可以了.

  在用户模块中的用户注册需求上,通常要进行用户名是否已被注册的验证,今天正好写了这个需求,把详细代码和所遇到的问题贴过来.在使用struts2+ajax时候,通常我们会返回json类型的数据,但是像上面的例子,我们只希望返回一个1和0有助于进行后续判断即可,没必要返回json类型,返回一个text字符串就可以了.

  regist.jsp(这里只提供<script>部分):

<script type="text/javascript">
    $(function() {
        $("#userNiName").blur(function() {

            var val = $(this).val();
            val = $.trim(val);

            var $this = $(this);

            if (val != "") {
                //把当前节点后面的所有 font 兄弟节点删除
                $this.nextAll("font").remove();

                var url = "user_checkName";
                var args = {
                    "userNiName" : val,
                    "time" : new Date()
                };
                $.post(url, args, function(data) {
                    //表示可用
                    if (data == "1") {
                        $this.after("<font color='green'>用户名可用!</font>");
                    }
                    //不可用
                    else if (data == "0") {
                        $this.after("<font color='red'>用户名已被注册!</font>");
                    }
                    //服务器错误
                    else {
                        alert("服务器错误!");
                    }
                });
            } else {

                $(this).val("");
                $this.focus();
            }
        });
    })
</script>

  这里我是用了Jquery.post(url,args,function(data){..})函数提交ajax请求到指定url,并且携带参数args,最后用一个回调函数处理请求返回结果data.

  UserAction:

public class UserAction extends ActionSupport implements ModelDriven<User>{

    private User user=new User();
    private UserService userService;
    
    private InputStream inputStream;
    public InputStream getInputStream() {
        return inputStream;
    }
    //检验用户昵称是否存在
    public String checkName() throws UnsupportedEncodingException{
        System.out.println("进入ajax检验");
        String userNiName=user.getUserNiName();
        if(userService.findUserByName(userNiName)==null){
            inputStream=new ByteArrayInputStream("1".getBytes("UTF-8"));
        }else{
            inputStream=new ByteArrayInputStream("0".getBytes("UTF-8"));
        }
        
        return "ajax_succ";
    }
    
    @Override
    public User getModel() {
        return user;
    }

    public void setUserService(UserService userService) {
        this.userService = userService;
    }
    
    
}

注意:这里我用的是ModelDriven的方式获取表单数据,而在使用ajax的时候,直接传了一个userNiName(昵称)过来,于是我在UserAction中加了一个私有字符串变量userNiName,并设置了set方法.结果死活传不过值来,传过来的是一个null,于是我将私有变量删掉,然后直接用user.getUserNiName()直接获取就得到了.切记.

UserService(省略).

User类(省略).

UserDao:

package com.wang.shop.user.dao;

import java.util.List;


import org.springframework.orm.hibernate4.support.HibernateDaoSupport;

import com.wang.shop.user.entity.User;

public class UserDao extends HibernateDaoSupport{

    /**
     * 通过用户昵称查询User
     * @param userNiName
     * @return
     */
    public User findUserByName(String userNiName){
        List<User> list = (List<User>) this.getHibernateTemplate().find("select u from User u where u.userNiName=?", userNiName);
        if(list!=null&&list.size()>0){
            System.out.println("list:"+list.get(0));
            return list.get(0);
        }
        return null;
    }

}

struts.xml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">

<struts>
    <package name="shop" namespace="/" extends="struts-default">
        <!-- UserAction -->
        <action name="user_*" class="userAction" method="{1}">
            <result name="regist_succ">/WEB-INF/jspForUser/login.jsp</result>
            <result type="stream" name="ajax_succ">
                <param name="contentType">text/html</param>
                <param name="inputStream">inputStream</param>
            </result>
        </action>
    </package>

   
</struts>

  注意在result标签中,type="stream".

  最后顺带说一句,我在调试的时候习惯使用输出语句,但每次加一句输出语句都需要重启Tomcat,好烦.于是参考网上的方式,将Tmocat安装目录下,conf->server.xml中在<host>标签下添加了以下代码,就可以修改类(细微的修改)的时候,不需要重启服务器了:

<!--docBase就是你的项目工程所在的全路径,path就是写你的项目名,reloadable="true",可以自动重新加载修改过的class文件-->
<Context  debug="0" docBase="D:\Tomcat 7.0\webapps\SSH_shop01" path="/SSH_shop01" reloadable="true" />

需要特别注意的是,当在Tomcat中卸载了该项目后,一定要回来将这个标签删除.

 

相关文章
|
6月前
|
XML 前端开发 JavaScript
什么是Ajax和jquery
什么是Ajax和jquery
56 0
|
14天前
|
JSON 前端开发 Java
利用Spring Boot处理JSON数据实战(包括jQuery,html,ajax)附源码 超详细
利用Spring Boot处理JSON数据实战(包括jQuery,html,ajax)附源码 超详细
66 0
|
14天前
|
敏捷开发 JavaScript 前端开发
❤❤❤【Vue.js最新版】sd.js基于jQuery Ajax最新原生完整版for凯哥API版本❤❤❤
❤❤❤【Vue.js最新版】sd.js基于jQuery Ajax最新原生完整版for凯哥API版本❤❤❤
|
14天前
|
弹性计算 运维 Shell
基于key验证多主机ssh访问
【4月更文挑战第30天】
24 1
|
14天前
|
安全 Shell 网络安全
ssh配置无密码验证
ssh配置无密码验证要在SSH中配置无密码验证,您需要使用公钥验证【2月更文挑战第18天】
49 1
|
14天前
|
JavaScript 前端开发 数据安全/隐私保护
jQuery最方便的前端验证方式2种(非空验证与比较验证)
jQuery最方便的前端验证方式2种(非空验证与比较验证)
54 0
|
14天前
|
前端开发 JavaScript
Jquery ajax捕获错误信息
Jquery ajax捕获错误信息
19 0
|
14天前
|
JavaScript 数据安全/隐私保护
jquery正则表达式验证手机号密码和姓名字段
jquery正则表达式验证手机号密码和姓名字段
|
14天前
|
JSON 缓存 前端开发
Jquery中AJAX的应用
Jquery中AJAX的应用
46 0
|
14天前
|
JSON 前端开发 JavaScript
jQuery中ajax的使用
jQuery中ajax的使用