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密码的数据。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

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