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

解決try-catch捕獲異常信息后Spring事務(wù)失效的問題

 更新時間:2021年06月21日 15:19:35   作者:DT辰白  
這篇文章主要介紹了解決try-catch捕獲異常信息后Spring事務(wù)失效的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

一、首先在Spring Boot項目中,手動添加異常方法進(jìn)行測試

@Transactional(rollbackFor=Exception.class) //表示此方法有異常時觸發(fā)Spring事務(wù)
@Override
public CommonResult<User> saveUser(User user) {
    int insert = baseMapper.insert(user);
    try {
        // 添加異常,并進(jìn)行捕獲
        int a = 10/0;
    }catch (Exception e){
        logger.info("打印異常信息:"+e);
        return CommonResult.commentFailure("服務(wù)器異常,事務(wù)回滾");
    }
    if(insert > 0){
        return CommonResult.commentSuccess(user);
    }else {
        return CommonResult.commentFailure("添加失敗");
    }
}

1、一個添加信息的實(shí)現(xiàn)類方法上,此處我們加了Spring的事務(wù)。

2、問題:一個方法報異常(int a = 10/0)進(jìn)行了異常捕獲,另一個方法不會回滾(insert添加方法)

這是什么情況呢,相當(dāng)于Spring事務(wù)策略失效了。

try-catch捕獲了異常后,這種業(yè)務(wù)方法也就等于脫離了spring事務(wù)的管理,因為沒有任何異常會從業(yè)務(wù)方法中拋出,全被捕獲并“吞掉”,導(dǎo)致spring異常拋出觸發(fā)事務(wù)回滾策略失效。

通俗的來說:默認(rèn)spring事務(wù)只在發(fā)生未被捕獲的 runtimeexcetpion或error時才回滾。

二、處理方案一

spring aop 異常捕獲進(jìn)而回滾。在catch中最后加上throw new runtimeexcetpion(),這樣程序異常時才能被aop捕獲進(jìn)而回滾,缺點(diǎn)是無法return異常信息提示,前端用戶交互效果不佳

@Transactional(rollbackFor=Exception.class)  //表示此方法有異常時觸發(fā)Spring事務(wù)
@Override
public CommonResult<User> saveUser(User user) {
    int insert = baseMapper.insert(user);
    try {
        // 添加異常,并進(jìn)行捕獲
        int a = 10/0;
    }catch (Exception e){
        logger.info("異常信息:"+e);
        // 方案一:spring aop 異常捕獲
        throw new RuntimeException();
    }
    if(insert > 0){
        return CommonResult.commentSuccess(user);
    }else {
        return CommonResult.commentFailure("添加失敗");
    }
}

三、處理方案二

就是讓一個方法報異常,另一個方法回滾,這樣才能真正的觸發(fā)Spring事務(wù)回滾策略。

catch語句中增加:

TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); //手動回滾,這樣上層就無需去處理異常了

完整代碼:

@Transactional(rollbackFor=Exception.class) //表示此方法有異常時觸發(fā)Spring事務(wù)
@Override
 public CommonResult<User> saveUser(User user) {
     int insert = baseMapper.insert(user);
     try {
         // 添加異常,并進(jìn)行捕獲
         int a = 10/0;
     }catch (Exception e){
         logger.info("異常信息:"+e);
         // 方案二:手動回滾
         TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
         return CommonResult.commentFailure("服務(wù)器異常,事務(wù)回滾");
     }
     if(insert > 0){
         return CommonResult.commentSuccess(user);
     }else {
         return CommonResult.commentFailure("添加失敗");
     }
 }

四、如過需要手動進(jìn)行手動回滾的業(yè)務(wù)方法比較多,我們可以寫一個公共的工具類

SpringRollBackUtil.java

public class SpringRollBackUtil {
    /**
     * 事務(wù)回滾機(jī)制
     */
    public static void rollBack() {
        try {
            TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

只需調(diào)用方法即可

// 方案三:公共工具類 手動回滾
SpringRollBackUtil.rollBack();

Spring mvc:事務(wù)引起的try/catch失效

在測試一個接口時,發(fā)現(xiàn)一個奇怪的現(xiàn)象:

該接口使用@ResponseBody注解返回json格式數(shù)據(jù),并且使用try/catch包括全部邏輯代碼,debug后發(fā)現(xiàn)返回數(shù)據(jù)沒有任何錯誤,只包含一段因產(chǎn)生異常導(dǎo)致的錯誤提示字符串,但是chrome瀏覽器network卻顯示http狀態(tài)碼為500。

最后發(fā)現(xiàn)在該RequestMapping方法上還有一個注解@Transactional,去除ok。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論