欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot用戶數(shù)據(jù)修改的詳細(xì)實現(xiàn)

 更新時間:2022年04月06日 16:30:38   作者:程序員小徐同學(xué)  
用戶管理功能作為所有的系統(tǒng)是必不可少的一部分,下面這篇文章主要給大家介紹了關(guān)于springboot用戶數(shù)據(jù)修改的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下

修改密碼

1 用戶-修改密碼-持久層

1.1 規(guī)劃需要執(zhí)行的SQL語句

用戶修改密碼時需要執(zhí)行的SQL語句大致是:

UPDATE t_user SET password=?, modified_user=?, modified_time=? WHERE uid=?

在執(zhí)行修改密碼之前,還應(yīng)檢查用戶數(shù)據(jù)是否存在、并檢查用戶數(shù)據(jù)是否被標(biāo)記為“已刪除”、并檢查原密碼是否正確,這些檢查都可以通過查詢用戶數(shù)據(jù)來輔助完成:

SELECT * FROM t_user WHERE uid=?

1.2 接口與抽象方法

在UserMapper接口添加updatePasswordByUid(Integer uid,String password,String modifiedUser,Date modifiedTime)抽象方法。

用注解來簡化xml配置時,@Param注解的作用是給參數(shù)命名,參數(shù)命名后就能根據(jù)名字得到參數(shù)值,正確的將參數(shù)傳入sql語句中。@Param("參數(shù)名")注解中的參數(shù)名需要和sql語句中的#{參數(shù)名}的參數(shù)名保持一致。

/**
 * 根據(jù)uid更新用戶的密碼
 * @param uid 用戶的id
 * @param password 新密碼
 * @param modifiedUser 最后修改執(zhí)行人
 * @param modifiedTime 最后修改時間
 * @return 受影響的行數(shù)
 */
Integer updatePasswordByUid(
		@Param("uid") Integer uid, 
		@Param("password") String password, 
		@Param("modifiedUser") String modifiedUser, 
		@Param("modifiedTime") Date modifiedTime);

/**
 * 根據(jù)用戶id查詢用戶數(shù)據(jù)
 * @param uid 用戶id
 * @return 匹配的用戶數(shù)據(jù),如果沒有匹配的用戶數(shù)據(jù),則返回null
 */
User findByUid(Integer uid);

1.3 配置SQL映射

1.在UserMapper.xml中配置updatePasswordByUid()、findByUid()抽象方法的映射。

<!-- 根據(jù)uid更新用戶的密碼:
	 Integer updatePasswordByUid(
		@Param("uid") Integer uid, 
		@Param("password") String password, 
		@Param("modifiedUser") String modifiedUser, 
		@Param("modifiedTime") Date modifiedTime) -->
<update id="updatePasswordByUid">
	UPDATE
		t_user 
	SET
		password = #{password},
		modified_user = #{modifiedUser},
		modified_time = #{modifiedTime} 
	WHERE
		uid = #{uid}
</update>

<!-- 根據(jù)用戶id查詢用戶數(shù)據(jù):User findByUid(Integer uid) -->
<select id="findByUid" resultMap="UserEntityMap">
	SELECT
		*
	FROM
		t_user
	WHERE
		uid = #{uid}
</select>

2.在UserMapperTests中編寫并執(zhí)行單元測試。

@Test
public void updatePasswordByUid() {
	Integer uid = 7;
	String password = "123456";
	String modifiedUser = "超級管理員";
	Date modifiedTime = new Date();
	Integer rows = userMapper.updatePasswordByUid(uid, password, modifiedUser, modifiedTime);
	System.out.println("rows=" + rows);
}

@Test
public void findByUid() {
	Integer uid = 7;
	User result = userMapper.findByUid(uid);
	System.out.println(result);
}

2 用戶-修改密碼-業(yè)務(wù)層

2.1 規(guī)劃異常

1.用戶在修改密碼前,需要檢查用戶數(shù)據(jù)是否存在及是否被標(biāo)記為“已刪除”。如果檢查不通過則應(yīng)拋出UserNotFoundException異常。

2.用戶修改密碼時,可能會因為輸入的原密碼錯誤導(dǎo)致修改失敗,則應(yīng)拋出PasswordNotMatchException異常。

3.在執(zhí)行修改密碼時,如果返回的受影響行數(shù)與預(yù)期值不同,則應(yīng)拋出UpdateException異常。

4.創(chuàng)建com.cy.store.service.ex.UpdateException異常類,繼承自ServiceException類。

/** 更新數(shù)據(jù)的異常 */
public class UpdateException extends ServiceException {
	// Override Methods...
}

2.2 接口與抽象方法

在IUserService中添加changePassword(Integer uid, String username, String oldPassword, String newPassword)抽象方法。

/**
 * 修改密碼
 * @param uid 當(dāng)前登錄的用戶id
 * @param username 用戶名
 * @param oldPassword 原密碼
 * @param newPassword 新密碼
 */
public void changePassword(Integer uid, String username, String oldPassword, String newPassword);

2.3 實現(xiàn)抽象方法

1.在UserServiceImpl類中實現(xiàn)changePassword()抽象方法。

public void changePassword(Integer uid, String username, String oldPassword, String newPassword) {
	// 調(diào)用userMapper的findByUid()方法,根據(jù)參數(shù)uid查詢用戶數(shù)據(jù)
	// 檢查查詢結(jié)果是否為null
	// 是:拋出UserNotFoundException異常

	// 檢查查詢結(jié)果中的isDelete是否為1
	// 是:拋出UserNotFoundException異常

	// 從查詢結(jié)果中取出鹽值
	// 將參數(shù)oldPassword結(jié)合鹽值加密,得到oldMd5Password
	// 判斷查詢結(jié)果中的password與oldMd5Password是否不一致
	// 是:拋出PasswordNotMatchException異常

	// 將參數(shù)newPassword結(jié)合鹽值加密,得到newMd5Password
	// 創(chuàng)建當(dāng)前時間對象
	// 調(diào)用userMapper的updatePasswordByUid()更新密碼,并獲取返回值
	// 判斷以上返回的受影響行數(shù)是否不為1
	// 是:拋了UpdateException異常
}

2.changePassword()方法的具體代碼。

String中的equals與contentEquals方法,都可以用來比較String對象內(nèi)容是否相同。

@Override
public void changePassword(Integer uid, String username, String oldPassword, String newPassword) {
	// 調(diào)用userMapper的findByUid()方法,根據(jù)參數(shù)uid查詢用戶數(shù)據(jù)
	User result = userMapper.findByUid(uid);
	// 檢查查詢結(jié)果是否為null
	if (result == null) {
		// 是:拋出UserNotFoundException異常
		throw new UserNotFoundException("用戶數(shù)據(jù)不存在");
	}
	
	// 檢查查詢結(jié)果中的isDelete是否為1
	if (result.getIsDelete().equals(1)) {
		// 是:拋出UserNotFoundException異常
		throw new UserNotFoundException("用戶數(shù)據(jù)不存在");
	}
	
	// 從查詢結(jié)果中取出鹽值
	String salt = result.getSalt();
	// 將參數(shù)oldPassword結(jié)合鹽值加密,得到oldMd5Password
	String oldMd5Password = getMd5Password(oldPassword, salt);
	// 判斷查詢結(jié)果中的password與oldMd5Password是否不一致
	if (!result.getPassword().contentEquals(oldMd5Password)) {
		// 是:拋出PasswordNotMatchException異常
		throw new PasswordNotMatchException("原密碼錯誤");
	}
	
	// 將參數(shù)newPassword結(jié)合鹽值加密,得到newMd5Password
	String newMd5Password = getMd5Password(newPassword, salt);
	// 創(chuàng)建當(dāng)前時間對象
	Date now = new Date();
	// 調(diào)用userMapper的updatePasswordByUid()更新密碼,并獲取返回值
	Integer rows = userMapper.updatePasswordByUid(uid, newMd5Password, username, now);
	// 判斷以上返回的受影響行數(shù)是否不為1
	if (rows != 1) {
		// 是:拋出UpdateException異常
		throw new UpdateException("更新用戶數(shù)據(jù)時出現(xiàn)未知錯誤,請聯(lián)系系統(tǒng)管理員");
	}
}

3.在UserServiceTests中編寫并執(zhí)行單元測試。

@Test
public void changePassword() {
    try {
        Integer uid = 5;
        String username = "lower";
        String oldPassword = "123456";
        String newPassword = "888888";
        userService.changePassword(uid, username, oldPassword, newPassword);
        System.out.println("密碼修改成功!");
    } catch (ServiceException e) {
        System.out.println("密碼修改失敗!" + e.getClass().getSimpleName());
        System.out.println(e.getMessage());
    }
}

3 用戶-修改密碼-控制器

3.1 處理異常

在用戶修改密碼的業(yè)務(wù)中拋出了新的UpdateException異常,需要在BaseController類中進(jìn)行處理。

@ExceptionHandler(ServiceException.class)
public JsonResult<Void> handleException(Throwable e) {
	JsonResult<Void> result = new JsonResult<Void>(e);
	if (e instanceof UsernameDuplicateException) {
		result.setState(4000);
	} else if (e instanceof UserNotFoundException) {
		result.setState(4001);
	} else if (e instanceof PasswordNotMatchException) {
		result.setState(4002);
	} else if (e instanceof InsertException) {
		result.setState(5000);
	} else if (e instanceof UpdateException) {
		result.setState(5001);
	}
	return result;
}

3.2 設(shè)計請求

設(shè)計用戶提交的請求,并設(shè)計響應(yīng)的方式。

請求路徑:/users/change_password
請求參數(shù):String oldPassword, String newPassword, HttpSession session
請求類型:POST
響應(yīng)結(jié)果:JsonResult<Void>

3.3 處理請求

1.在UserController類中添加處理請求的changePassword(String oldPassword, String newPassword, HttpSession session)方法。

@RequestMapping("change_password")
public JsonResult<Void> changePassword(String oldPassword, String newPassword, HttpSession session) {
	// 調(diào)用session.getAttribute("")獲取uid和username
	// 調(diào)用業(yè)務(wù)對象執(zhí)行修改密碼
	// 返回成功
	
	return null;
}

2.實現(xiàn)UserController控制器中的修改密碼方法的代碼。

@RequestMapping("change_password")
public JsonResult<Void> changePassword(String oldPassword, String newPassword, HttpSession session) {
	// 調(diào)用session.getAttribute("")獲取uid和username
	Integer uid = getUidFromSession(session);
	String username = getUsernameFromSession(session);
	// 調(diào)用業(yè)務(wù)對象執(zhí)行修改密碼
	iUserService.changePassword(uid, username, oldPassword, newPassword);
	// 返回成功
	return new JsonResult<Void>(OK);
}

3.啟動項目先登錄,再訪問http://localhost:8080/users/change_password?oldPassword=xx&newPassword=xx進(jìn)行測試。

4 用戶-修改密碼-前端頁面

1.在password.html頁面中body標(biāo)簽內(nèi)部的最后,添加script標(biāo)簽用于編寫JavaScript程序。

<script type="text/javascript">
    $("#btn-change-password").click(function() {
        $.ajax({
            url: "/users/change_password",
            type: "POST",
            data: $("#form-change-password").serialize(),
            dataType: "json",
            success: function(json) {
                if (json.state == 200) {
                    alert("修改成功!");
                } else {
                    alert("修改失??!" + json.message);
                }
            }
        });
	});
</script>

2.啟動項目先登錄,再訪問http://localhost:8080/web/password.html頁面并進(jìn)行修改密碼。

問題:如果無法正常將數(shù)據(jù)傳遞給后臺,重啟動系統(tǒng)和IDEA開發(fā)工具,登陸后便可修改密碼。

3.問題:在操作前端頁面時用戶進(jìn)入修改密碼頁面,長時間停留在當(dāng)前頁面未進(jìn)行任何操作,將導(dǎo)致登錄信息過期。此時點擊修改按鈕時,仍會向/users/change_password發(fā)送請求,會被攔截器重定向到登錄頁面。由于整個過程是由$.ajax()函數(shù)采用異步的方式處理的,所以重定向也是由異步任務(wù)完成的,在頁面中沒有任何表現(xiàn)就會出現(xiàn)“用戶登錄信息超時后點擊按鈕沒有任何反應(yīng)”的問題。

解決方案:可以在password.html頁面的$.ajax()中補充error屬性的配置,該屬性的值是一個回調(diào)函數(shù)。當(dāng)服務(wù)器未正常響應(yīng)狀態(tài)碼時,例如出現(xiàn)302、400、404、405、500等狀態(tài)碼時,將會調(diào)用該函數(shù)。

error: function (xhr) {
    alert("您的登錄信息已經(jīng)過期,請重新登錄!HTTP響應(yīng)碼:" + xhr.status);
    location.href = "login.html";
}

個人資料

1 用戶-個人資料-持久層

1.1 規(guī)劃需要執(zhí)行的SQL語句

1.執(zhí)行修改用戶個人資料的SQL語句大致是:

UPDATE t_user SET phone=?, email=?, gender=?, modified_user=?, modified_time=? WHERE uid=?

2.在執(zhí)行修改用戶資料之前,當(dāng)用戶剛打開修改資料的頁面時,就應(yīng)把當(dāng)前登錄的用戶信息顯示到頁面中。顯示用戶資料可以通過:

SELECT * FROM t_user WHERE uid=?

說明:

1.該查詢功能已經(jīng)實現(xiàn),無需再次開發(fā);

2.在執(zhí)行修改用戶資料之前,還應(yīng)檢查用戶數(shù)據(jù)是否存在、是否標(biāo)記為“已刪除”,也可以通過以上查詢來實現(xiàn)。

1.2 接口與抽象方法

在UserMapper接口中添加updateInfoByUid(User user)方法。

/**
 * 根據(jù)uid更新用戶資料
 * @param user 封裝了用戶id和新個人資料的對象
 * @return 受影響的行數(shù)
 */
Integer updateInfoByUid(User user);

1.3 配置SQL映射

1.在UserMapper.xml中配置Integer updateInfoByUid(User user)抽象方法的映射。

<!-- 根據(jù)uid更新用戶個人資料:Integer updateInfoByUid(User user) -->
<update id="updateInfoByUid">
	UPDATE
		t_user 
	SET
		<if test="phone != null">phone = #{phone},</if>
		<if test="email != null">email = #{email},</if>
		<if test="gender != null">gender = #{gender},</if>
		modified_user = #{modifiedUser},
		modified_time = #{modifiedTime}
	WHERE
		uid = #{uid}
</update>

2.在UserMapperTests中編寫并執(zhí)行單元測試。

@Test
public void updateInfoByUid() {
    User user = new User();
    user.setUid(20);
    user.setPhone("17858802222");
    user.setEmail("admin@cy.com");
    user.setGender(1);
    user.setModifiedUser("系統(tǒng)管理員");
    user.setModifiedTime(new Date());
    Integer rows = userMapper.updateInfoByUid(user);
    System.out.println("rows=" + rows);
}

2 用戶-個人資料-業(yè)務(wù)層

2.1 規(guī)劃異常

1.關(guān)于用戶修改個人資料是由兩個功能組成的。

  • 打開頁面時顯示當(dāng)前登錄的用戶的信息;

  • 點擊修改按鈕時更新用戶的信息。

2.關(guān)于打開頁面時顯示當(dāng)前登錄的用戶的信息,可能會因為用戶數(shù)據(jù)不存在、用戶被標(biāo)記為“已刪除”而無法正確的顯示頁面,則拋出UserNotFoundException異常。

3.關(guān)于點擊修改按鈕時更新用戶的信息,在執(zhí)行修改資料之前仍需再次檢查用戶數(shù)據(jù)是否存在、用戶是否被標(biāo)記為“已刪除”,則可能拋出UserNotFoundException異常。并且在執(zhí)行修改資料過程中,還可能拋出UpdateException異常。

2.2 接口與抽象方法

在IUserService接口中添加兩個抽象方法,分別對應(yīng)以上兩個功能。

/**
 * 獲取當(dāng)前登錄的用戶的信息
 * @param uid 當(dāng)前登錄的用戶的id
 * @return 當(dāng)前登錄的用戶的信息
 */
User getByUid(Integer uid);

/**
 * 修改用戶資料
 * @param uid 當(dāng)前登錄的用戶的id
 * @param username 當(dāng)前登錄的用戶名
 * @param user 用戶的新的數(shù)據(jù)
 */
void changeInfo(Integer uid, String username, User user);

2.3 實現(xiàn)抽象方法

1.在UserServiceImpl實現(xiàn)類中實現(xiàn)getByUid(Integer uid)和changeInfo(Integer uid, String username, User user)以上兩個抽象方法。

@Override
public User getByUid(Integer uid) {
	// 調(diào)用userMapper的findByUid()方法,根據(jù)參數(shù)uid查詢用戶數(shù)據(jù)
	// 判斷查詢結(jié)果是否為null
	// 是:拋出UserNotFoundException異常

	// 判斷查詢結(jié)果中的isDelete是否為1
	// 是:拋出UserNotFoundException異常

	// 創(chuàng)建新的User對象
	// 將以上查詢結(jié)果中的username/phone/email/gender封裝到新User對象中

	// 返回新的User對象
	return null;
}

@Override
public void changeInfo(Integer uid, String username, User user) {
	// 調(diào)用userMapper的findByUid()方法,根據(jù)參數(shù)uid查詢用戶數(shù)據(jù)
	// 判斷查詢結(jié)果是否為null
	// 是:拋出UserNotFoundException異常

	// 判斷查詢結(jié)果中的isDelete是否為1
	// 是:拋出UserNotFoundException異常

	// 向參數(shù)user中補全數(shù)據(jù):uid
	// 向參數(shù)user中補全數(shù)據(jù):modifiedUser(username)
	// 向參數(shù)user中補全數(shù)據(jù):modifiedTime(new Date())
	// 調(diào)用userMapper的updateInfoByUid(User user)方法執(zhí)行修改,并獲取返回值
	// 判斷以上返回的受影響行數(shù)是否不為1
	// 是:拋出UpdateException異常
	
}

2.getByUid(Integer uid)和changeInfo(Integer uid, String username, User user)方法的具體代碼實現(xiàn)。

@Override
public User getByUid(Integer uid) {
	// 調(diào)用userMapper的findByUid()方法,根據(jù)參數(shù)uid查詢用戶數(shù)據(jù)
	User result = userMapper.findByUid(uid);
	// 判斷查詢結(jié)果是否為null
	if (result == null) {
		// 是:拋出UserNotFoundException異常
		throw new UserNotFoundException("用戶數(shù)據(jù)不存在");
	}
 
	// 判斷查詢結(jié)果中的isDelete是否為1
	if (result.getIsDelete().equals(1)) {
		// 是:拋出UserNotFoundException異常
		throw new UserNotFoundException("用戶數(shù)據(jù)不存在");
	}

	// 創(chuàng)建新的User對象
	User user = new User();
	// 將以上查詢結(jié)果中的username/phone/email/gender封裝到新User對象中
	user.setUsername(result.getUsername());
	user.setPhone(result.getPhone());
	user.setEmail(result.getEmail());
	user.setGender(result.getGender());
	
	// 返回新的User對象
	return user;
}

@Override
public void changeInfo(Integer uid, String username, User user) {
	// 調(diào)用userMapper的findByUid()方法,根據(jù)參數(shù)uid查詢用戶數(shù)據(jù)
	User result = userMapper.findByUid(uid);
	// 判斷查詢結(jié)果是否為null
	if (result == null) {
		// 是:拋出UserNotFoundException異常
		throw new UserNotFoundException("用戶數(shù)據(jù)不存在");
	}

	// 判斷查詢結(jié)果中的isDelete是否為1
	if (result.getIsDelete().equals(1)) {
		// 是:拋出UserNotFoundException異常
		throw new UserNotFoundException("用戶數(shù)據(jù)不存在");
	}

	// 向參數(shù)user中補全數(shù)據(jù):uid
	user.setUid(uid);
	// 向參數(shù)user中補全數(shù)據(jù):modifiedUser(username)
	user.setModifiedUser(username);
	// 向參數(shù)user中補全數(shù)據(jù):modifiedTime(new Date())
	user.setModifiedTime(new Date());
	// 調(diào)用userMapper的updateInfoByUid(User user)方法執(zhí)行修改,并獲取返回值
	Integer rows = userMapper.updateInfoByUid(user);
	// 判斷以上返回的受影響行數(shù)是否不為1
	if (rows != 1) {
		// 是:拋出UpdateException異常
		throw new UpdateException("更新用戶數(shù)據(jù)時出現(xiàn)未知錯誤,請聯(lián)系系統(tǒng)管理員");
	}
}

3.在UserServiceTests類中進(jìn)行單元測試。

@Test
public void getByUid() {
    try {
        Integer uid = 20;
        User user = iUserService.getByUid(uid);
        System.out.println(user);
    } catch (ServiceException e) {
        System.out.println(e.getClass().getSimpleName());
        System.out.println(e.getMessage());
    }
}

@Test
public void changeInfo() {
    try {
        Integer uid = 20;
        String username = "數(shù)據(jù)管理員";
        User user = new User();
        user.setPhone("15512328888");
        user.setEmail("admin03@cy.cn");
        user.setGender(2);
        iUserService.changeInfo(uid, username, user);
        System.out.println("OK.");
    } catch (ServiceException e) {
        System.out.println(e.getClass().getSimpleName());
        System.out.println(e.getMessage());
    }
}

3 用戶-個人資料-控制器

3.1 處理異常

說明:無需再次開發(fā)。

3.2 設(shè)計請求

1.設(shè)計用戶提交顯示當(dāng)前登錄的用戶信息的請求,并設(shè)計響應(yīng)的方式。

請求路徑:/users/get_by_uid
請求參數(shù):HttpSession session
請求類型:GET
響應(yīng)結(jié)果:JsonResult<User>

2.設(shè)計用戶提交執(zhí)行修改用戶信息的請求,并設(shè)計響應(yīng)的方式。

請求路徑:/users/change_info
請求參數(shù):User user, HttpSession session
請求類型:POST
響應(yīng)結(jié)果:JsonResult<Void>

3.3 處理請求

1.處理獲取用戶信息請求

1.在UserController類中添加處理請求的getByUid()方法,并導(dǎo)入org.springframework.web.bind.annotation.GetMapping包。

@GetMapping("get_by_uid")
public JsonResult<User> getByUid(HttpSession session) {
	// 從HttpSession對象中獲取uid
	// 調(diào)用業(yè)務(wù)對象執(zhí)行獲取數(shù)據(jù)
	// 響應(yīng)成功和數(shù)據(jù)
	return null;
}

2.getByUid(HttpSession session)方法中具體代碼實現(xiàn)為。

@GetMapping("get_by_uid")
public JsonResult<User> getByUid(HttpSession session) {
    // 從HttpSession對象中獲取uid
    Integer uid = getUidFromSession(session);
    // 調(diào)用業(yè)務(wù)對象執(zhí)行獲取數(shù)據(jù)
    User data = userService.getByUid(uid);
    // 響應(yīng)成功和數(shù)據(jù)
    return new JsonResult<User>(OK, data);
}

3.完成后啟動項目,打開瀏覽器先登錄,再訪問http://localhost:8080/users/get_by_uid請求進(jìn)行測試。

2.處理修改用戶個人信息請求

1.在UserController類中添加處理請求的changeInfo(User user, HttpSession session)方法。

@RequestMapping("change_info")
public JsonResult<Void> changeInfo(User user, HttpSession session) {
	// 從HttpSession對象中獲取uid和username
	// 調(diào)用業(yè)務(wù)對象執(zhí)行修改用戶資料
	// 響應(yīng)成功
	return null;
}

2.changeInfo(User user, HttpSession session)方法中具體代碼實現(xiàn)為。

@RequestMapping("change_info")
public JsonResult<Void> changeInfo(User user, HttpSession session) {
	// 從HttpSession對象中獲取uid和username
	Integer uid = getUidFromSession(session);
	String username = getUsernameFromSession(session);
	// 調(diào)用業(yè)務(wù)對象執(zhí)行修改用戶資料
	userService.changeInfo(uid, username, user);
	// 響應(yīng)成功
	return new JsonResult<Void>(OK);
}

3.完成后啟動項目,打開瀏覽器先登錄,再訪問http://localhost:8080/users/change_info?phone=17858800000&email=admin07@cy.com&gender=1進(jìn)行測試。

4 用戶-個人資料-前端頁面

1.在userdata.html頁面中body標(biāo)簽內(nèi)部的最后,添加script標(biāo)簽用于編寫JavaScript程序。

<script type="text/javascript">
    $(document).ready(function() {
        $.ajax({
            url: "/users/get_by_uid",
            type: "GET",
            dataType: "json",
            success: function(json) {
                if (json.state == 200) {
                    console.log("username=" + json.data.username);
                    console.log("phone=" + json.data.phone);
                    console.log("email=" + json.data.email);
                    console.log("gender=" + json.data.gender);

                    $("#username").val(json.data.username);
                    $("#phone").val(json.data.phone);
                    $("#email").val(json.data.email);

                    let radio = json.data.gender == 0 ? $("#gender-female") : $("#gender-male");
                    radio.prop("checked", "checked");
                } else {
                    alert("獲取用戶信息失??!" + json.message);
                }
            }
        });
	});

    $("#btn-change-info").click(function() {
        $.ajax({
            url: "/users/change_info",
            type: "POST",
            data: $("#form-change-info").serialize(),
            dataType: "json",
            success: function(json) {
                if (json.state == 200) {
                    alert("修改成功!");
                    location.href = "login.html";
                } else {
                    alert("修改失?。? + json.message);
                }
            },
            error: function(xhr) {
                alert("您的登錄信息已經(jīng)過期,請重新登錄!HTTP響應(yīng)碼:" + xhr.status);
                location.href = "login.html";
            }
        });
    });
</script>

2.完成后啟動項目,打開瀏覽器先登錄,再訪問http://localhost:8080/web/userdata.html頁面并進(jìn)行用戶個人資料的修改測試。

總結(jié)

到此這篇關(guān)于springboot用戶數(shù)據(jù)修改的文章就介紹到這了,更多相關(guān)springboot用戶數(shù)據(jù)修改內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中的字符編碼問題處理心得總結(jié)

    Java中的字符編碼問題處理心得總結(jié)

    Java中的String類默認(rèn)是Unicode編碼,大家平常所說的UTF-8就是使用最廣的一種unicode的實現(xiàn)方式,以下我們還是來看一下Java中的字符編碼問題處理心得總結(jié):
    2016-06-06
  • 關(guān)于pytorch相關(guān)部分矩陣變換函數(shù)的問題分析

    關(guān)于pytorch相關(guān)部分矩陣變換函數(shù)的問題分析

    這篇文章主要介紹了pytorch相關(guān)部分矩陣變換函數(shù),包括tensor維度順序變換BCHW順序的調(diào)整,矩陣乘法相關(guān)函數(shù),矩陣乘,點乘,求取矩陣對角線元素或非對角線元素的問題,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • 使用res:bean屬性復(fù)制避免null值覆蓋版本

    使用res:bean屬性復(fù)制避免null值覆蓋版本

    這篇文章主要介紹了使用res:bean屬性復(fù)制避免null值覆蓋版本的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Spring Cloud CLI簡單介紹

    Spring Cloud CLI簡單介紹

    本文我們將介紹Spring Boot Cloud CLI(或簡稱Cloud CLI)。該工具為Spring Boot CLI提供了一組命令行增強功能,有助于進(jìn)一步抽象和簡化Spring Cloud部署。感興趣的小伙伴們可以參考一下
    2018-12-12
  • IO中flush()函數(shù)的使用代碼示例

    IO中flush()函數(shù)的使用代碼示例

    這篇文章主要介紹了IO中flush()函數(shù)的使用代碼示例,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • java?CompletableFuture異步任務(wù)編排示例詳解

    java?CompletableFuture異步任務(wù)編排示例詳解

    這篇文章主要為大家介紹了java?CompletableFuture異步任務(wù)編排示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • Hibernate對數(shù)據(jù)庫刪除、查找、更新操作實例代碼

    Hibernate對數(shù)據(jù)庫刪除、查找、更新操作實例代碼

    本篇文章主要介紹了Hibernate對數(shù)據(jù)庫刪除、查找、更新操作實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 2020.2 IntelliJ IDEA激活與IDEA2020.2破解詳細(xì)教程

    2020.2 IntelliJ IDEA激活與IDEA2020.2破解詳細(xì)教程

    這篇文章主要介紹了2020.2 IntelliJ IDEA激活與IDEA2020.2破解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • 詳解Java多線程處理List數(shù)據(jù)

    詳解Java多線程處理List數(shù)據(jù)

    這篇文章主要介紹了Java多線程處理List數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • SpringBoot常用計量與bean屬性校驗和進(jìn)制數(shù)據(jù)轉(zhuǎn)換規(guī)則全面分析

    SpringBoot常用計量與bean屬性校驗和進(jìn)制數(shù)據(jù)轉(zhuǎn)換規(guī)則全面分析

    這篇文章主要介紹了SpringBoot常用計量、bean屬性校驗與進(jìn)制數(shù)據(jù)轉(zhuǎn)換規(guī)則,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-10-10

最新評論