排查spring事務(wù)不生效

相信很多人和我一樣配置spring 和 spring mvc項(xiàng)目的台腥,spring的初始化交給ContextLoaderListener進(jìn)行,使用的是applicationContext.xml文件。而spring mvc 初始化是交給DispatcherServlet進(jìn)行的,使用的mvc-context.xml文件

web.xml

<context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>
            classpath:applicationContext.xml
           </param-value>
    </context-param>


    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <listener>
        <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
    </listener>

<!-- 加入spring mvc -->
    <servlet>
        <servlet-name>mvcServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:mvc-context.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>mvcServlet</servlet-name>
        <url-pattern>/new/*</url-pattern>
    </servlet-mapping>

applicationContext.xml

<!-- 使用annotation 自動注冊bean,并保證@Required,@Autowired的屬性被注入 -->
    <context:component-scan base-package="org.demo">
        <context:exclude-filter type="annotation"
            expression="org.springframework.stereotype.Controller" />
        <context:exclude-filter type="annotation"
            expression="org.springframework.web.bind.annotation.ControllerAdvice" />
    </context:component-scan>
    
其他配置省略

mvc-context.xml

<!-- 掃描 controller 和 ControllerAdvice類型的 類,其他類型交由spring掃描 -->
    <context:component-scan base-package="org.demo">
        <context:include-filter type="annotation"
            expression="org.springframework.stereotype.Controller" />
        <context:include-filter type="annotation"
            expression="org.springframework.web.bind.annotation.ControllerAdvice" />
    </context:component-scan>

其他配置省略...

問題來了
當(dāng)我在界面上測試一個(gè)帶事務(wù)的操作發(fā)現(xiàn)事務(wù)不生效萄焦,我使用的是在service層加入注解事務(wù)@Transactional,開始以為我事務(wù)配置有問題,檢查了很久怎么都沒有發(fā)現(xiàn)有問題拂封。然后我使用junit代碼測試service層發(fā)現(xiàn)事務(wù)是生效的茬射,那么說明了spring mvc的配置造成了事務(wù)不生效。

解決辦法有兩個(gè):

1.指定mvc-context.xml 文件掃描包路徑更為精確點(diǎn)冒签,如果org.demo.controller,但是這樣要確保所有Controller要放在改包下在抛。

mvc-context.xml

2.去掉mvc-context.xml對其他類型注釋的掃描,使用use-default-filters="false"配置

mvc-context.xml

use-default-filters默認(rèn)值為true萧恕,會對@Component, @Repository, @Service,@Controller都進(jìn)行掃描刚梭,我們原意是只對@Controller進(jìn)行掃描的。

use-default-filters說明
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末票唆,一起剝皮案震驚了整個(gè)濱河市朴读,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌走趋,老刑警劉巖衅金,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異簿煌,居然都是意外死亡氮唯,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門姨伟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來惩琉,“玉大人,你說我怎么就攤上這事夺荒∮匙” “怎么了次和?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵妒穴,是天一觀的道長蒜茴。 經(jīng)常有香客問我券膀,道長嬉荆,這世上最難降的妖魔是什么浸须? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任移怯,我火速辦了婚禮始赎,結(jié)果婚禮上和橙,老公的妹妹穿的比我還像新娘。我一直安慰自己造垛,他們只是感情好魔招,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著五辽,像睡著了一般办斑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天乡翅,我揣著相機(jī)與錄音鳞疲,去河邊找鬼。 笑死蠕蚜,一個(gè)胖子當(dāng)著我的面吹牛尚洽,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播靶累,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼腺毫,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了挣柬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤澈灼,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后店溢,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡床牧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年荣回,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片心软。...
    茶點(diǎn)故事閱讀 39,991評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡著蛙,死狀恐怖删铃,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情踏堡,我是刑警寧澤猎唁,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站顷蟆,受9級特大地震影響诫隅,放射性物質(zhì)發(fā)生泄漏帐偎。R本人自食惡果不足惜削樊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沛硅,春花似錦、人聲如沸摇肌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至肯适,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間框舔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工樱溉, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人福贞。 一個(gè)月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓停士,卻偏偏與公主長得像挖帘,于是被迫代替她去往敵國和親恋技。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容