1、更新用戶密碼功能的實現javascript
1. 新建頁面 profile.jsp,添加三個輸入框和提交按鈕:用戶輸入當前密碼、輸入新密碼、再次確認密碼和重置按鈕、修改密碼按鈕;css
2. 前臺 js(JavaScript) 校驗用戶輸入經過後觸發 Ajax 請求至後臺;html
3. 後臺(這裏使用 Spring+SpringMVC+Mybatis 框架實現)在 UserMapper.xml 寫 SQL 語句實現,接着是 UserModel.java、UserDAO.java、UserService.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個字符,由英文大小寫字母、數字、符號組成" > <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="新密碼不能當前密碼相同" > <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="確認密碼與新密碼保持一致" > <span id="confirmMsg" class="errorMsg"></span> </div> <div class="btn"> <input type="reset" value="重置" onclick="clearInput();"></i> <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>
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>
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); }
4. UserService.javamybatis
public interface UserService { /** * 經過ID修改用戶密碼 * @param userId user id * @param newPassword new password * @return 受影響的數據行數 */ int updatePassword(int userId, String newPassword); }
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); } }
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"; } } }