SSM注册登陆+md5加密

整体思路。
1.登录界面,输入正确的账号密码,跳转到用户显示界面。不正确则显示错误信息。
2.注册界面,输入账号密码昵称,假如3者有一个为空,显示输入有误请重新输入。假如用户名存在于数据库,显示用户以存在请重新输入。所以还要编写一个findUserByName的接口,作用是查询数据库中是否以存在这条数据。
均使用ajax实现异步请求。

常见的问题

在连接数据库的过程中,很容易出现一些错误。比如数据表名字、账号、密码填写错误。如果控制台输出有关SQL方面错误,请认真检查mybatis配置、dao层SQL语句是否编写错误。

项目格式:
Controller、dao、model、service,分别是控制层、持久层、数据模型层、业务处理层。


1529458005(1).jpg

数据库有4个字段: id(用户编号)、user_name(用户名称)、login_name(登录名称)、password(密码)。

用户登录用的是登录名(login_name) 、密码(password)。


2.jpg

数据库连接配置

Spring-mybatis.xml
  <!-- 配置数据库相关参数properties的属性:${url} -->
<context:property-placeholder location="classpath*:jdbc.properties"/>

<!-- 数据库连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" value="${jdbc.driver}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
</bean>

jdbc.properties  

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/userdb?useUnicode=true&characterEncoding=UTF-8
jdbc.username=root
jdbc.password=root

首先是根据数据表编写实体User.java。 dao层 定义方法的接口。userMapper.java编写接口。userMapper.xml编写sql语句。

1.根据数据表编写实体类:User.java

private Integer id;
private String user_name;
private String login_name;
private String password;
getter/setter方法

2.dao层编写接口:userMapper.java

User login(@Param("login_name") String login_name, @Param("password") String password);

boolean register(@Param("login_name") String login_name, 
@Param("password") String password, @Param("user_name") String user_name);

3.编写sql语句:userMapper.xml

 <!--登录-->
<select id="login" resultMap="BaseResultMap" parameterType="String">
  select login_name, password from User
  WHERE  login_name = #{login_name} AND password= #{password}
</select>
    
<!--注册-->
<insert id="register" parameterType="com.ssm.model.User">
  insert into User (login_name,password,user_name)
  values (#{login_name}, #{password}, #{user_name})
</insert>
<!--验证用户是否存在-->
<select id="findUserByLgName" resultType="int">
    select count(*) from user where login_name like #{login_name}
</select>

service层专注于业务逻辑 ,可以根据userMapper.JAVA编写接口,然后编写实 现类,这里可以做一些数据的限制,比如与拦截器做一些登录验证之类的。
(这个功能看过文章,没实现。)

4.service编写接口:IUserService.java

boolean login(String login_name, String password);
boolean register(String login_name, String password, String user_name);

5serviceImpl编写实现类:UserServiceImpl.java

@Autowired
private UserMapper userMapper;
@Override
public boolean login(String login_name, String password) {
    if (userMapper.login(login_name, password) != null) {
        return true;
    } else {
        return false;
    }
}

@Override
public boolean register(String login_name, String password, String user_name) {
    return userMapper.register(login_name, password, user_name);
}

6.Util包下编写工具类:Md5.java

public static String MD5(String inStr) {
    MessageDigest md5 = null;
    try {
        md5 = MessageDigest.getInstance("MD5");
    } catch (Exception e) {
        System.out.println(e.toString());
        e.printStackTrace();
        return "";
    }
    char[] charArray = inStr.toCharArray();
    byte[] byteArray = new byte[charArray.length];

    for (int i = 0; i < charArray.length; i++)
        byteArray[i] = (byte) charArray[i];

    byte[] md5Bytes = md5.digest(byteArray);

    StringBuffer hexValue = new StringBuffer();

    for (int i = 0; i < md5Bytes.length; i++) {
        int val = ((int) md5Bytes[i]) & 0xff;
        if (val < 16)
            hexValue.append("0");
        hexValue.append(Integer.toHexString(val));
    }

    return hexValue.toString();
}

// 可逆的加密算法
public static String KL(String inStr) {
    // String s = new String(inStr);
    char[] a = inStr.toCharArray();
    for (int i = 0; i < a.length; i++) {
        a[i] = (char) (a[i] ^ 't');
    }
    String s = new String(a);
    return s;
}

// 加密后解密
public static String JM(String inStr) {
    char[] a = inStr.toCharArray();
    for (int i = 0; i < a.length; i++) {
        a[i] = (char) (a[i] ^ 't');
    }
    String k = new String(a);
    return k;
}

Controller层:传递参数处理数据,返回给view展示数据。

7.Controller编写UserController.java

@Autowired
private IUserService userService;

//跳转登录
@RequestMapping("login")
public String toLogin() {
    return "login";
}
/*验证登录
 *
 * 使用 @ResponseBody 在ajax异步获取数据时使用。返回0/1
 *
 */
@RequestMapping(value = "login_check", method = RequestMethod.POST)
@ResponseBody
public int login(String login_name, String password) {
    String passwordByMd5 = MD5.MD5(password);
    boolean count = userService.login(login_name, passwordByMd5);
    int message;
    if (count == true) {
        message = 1;
    } else {
        message = 0;
    }
    return message;
}

//跳转注册
@RequestMapping(value = "toAdd")
public String toAdd() {
    return "register";
}

//实现注册
@RequestMapping(value = "implAdd", method = RequestMethod.POST)
@ResponseBody
public int add(String login_name, String password, String user_name) {
    String passwordByMd5 = MD5.MD5(password);
    int findUserByLgName = userService.findUserByLgName(login_name);
    int message;
    if (login_name.length() == 0 || user_name.length() == 0 || password.length() == 0) {
        message = -1;
        //System.out.println("用户信息输入信息有误");
    } else if (findUserByLgName == 0) {
        userService.register(login_name, passwordByMd5, user_name);
        message = 1;
        //System.out.println("可以注册");
    } else {
        //System.out.println("用户存在");
        message = 0;
    }
    return message;
}

8.编写login.jsp

<script type="text/javascript" language="JavaScript">
$(document).ready(function () {
    $('#login').click(function () {
        $.ajax({
            type: "post",
            url: "/login_check",
            data: {
                "login_name": $("#lg_name").val(),
                "password": $("#pwd").val(),
            },
            dataType: "JSON",
            async: false,
            beforeSend: function () {
                alert("正在提交");
            },
            success: function (data) {
                if (data == 1) {
                    alert("登录成功")
                    window.location.href = "userList";

                } else {
                    alert("用户名或者密码错误!");
                }
            },
            error: function () {
                alert("提交失败");
            }
        });
    })
})
</script>

   <h1>登录页面</h1>
<form class="bs-example bs-example-form" role="form1" method="post">
    <div class="input-group">
        <span class="input-group-addon">username</span>
        <input type="text" id="lg_name" class="form-control" >
    </div>
    <div class="input-group">
        <span class="input-group-addon">password</span>
        <input type="text" id="pwd" class="form-control" >
    </div>
</form>
<button  class="btn btn-info" style="align-content: center" id="register">注册</button>
<button  class="btn btn-info" style="align-content: center" id="login">登录</button>
</div>

9.编写Register.jsp

<script type="text/javascript" language="JavaScript">
$(document).ready(function () {
    $('#addUser').click(function () {
        $.ajax({
            type: "post",
            url: "/implAdd",
            data: {
                login_name: $("#lg_name").val(),
                password: $("#pwd").val(),
                user_name: $("#user_name").val(),
            },
            dataType: "JSON",
            async: false,
            beforeSend: function () {
                alert("正在提交");
            },

            success: function (data) {
                if (data == -1) {
                    alert("数据输入有误!");
                } else if (data == 0) {
                    alert("用户以存在!");

                } else {
                    alert("注册成功")
                    window.location.href = "login";
                }
            },
            error: function () {
                alert("提交失败");
            }
        });
    })

})
</script>

<h1>注册页面</h1>
<form class="bs-example bs-example-form" role="form" method="post">
    <div class="input-group">
        <span class="input-group-addon">用户名:</span>
        <input type="text" id="lg_name" class="form-control" placeholder="输入你的登录名">
    </div>
    <div class="input-group">
        <span class="input-group-addon">密码:</span>
        <input type="text" id="pwd" class="form-control" placeholder="输入你的密码">
    </div>
    <div class="input-group">
        <span class="input-group-addon">昵称:</span>
        <input type="text" id="user_name" class="form-control" placeholder="输入你的昵称">
    </div>
</form>
<button class="btn btn-info" style="align-content: center" id="addUser">提交</button>
<button class="btn btn-info" style="align-content: center" id="returnLogin">返回</button>

10.gif展示

GIF1.gif

11.实现思路

因为做得是注册、登录功能,在接口用了boolean作为接口的类型。
登录功能:返回0 就是登录失败,没有在数据库匹配到数据,反之,1就是成功。
注册功能:返回 0代表输入有误,返回-1代表数据存在数据库中,返回1代表成功。
md5加密是 在网上找的,然后在用 string passwordMd5 =md5(password) 代替原来的密码实现加密。这里我做了一个注册功能,在注册的时候数据库记录 的就是 md5密码的数据。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341

推荐阅读更多精彩内容

  • 【0424我在悦读】金钢 第5次打卡 书名:发展心理学 作者:戴安娜.帕帕拉 篇目:受遗传和环境影响的性状 人格。...
    金老狮阅读 622评论 0 49
  • 1 .我的大学生活之大学英语学习 1) 在上半学期的大学英语学习中,我的GPS [Gains] 加入了英语角,不断...
    上官云婍阅读 238评论 0 0
  • 设计模式有啥用 设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了重...
    maxwellyue阅读 479评论 0 0
  • 乌托邦症候群的共通特点:前提比现实还要真实。 自上而下的角度去建立自己的时间,而并非接地气的从现实出发。抱着这样的...
    没有方向的风阅读 192评论 0 0