idea搭建SSM框架遇踩的坑(附完整過程)
首先說明這是我一個(gè)不熟悉idea和SSM框架的新手小白遇到的坑,適合用idea搭建SSM框架的小伙伴看一看,老鳥就不用看了。以下為詳細(xì)步驟(傻瓜教程,超級細(xì)節(jié))
搭建SSM框架的前提當(dāng)然是我們已經(jīng)準(zhǔn)備好一下環(huán)境
安裝好的intellige idea, java環(huán)境,tomcat服務(wù)器,maven倉庫,mysql數(shù)據(jù)庫。
打開idea,new一個(gè)project,選擇maven項(xiàng)目,如圖,注意不要選錯(cuò)成上面那個(gè)webapp
點(diǎn)擊next繼續(xù),
groupid一般是公司名,Artfactid一般為項(xiàng)目名,對于idea的項(xiàng)目目錄結(jié)構(gòu),我自己也沒弄明白,不過這并不影響我們的目標(biāo)
點(diǎn)擊next繼續(xù),
這里我們使用自己的本地maven倉庫,注意setting.xml,repository路徑的修改。next繼續(xù),然后finish。
第一次建web maven項(xiàng)目可能需要的時(shí)間比較長,耐心等待Maven execution finished。最后的項(xiàng)目結(jié)構(gòu)如下圖
我們需要在main包下面新建一個(gè)java根目錄
然后將java目錄改成資源根目錄。
然后再java目錄下創(chuàng)建package com.ssm 如圖
再在com.ssm下創(chuàng)建一個(gè)a.txt文件來分隔路徑
然后在com.ssm 下創(chuàng)建一下6個(gè)package,然后刪除a.txt,最后如下
修改pom.xml的內(nèi)容如下
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>自己項(xiàng)目的groupId</groupId> <artifactId>自己項(xiàng)目對應(yīng)</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>同上對應(yīng) Maven Webapp</name> <url>http://maven.apache.org</url> <properties> <!-- spring版本號 --> <spring.version>4.0.2.RELEASE</spring.version> <!-- mybatis版本號 --> <mybatis.version>3.2.6</mybatis.version> <!-- log4j日志文件管理包版本 --> <slf4j.version>1.7.7</slf4j.version> <log4j.version>1.2.17</log4j.version> </properties> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <!-- 表示開發(fā)的時(shí)候引入,發(fā)布的時(shí)候不會加載此包 --> <scope>test</scope> </dependency> <!-- spring核心包 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-oxm</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> </dependency> <!-- mybatis核心包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <!-- mybatis/spring包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.2</version> </dependency> <!-- 導(dǎo)入java ee jar 包 --> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>7.0</version> </dependency> <!-- 導(dǎo)入Mysql數(shù)據(jù)庫鏈接jar包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.30</version> </dependency> <!-- 導(dǎo)入dbcp的jar包,用來在applicationContext.xml中配置數(shù)據(jù)庫 --> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.2.2</version> </dependency> <!-- JSTL標(biāo)簽類 --> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- 日志文件管理包 --> <!-- log start --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.version}</version> </dependency> <!-- 格式化對象,方便輸出日志 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.1.41</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>${slf4j.version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>${slf4j.version}</version> </dependency> <!-- log end --> <!-- 映入JSON --> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency> <!-- 上傳組件包 --> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.9</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-messaging</artifactId> <version>4.0.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-websocket</artifactId> <version>4.0.5.RELEASE</version> </dependency> <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>2.3.1</version> </dependency> </dependencies>
<!-- 千萬不要遺漏下面的內(nèi)容,我就是遺漏了,導(dǎo)致deploment的war包里沒有mapper里的xml文件 ,ecilpse中則不會出現(xiàn)這個(gè)問題-->
<build> <finalName>ProjectMatch</finalName> <resources> <resource> <directory>${basedir}/src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> </resources> </build> </project>
然后在resources目錄下新建如下4個(gè)文件如圖
jdbc.properties 內(nèi)容如下,標(biāo)紅的地方都需要按自己數(shù)據(jù)庫修改,test為數(shù)據(jù)庫名
driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8 username=root password=123456 #定義初始連接數(shù) initialSize=0 #定義最大連接數(shù) maxActive=20 #定義最大空閑 maxIdle=20 #定義最小空閑 minIdle=1 #定義最長等待時(shí)間 maxWait=60000
log4j.properties內(nèi)容如下,可完全復(fù)制
#定義LOG輸出級別 log4j.rootLogger=INFO,Console,File #定義日志輸出目的地為控制臺 log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.Target=System.out #可以靈活地指定日志輸出格式,下面一行是指定具體的格式 log4j.appender.Console.layout = org.apache.log4j.PatternLayout log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n #文件大小到達(dá)指定尺寸的時(shí)候產(chǎn)生一個(gè)新的文件 log4j.appender.File = org.apache.log4j.RollingFileAppender #指定輸出目錄 log4j.appender.File.File = logs/ssm.log #定義文件最大大小 log4j.appender.File.MaxFileSize = 10MB # 輸出所以日志,如果換成DEBUG表示輸出DEBUG以上級別日志 log4j.appender.File.Threshold = ALL log4j.appender.File.layout = org.apache.log4j.PatternLayout log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n
spring-mvc.xml內(nèi)容如下 ,紅色標(biāo)記需要自己對應(yīng)修改
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> <!-- 自動掃描該包,使SpringMVC認(rèn)為包下用了@controller注解的類是控制器 --> <context:component-scan base-package="com.qihang.controller" /> <!--避免IE執(zhí)行AJAX時(shí),返回JSON出現(xiàn)下載文件 --> <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> </list> </property> </bean> <import resource="classpath:spring-mybatis.xml" /> <!-- 啟動SpringMVC的注解功能,完成請求和注解POJO的映射 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON轉(zhuǎn)換器 --> </list> </property> </bean> <!-- 定義跳轉(zhuǎn)的文件的前后綴 ,視圖模式配置--> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <!-- 這里的配置我的理解是自動給后面action的方法return的字符串加上前綴和后綴,變成一個(gè) 可用的url地址 --> <property name="prefix" value="/WEB-INF/page/" /> <property name="suffix" value=".jsp" /> </bean> <!-- 配置文件上傳,如果沒有使用文件上傳可以不用配置,當(dāng)然如果不配,那么配置文件中也不必引入上傳組件包 --> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!-- 默認(rèn)編碼 --> <property name="defaultEncoding" value="utf-8" /> <!-- 文件大小最大值 --> <property name="maxUploadSize" value="10485760000" /> <!-- 內(nèi)存中的最大值 --> <property name="maxInMemorySize" value="40960" /> </bean> <mvc:annotation-driven/> <mvc:default-servlet-handler/> <!--<mvc:resources location="/" mapping="/js/**" />--> <!--<mvc:resources location="/css/" mapping="/css/**"/>--> <!--<mvc:resources location="/fonts/" mapping="/fonts/**"/>--> <!--<mvc:resources location="/resources/" mapping="/resources/**"/>--> </beans>
spring-mybatis.xml內(nèi)容如下 同上
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> <!-- 自動掃描 --> <context:component-scan base-package="com.qihang" /> <!-- 引入配置文件 --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location" value="classpath:jdbc.properties" /> </bean> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driver}" /> <property name="url" value="${url}" /> <property name="username" value="${username}" /> <property name="password" value="${password}" /> <!-- 初始化連接大小 --> <property name="initialSize" value="${initialSize}"></property> <!-- 連接池最大數(shù)量 --> <property name="maxActive" value="${maxActive}"></property> <!-- 連接池最大空閑 --> <property name="maxIdle" value="${maxIdle}"></property> <!-- 連接池最小空閑 --> <property name="minIdle" value="${minIdle}"></property> <!-- 獲取連接最大等待時(shí)間 --> <property name="maxWait" value="${maxWait}"></property> </bean> <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="configLocation" value="classpath:/mybatis-config.xml"></property> <!-- 自動掃描mapping.xml文件 --> <property name="mapperLocations" value="classpath:com/qihang/mapper/*.xml"></property> </bean> <!--<!– spring和MyBatis完美整合,不需要mybatis的配置映射文件 –>--> <!--<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">--> <!--<property name="dataSource" ref="dataSource" />--> <!--<property name="configLocation" value="classpath:/mybatis-config.xml"></property>--> <!--<!– 自動掃描mapping.xml文件 –>--> <!--<property name="mapperLocations" value="classpath:com/qihang/mapper/*.xml"></property>--> <!--</bean>--> <!-- DAO接口所在包名,Spring會自動查找其下的類 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.qihang.dao" /> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property> </bean> <!-- (事務(wù)管理)transaction manager, use JtaTransactionManager for global tx --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> </beans>
然后項(xiàng)目的web.xml也要對應(yīng)修改 如下,紅色標(biāo)記同上
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" > <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> <display-name>Archetype Created Web Application</display-name> <!-- Spring和mybatis的配置文件 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mybatis.xml</param-value> </context-param> <!--Log4j配置--> <context-param> <param-name>log4jRefreshInterval</param-name> <param-value>60000</param-value> </context-param> <listener> <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class> </listener> <!-- 編碼過濾器 --> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!--Spring監(jiān)聽器 ApplicationContext 載入 --> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- 防止Spring內(nèi)存溢出監(jiān)聽器 --> <listener> <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class> </listener> <!-- Spring MVC 核心配置開始 --> <servlet> <servlet-name>mvc-dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 可以通過contextConfigLocation來自定義SpringMVC配置文件的位置,如不指定,則默認(rèn)在WEB-INF目錄下,名稱為[<servlet-name>]-servlet.xml, 此時(shí)文件名必須為[<servlet-name>]-servlet.xml,否則會出錯(cuò)--> <!--以下init-param是自定義SpringMVC的配置文件的位置 --> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> <async-supported>true</async-supported> </servlet> <!-- 攔截設(shè)置 --> <servlet-mapping> <servlet-name>mvc-dispatcher</servlet-name> <!-- 此處可以可以配置成*.do,對應(yīng)struts的后綴習(xí)慣 --> <url-pattern>/</url-pattern> </servlet-mapping> <!-- Spring MVC 核心配置結(jié)束 --> <!-- 配置SESSION超時(shí),單位是分鐘 --> <session-config> <session-timeout>15</session-timeout> </session-config> </web-app>
然后我們就可以編寫測試了。
在數(shù)據(jù)庫中創(chuàng)建user表,有兩條記錄,如圖
在pojo包中創(chuàng)建user類
package com.qihang.pojo; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.Table; @Entity @Table(name = "user") public class user { @Column(name = "username") String username; @Column(name = "password") String password; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
在dao包中創(chuàng)建userDao接口
package com.qihang.dao; import com.qihang.pojo.user; public interface userDao { public user selectByUserId(String username); public int insertUser(user user); }
在mapper包中創(chuàng)建userMapping.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.qihang.dao.userDao" > <resultMap id="BaseResultMap" type="com.qihang.pojo.user" ><!--對應(yīng)的實(shí)體類位置 --> <result column="username" property="username" jdbcType="VARCHAR" /> <result column="password" property="password" jdbcType="VARCHAR" /> </resultMap> <sql id="userAtr"> #{username},#{password} </sql> <select id="selectByUserId" parameterType="String" resultMap="BaseResultMap"> SELECT * FROM user WHERE 1=1 <if test="_parameter != null"> AND username = #{username} </if> </select> <insert id="insertUser" parameterType="java.util.HashMap"> INSERT INTO user VALUE(<include refid="userAtr"></include>) </insert> </mapper>
在services包中創(chuàng)建userService接口
package com.qihang.services; import com.qihang.pojo.user; public interface userService { public user querybyUsername(String username); public int insert(user user); }
在servicesImp中創(chuàng)建userServiceImp類
package com.qihang.servicesImp; import com.qihang.pojo.user; import com.qihang.services.userService; import com.qihang.dao.userDao; import org.springframework.stereotype.Service; import org.springframework.beans.factory.annotation.Autowired; @Service("userServiceImp") public class userServiceImp implements userService { @Autowired private userDao userDao; public int insert(user user) { return userDao.insertUser(user); } public user querybyUsername(String username) { return userDao.selectByUserId(username); } }
在WEB-INF下創(chuàng)建page包,然后在page包中創(chuàng)建test.jsp文件 如圖
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <body> 用戶名<h1>${user.username}</h1> 密碼<h1>${user.password}</h1> </body> </html>
然后在controller包下創(chuàng)建userController類
package com.qihang.controller; import com.qihang.pojo.user; import com.qihang.services.userService; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.ModelAttribute; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestParam; @Controller public class UserController { @Autowired private userService userService; @RequestMapping("/query") public String query(@RequestParam(value = "username",required = true) String username, Model model){ user user = new user(); user = userService.querybyUsername(username); model.addAttribute("user",user); return "test";
做到這里就把測試domo寫完了,下一步將項(xiàng)目部署到服務(wù)器。
如圖點(diǎn)擊配置
點(diǎn)擊 +
將本地tomcat配置好,按如圖deployment
配置好就完成了。點(diǎn)擊運(yùn)行,在瀏覽器上輸入
http://localhost:8080/query?username=lisi
看到如下就說明我們配置ok了
謝謝你們,看到這里也是幸苦了,如果還沒有成功的再認(rèn)真看看還有哪里是不是遺漏了,也可以在樓下留言,千萬別灰心,程序員工作就是與bug作斗爭的過程,也是在這些坑中慢慢學(xué)習(xí)的。
對于新手小白,經(jīng)常會花很多時(shí)間在這些框架的搭建上或是一些工具的配置,而且由于不熟悉,會踩很多坑,花大量時(shí)間在這上面確實(shí)很不值得的。寫這篇博客也是為大家能在學(xué)習(xí)的路上能更順利些,當(dāng)然也是給自己的踩坑路做個(gè)記錄吧
總結(jié)
到此這篇關(guān)于idea搭建SSM框架遇踩的坑的文章就介紹到這了,更多相關(guān)idea搭建SSM框架內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 使用IDEA搭建SSM框架的詳細(xì)教程(spring + springMVC +MyBatis)
- 使用IntelliJ IDEA搭建SSM框架的圖文教程
- 使用IDEA配置Maven搭建開發(fā)框架ssm教程
- 使用idea2017搭建SSM框架(圖文步驟)
- 教你使用idea搭建ssm詳細(xì)教程(Spring+Spring Mvc+Mybatis)
- 使用IDEA搭建ssm框架的詳細(xì)圖文教程
- IntelliJ IDEA基于SpringBoot如何搭建SSM開發(fā)環(huán)境的步驟詳解
- IDEA?+?Maven環(huán)境下的SSM框架整合及搭建過程
- 利用idea搭建SSM項(xiàng)目看這一篇就夠了
相關(guān)文章
java:程序包javax.servlet.http不存在問題解決
這篇文章主要給大家介紹了關(guān)于java:程序包javax.servlet.http不存在問題解決的相關(guān)資料,如果引用的包依賴的庫文件缺失或版本不匹配,就會導(dǎo)致"Java 程序包不存在"的錯(cuò)誤,需要的朋友可以參考下2023-10-10Java后端向前端返回文件流實(shí)現(xiàn)下載功能的方法
這篇文章主要給大家介紹了關(guān)于Java后端向前端返回文件流實(shí)現(xiàn)下載功能的相關(guān)資料,Java后端可以通過調(diào)用接口返回文件流來實(shí)現(xiàn)文件傳輸功能,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10Spring多定時(shí)任務(wù)@Scheduled執(zhí)行阻塞問題解決
這篇文章主要介紹了Spring多定時(shí)任務(wù)@Scheduled執(zhí)行阻塞問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05