SSM框架應用

1、更新用戶密碼功能的實現javascript

1. 新建頁面 profile.jsp,添加三個輸入框和提交按鈕:用戶輸入當前密碼、輸入新密碼、再次確認密碼和重置按鈕、修改密碼按鈕;css

2. 前臺 js(JavaScript) 校驗用戶輸入經過後觸發 Ajax 請求至後臺;html

3. 後臺(這裏使用 Spring+SpringMVC+Mybatis 框架實現)在 UserMapper.xmlSQL 語句實現,接着是 UserModel.javaUserDAO.javaUserService.java 和 UserServiceImpl.java 的接口實現;java

4. 後臺控制器 UserAction.java 實現,請求路徑(path)、請求參數(parameter)、返回值實現。jquery

 

2、相關代碼示例web

1. profile.jsp (將其文件後綴改成 profile.html 並在 Chrome 谷歌瀏覽器中打開可參見 Demo)sql

<%@ 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>
View Code

 2. UserMapper.xml瀏覽器

<?xml version="1.0" encoding="UTF-8"?>  
<!DOCTYPE mapper  
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.cqupt.dao.UserDAO">

    <resultMap id="userResultMap" type="com.cqupt.model.UserModel">
        <result property="id" column="id" jdbcType="INTEGER" javaType="int" />
        <result property="account" column="account" jdbcType="VARCHAR" javaType="String" />
        <result property="gender" column="gender" jdbcType="BIT" javaType="boolean" />
        <result property="password" column="password" jdbcType="VARCHAR" javaType="String" />
        <result property="phone" column="phone" jdbcType="VARCHAR" javaType="String" />
        <result property="qq" column="qq" jdbcType="VARCHAR" javaType="String" />
        <result property="mail" column="mail" jdbcType="VARCHAR" javaType="String" />
        <result property="type" column="type" jdbcType="INTEGER" javaType="int" />
        <result property="regTime" column="reg_time" jdbcType="TIMESTAMP" javaType="java.sql.Timestamp" />
    </resultMap>

    <insert id="addUser" parameterType="com.cqupt.model.UserModel">
        INSERT INTO web_user_info (account, gender,  password, phone, qq, mail, type, reg_time)
        VALUES(#{account }, #{gender }, #{password }, #{ phone } #{qq }, #{mail }, #{type }, now())
    </insert>

    <select id="findUserById" parameterType="int" resultMap="userResultMap">
        SELECT * FROM web_user_info WHERE id = #{userId }
    </select>
    
    <select id="findByAccount" parameterType="String" resultMap="userResultMap">
        SELECT * FROM web_user_info WHERE account = #{account }
    </select>

    <!-- 查詢全部用戶信息 -->
    <select id="findAllUsers" resultMap="userResultMap">
        SELECT * FROM web_user_info
    </select>
    
    <update id="updatePassword">
        UPDATE web_user_info SET password= #{newPassword } WHERE id = #{userId}
    </update>
    
</mapper> 
View Code

 3. UserDAO.javasession

public interface UserDAO
{

    /**
     * 經過用戶ID修改密碼
     * @param userId user id
     * @param newPassword new password
     * @return 受影響的條數
     */
    int updatePassword(@Param("userId") int userId, @Param("newPassword") String newPassword);

}
View Code

 4. UserService.javamybatis

public interface UserService
{

    /**
     * 經過ID修改用戶密碼
     * @param userId user id
     * @param newPassword new password
     * @return 受影響的數據行數
     */
    int updatePassword(int userId, String newPassword);

}
View Code

 5. UserServiceImpl.java

@Service
public class UserServiceImpl implements UserService
{

    @Autowired
    private UserDAO userDAO;

    /**
     * {@inheritDoc }
     */
    @Override
    public int updatePassword(int userId, String newPassword) 
    {
        return userDAO.updatePassword(userId, newPassword);
    }

}
View Code

 6. UserAction.java

@Controller
@RequestMapping("user")
public class UserAction extends WebCommonAction
{

    @Autowired
    private UserService userService;

    /**
     * 經過用戶ID修改密碼
     * @param req HttpServletRequest
     * @param newPassword 新密碼
     * @return ModelAndView
     */
    @ResponseBody
    @RequestMapping(value = "updatePassword", method = RequestMethod.POST)
    public Object updatePassword(HttpServletRequest req, String currentPassword, String newPassword)
    {
        UserModel currentUserModel = getCurrentUser(req);
        if (!currentUserModel.getPassword().equals(StringUtil.encodePwd(currentPassword))) 
        {
            return "當前密碼輸入不正確";
        }
        else 
        {
            userService.updatePassword(getCurrentUserId(req), StringUtil.encodePwd(newPassword));
            HttpSession session = req.getSession();
            session.setAttribute(Constant.WEB_CURRENT_USER, null);
            session.invalidate();
            return "success";
        }
    }
    
}
View Code
相關文章
相關標籤/搜索