用户修改密码

Posted 梦飞扬~

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用户修改密码相关的知识,希望对你有一定的参考价值。

一、记·修改用户密码功能实现

1. 新建页面 profile.jsp,添加三个输入框和提交按钮:用户输入当前密码、输入新密码、再次确认密码和重置按钮、修改密码按钮;

2. 前台 javascript 校验用户输入通过后触发 Ajax 请求至后台;

3. 后台(这里使用 SSM 框架实现)在 UserMapper.xml 写 SQL 语句实现,接着是 UserDao.java、UserService.java 和 UserServiceImpl.java 的接口实现;

4. 后台控制器 UserAction.java 实现,请求路径、请求参数、返回值实现。

 

二、相关代码示例

1. profile.jsp 

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>
<%
    String path = request.getContextPath();
%>
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <title>修改密码-系统后台管理</title>
        
        <!-- <jsp:include page="_css.jsp" /> -->
        
        <!-- <link rel="stylesheet" type="text/css" href="<%=path%>/view/assets/javascript/editor.css"/> --> <!-- 外部样式 -->
        <script type="text/javascript" src="https://cdn.bootcss.com/jquery/1.11.0/jquery.min.js"></script>
        <!-- 内部样式 -->
        <style type="text/css">
        .errorMsg {
            color: red;
        }
        
        .error {
            border: 1px solid red;
        }
        
        .password-input {
            width: 400px;
            hight: 25px !importent;
            margin-top: 5px;
        }
        
        .btn {
            vertical-align: middle;
            text-align: center;
            margin-top: 30px;
            width: 50%;
        }
        </style>
    </head>
    <body>
        <!-- <jsp:include page="_header.jsp" /> -->
        <div>
            <h3>修改用户密码</h3>
            <div>
                <label>当前密码</label></br>
                <input type="password" class="password-input" id="current_password" name="current_password" placeholder="密码长度为6-16个字符,由英文大小写字母、数字、符号组成" >
                &nbsp;<span id="currentMsg" class="errorMsg"></span>
            </div>
            <div style="margin-top: 15px;"> <!-- 内联样式 -->
                <label>新密码</label></br>
                <input type="password" class="password-input" id="new_password" name="new_password" placeholder="新密码不能当前密码相同" >
                &nbsp;<span id="newMsg" class="errorMsg"></span>
            </div>
            <div style="margin-top: 15px;">
                <label>确认密码</label></br>
                <input type="password" class="password-input" id="confirmation_password" name="confirmation_password" placeholder="确认密码与新密码保持一致" >
                &nbsp;<span id="confirmMsg" class="errorMsg"></span>
            </div>
            <div class="btn">
                <input type="reset" value="重置" onclick="clearInput();"></i> &nbsp;
                <input type="button" value="修改密码" onclick="checkInput();"></i>
            </div>
        </div>
        
        <!-- <jsp:include page="_footer.jsp" /> -->
        <!-- <jsp:include page="_js.jsp">
                <jsp:param value="true" name="enableScript" />
             </jsp:include> -->
        
        <!-- <script type="text/javascript" src="<%=path%>/view/assets/javascript/editor.js"></script> -->
        <script type="text/javascript">
        var flag = true;
        
        function clearInput() {
            $("#current_password").val("");
            $("#new_password").val("");
            $("#confirmation_password").val("");
            clearErrorMsg();
        }
        
        function clearErrorMsg() {
            $("#currentMsg").html("");
            $("#newMsg").html("");
            $("#confirmMsg").html("");
            $("#current_password").removeClass("error");
            $("#new_password").removeClass("error");
            $("#confirmation_password").removeClass("error");
        }
    
        function checkInput() {
            clearErrorMsg();
            var currentPassword = $("#current_password").val();
            var newPassword = $("#new_password").val();
            var confirmPassword = $("#confirmation_password").val();
            
            checkPwdLength(currentPassword, "currentMsg", "current_password");
            checkPwdLength(newPassword, "newMsg", "new_password");
            checkPwdLength(confirmPassword, "confirmMsg", "confirmation_password");
            
            if (flag) {
                $.post("<%=path%>/user/updatePassword", {
                    currentPassword : currentPassword,
                    newPassword : newPassword
                }, function(data) {
                    if ("success" == data) {
                        alert("密码修改成功,请使用新密码重新登陆!");
                        window.location.href="<%=path%>/login";
                    } else {
                        $("#currentMsg").html(data);
                        $("#current_Password").addClass("error");
                    }
                });
            }
        }

        function checkPwdLength(obj, msg, id) {
            if ("" == obj) {
                $("#" + msg).html("该项不能为空!");
                $("#" + id).addClass("error");
                flag = false;
            } else if (6 > obj.length || obj.length > 16) {
                $("#" + msg).html("密码长度为6-16个字符!");
                $("#" + id).addClass("error");
                flag = false;
            } else if($("#current_password").val() == $("#new_password").val()) {
                $("#newMsg").html("新密码不能当前密码相同!");
                flag = false;
            } else if ($("#new_password").val() != $("#confirmation_password").val()) {
                $("#confirmMsg").html("两次输入的密码不一致!");
                flag = false;
            } else {
                flag = true;
            }
        }
        </script>
    </body>
</html>

 

以上是关于用户修改密码的主要内容,如果未能解决你的问题,请参考以下文章

如何修改Debian用户密码

进销存系统_用户信息更新&密码修改

进销存系统_用户信息更新&密码修改

Oracle-常用数据库对象笔记(片段)

如何在Linux下修改Mysql的用户(root)密码

rabbitmq 修改用户密码怎么用java代码实现