利用idea搭建SSM項(xiàng)目看這一篇就夠了
1. 創(chuàng)建Maven項(xiàng)目
1.1 創(chuàng)建一個(gè)新的項(xiàng)目 (請(qǐng)先連接好網(wǎng)絡(luò))

1.2 選擇maven --> 選擇你的jdk版本 --> 勾選Create from archetype

1.3 隨便選中一條輸入webapp進(jìn)行模糊查詢?nèi)缓筮x中下列我選中的內(nèi)容(重要!不可錯(cuò))

1.4 填寫你的項(xiàng)目名 --> 選擇項(xiàng)目保存到你的電腦地址 --> 隨便寫(最好用兩個(gè)單詞中間用.隔開(kāi)) --> 和項(xiàng)目名保持一致

1.5 選擇你的maven安裝包地址 --> 查看settings.xml文件是否在idea顯示的地址 -->查看你的下載資源本地倉(cāng)庫(kù)是否在idea顯示的地址
(如果有誤或自己整改過(guò)都要進(jìn)行修改和idea保持一致)

1.6 正在創(chuàng)建中...請(qǐng)稍后(注意!!!創(chuàng)建maven項(xiàng)目請(qǐng)先連接網(wǎng)絡(luò))

1.7 控制臺(tái)出現(xiàn)(BUILD SUCCESS)代表Maven項(xiàng)目已創(chuàng)建成功

2. 搭建項(xiàng)目相關(guān)目錄
2.1 選中main文件夾右鍵

2.2 new一個(gè)新的文件夾選中(new --> Directory)

2.3 此操作要操作兩遍因?yàn)橐砑酉路綀D中這兩個(gè)文件夾(java,resources)

2.4 選中src文件夾右鍵

2.5 new一個(gè)新的文件夾(new --> Directory)

2.6 選中添加下方圖中文件夾即可(test\java)

3. 添加pom相關(guān)依賴
直接復(fù)制下方依賴覆蓋你自己創(chuàng)建好的項(xiàng)目pom文件中即可
<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.jmh</groupId>
<artifactId>mybatis03</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<name>mybatis03 Maven Webapp</name>
<!-- FIXME change it to the project's website -->
<url>http://www.example.com</url>
<!--版本-->
<properties>
<spring.version>5.0.2.RELEASE</spring.version>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<jackson.version>2.9.3</jackson.version>
<shiro.version>1.2.5</shiro.version>
<slf4j.version>1.7.7</slf4j.version>
<log4j2.version>2.9.1</log4j2.version>
</properties>
<dependencies>
<!-- **********************spring依賴 ********************** -->
<!--1)spring核心依賴-->
<!-- ********************** spring-ore核心依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<!--spring ioc依賴 -->
<!-- ********************** spring-ioc依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring.version}</version>
</dependency>
<!--spring 擴(kuò)展依賴 -->
<!-- ********************** spring-context依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<!--2)spring dao層依賴-->
<!-- ********************** spring-orm依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- ********************** spring-tx依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>${spring.version}
</version>
</dependency>
<!--3)aop相關(guān)依賴 -->
<!-- ********************** spring-aspects依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>${spring.version}</version>
</dependency>
<!--4)spring web相關(guān)依賴 -->
<!-- ********************** spring-web依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<!--5) spring test相關(guān)依賴 -->
<!-- ********************** spring-test依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- ********************** spring-webmvc依賴 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- ********************** JSTL依賴 ********************** -->
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
<!-- ********************** Json相關(guān)依賴 ********************** -->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>${jackson.version}</version>
<exclusions>
<exclusion>
<artifactId>jackson-annotations</artifactId>
<groupId>com.fasterxml.jackson.core</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>${jackson.version}</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>${jackson.version}</version>
</dependency>
<!-- ********************** 文件上傳依賴 ********************** -->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.3</version>
</dependency>
<!-- ********************** JSR303依賴 ********************** -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
<version>6.0.7.Final</version>
</dependency>
<!-- ********************** junit單元測(cè)試依賴 ********************** -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<!-- ********************** JavaServlet API ********************** -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.0</version>
<scope>provided</scope>
</dependency>
<!-- ********************** Mybatis依賴 ********************** -->
<!--1) mybatis核心 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
<!--2) Mybatis分頁(yè)插件-->
<!-- ********************** Mybatis分頁(yè)插件 ********************** -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.2</version>
</dependency>
<!--3) spring整合mybatis -->
<!-- ********************** spring整合mybatis ********************** -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.1</version>
</dependency>
<!-- ********************** MysqlJDBC驅(qū)動(dòng) ********************** -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.44</version>
</dependency>
<!--dbcp2連接池依賴-->
<!-- ********************** dbcp2連接池依賴 ********************** -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
<version>2.1.1</version>
</dependency>
<!-- ********************** commons-pool2 ********************** -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.4.3</version>
</dependency>
<!-- ********************** 日志配置 ********************** -->
<!--記得修改mybatis.cfg.xml添加如下內(nèi)容-->
<!--<setting name="logImpl"value="LOG4J2"/>-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>${slf4j.version}</version>
<scope>runtime</scope>
<exclusions>
<exclusion>
<artifactId>slf4j-api</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<!-- 用于與slf4j保持橋接-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>${log4j2.version}</version>
<exclusions>
<exclusion>
<artifactId>slf4j-api</artifactId>
<groupId>org.slf4j</groupId>
</exclusion>
</exclusions>
</dependency>
<!--核心log4j2jar包-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j2.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j2.version}</version>
</dependency>
<!--web工程需要包含log4j-web,非web工程不需要-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
<version>${log4j2.version}</version>
</dependency>
<!--需要使用log4j2的AsyncLogger需要包含disruptor -->
<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>3.2.0</version>
</dependency>
<!-- ********************** lombok依賴 ********************** -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.20</version>
<scope>provided</scope>
</dependency>
<!-- ********************** shiro相關(guān)依賴 ********************** -->
<!-- shiro核心包 -->
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-core</artifactId>
<version>${shiro.version}</version>
</dependency>
<!-- 添加shiro web支持 -->
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-web</artifactId>
<version>${shiro.version}</version>
</dependency>
<!--shiro和spring的集成-->
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-spring</artifactId>
<version>${shiro.version}</version>
</dependency>
</dependencies>
<!--插件部分-->
<build>
<finalName>ssm</finalName>
<resources>
<!--解決mybatis-generator-maven-plugin運(yùn)行時(shí)沒(méi)有將XxxMapper.xml文件放入target文件夾的問(wèn)題-->
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
<!--解決mybatis-generator-maven-plugin運(yùn)行時(shí)沒(méi)有將jdbc.properites文件放入target文件夾的問(wèn)題-->
<resource>
<directory>src/main/resources</directory>
<includes>
<include>jdbc.properties</include>
<include>*.xml</include>
</includes>
</resource>
</resources>
<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
<plugins>
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.2</version>
<dependencies>
<!--使用Mybatis-generator插件不能使用太高版本的mysql驅(qū)動(dòng)-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.44</version>
</dependency>
</dependencies>
<configuration>
<overwrite>true</overwrite>
</configuration>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>4. 添加/修改相關(guān)配置文件
4.1 jdbc.properties(添加到main文件夾 --> resources文件夾下面)
下方配置文件需要修改:
1. 你的數(shù)據(jù)庫(kù)名稱
2. 你的數(shù)據(jù)庫(kù)登錄賬號(hào)
3. 你的數(shù)據(jù)庫(kù)登錄密碼
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/你的數(shù)據(jù)庫(kù)名稱?useUnicode=true&characterEncoding=UTF-8 jdbc.username=你的數(shù)據(jù)庫(kù)登錄賬號(hào) jdbc.password=你的數(shù)據(jù)庫(kù)登錄密碼
4.2 log4j2.xml(添加到main文件夾 --> resources文件夾下面)
<?xml version="1.0" encoding="UTF-8"?>
<!-- status : 指定log4j本身的打印日志的級(jí)別.ALL< Trace < DEBUG < INFO < WARN < ERROR
< FATAL < OFF。 monitorInterval : 用于指定log4j自動(dòng)重新配置的監(jiān)測(cè)間隔時(shí)間,單位是s,最小是5s. -->
<Configuration status="WARN" monitorInterval="30">
<Properties>
<!-- 配置日志文件輸出目錄 ${sys:user.home} -->
<Property name="LOG_HOME">/root/workspace/lucenedemo/logs</Property>
<property name="ERROR_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/error</property>
<property name="WARN_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/warn</property>
<property name="PATTERN">%d{yyyy-MM-dd HH:mm:ss.SSS} [%t-%L] %-5level %logger{36} - %msg%n</property>
</Properties>
<Appenders>
<!--這個(gè)輸出控制臺(tái)的配置 -->
<Console name="Console" target="SYSTEM_OUT">
<!-- 控制臺(tái)只輸出level及以上級(jí)別的信息(onMatch),其他的直接拒絕(onMismatch) -->
<ThresholdFilter level="trace" onMatch="ACCEPT"
onMismatch="DENY" />
<!-- 輸出日志的格式 -->
<!-- %d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生產(chǎn)時(shí)間 %p : 日志輸出格式 %c : logger的名稱
%m : 日志內(nèi)容,即 logger.info("message") %n : 換行符 %C : Java類名 %L : 日志輸出所在行數(shù) %M
: 日志輸出所在方法名 hostName : 本地機(jī)器名 hostAddress : 本地ip地址 -->
<PatternLayout pattern="${PATTERN}" />
</Console>
<!--文件會(huì)打印出所有信息,這個(gè)log每次運(yùn)行程序會(huì)自動(dòng)清空,由append屬性決定,這個(gè)也挺有用的,適合臨時(shí)測(cè)試用 -->
<!--append為TRUE表示消息增加到指定文件中,false表示消息覆蓋指定的文件內(nèi)容,默認(rèn)值是true -->
<File name="log" fileName="logs/test.log" append="false">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
</File>
<!-- 這個(gè)會(huì)打印出所有的info及以下級(jí)別的信息,每次大小超過(guò)size, 則這size大小的日志會(huì)自動(dòng)存入按年份-月份建立的文件夾下面并進(jìn)行壓縮,作為存檔 -->
<RollingFile name="RollingFileInfo" fileName="${LOG_HOME}/info.log"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log">
<!--控制臺(tái)只輸出level及以上級(jí)別的信息(onMatch),其他的直接拒絕(onMismatch) -->
<ThresholdFilter level="info" onMatch="ACCEPT"
onMismatch="DENY" />
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
<Policies>
<!-- 基于時(shí)間的滾動(dòng)策略,interval屬性用來(lái)指定多久滾動(dòng)一次,默認(rèn)是1 hour。 modulate=true用來(lái)調(diào)整時(shí)間:比如現(xiàn)在是早上3am,interval是4,那么第一次滾動(dòng)是在4am,接著是8am,12am...而不是7am. -->
<!-- 關(guān)鍵點(diǎn)在于 filePattern后的日期格式,以及TimeBasedTriggeringPolicy的interval, 日期格式精確到哪一位,interval也精確到哪一個(gè)單位 -->
<!-- log4j2的按天分日志文件 : info-%d{yyyy-MM-dd}-%i.log -->
<TimeBasedTriggeringPolicy interval="1"
modulate="true" />
<!-- SizeBasedTriggeringPolicy:Policies子節(jié)點(diǎn), 基于指定文件大小的滾動(dòng)策略,size屬性用來(lái)定義每個(gè)日志文件的大小. -->
<!-- <SizeBasedTriggeringPolicy size="2 kB" /> -->
</Policies>
</RollingFile>
<RollingFile name="RollingFileWarn" fileName="${WARN_LOG_FILE_NAME}/warn.log"
filePattern="${WARN_LOG_FILE_NAME}/$${date:yyyy-MM}/warn-%d{yyyy-MM-dd}-%i.log">
<ThresholdFilter level="warn" onMatch="ACCEPT"
onMismatch="DENY" />
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="2 kB" />
</Policies>
<!-- DefaultRolloverStrategy屬性如不設(shè)置,則默認(rèn)為最多同一文件夾下7個(gè)文件,這里設(shè)置了20 -->
<DefaultRolloverStrategy max="20" />
</RollingFile>
<RollingFile name="RollingFileError" fileName="${ERROR_LOG_FILE_NAME}/error.log"
filePattern="${ERROR_LOG_FILE_NAME}/$${date:yyyy-MM}/error-%d{yyyy-MM-dd-HH-mm}-%i.log">
<ThresholdFilter level="error" onMatch="ACCEPT"
onMismatch="DENY" />
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
<Policies>
<!-- log4j2的按分鐘 分日志文件 : warn-%d{yyyy-MM-dd-HH-mm}-%i.log -->
<TimeBasedTriggeringPolicy interval="1"
modulate="true" />
<!-- <SizeBasedTriggeringPolicy size="10 MB" /> -->
</Policies>
</RollingFile>
</Appenders>
<!--然后定義logger,只有定義了logger并引入的appender,appender才會(huì)生效 -->
<Loggers>
<!--過(guò)濾掉spring和mybatis的一些無(wú)用的DEBUG信息 -->
<logger name="org.springframework" level="INFO"></logger>
<logger name="org.mybatis" level="INFO"></logger>
<!-- 第三方日志系統(tǒng) -->
<logger name="org.springframework" level="ERROR" />
<logger name="org.hibernate" level="ERROR" />
<logger name="org.apache.struts2" level="ERROR" />
<logger name="com.opensymphony.xwork2" level="ERROR" />
<logger name="org.jboss" level="ERROR" />
<!-- 配置日志的根節(jié)點(diǎn) -->
<root level="all">
<appender-ref ref="Console" />
<appender-ref ref="RollingFileInfo" />
<appender-ref ref="RollingFileWarn" />
<appender-ref ref="RollingFileError" />
</root>
</Loggers>
</Configuration>4.3 mybatis.cfg.xml(添加到main文件夾 --> resources文件夾下面)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--日志配置-->
<settings>
<setting name="logImpl" value="LOG4J2"/>
</settings>
<!--分頁(yè)配置-->
<plugins>
<plugin interceptor="com.github.pagehelper.PageInterceptor">
</plugin>
</plugins>
</configuration>4.4 spring.xml(添加到main文件夾 --> resources文件夾下面)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--1. 引入外部properties文件 -->
<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="systemPropertiesModeName" value="SYSTEM_PROPERTIES_MODE_OVERRIDE" />
<property name="ignoreResourceNotFound" value="true" />
<property name="locations">
<list>
<value>classpath:jdbc.properties</value>
<!--<value>classpath:config.properties</value>-->
<!--<value>classpath:shiro-config.properties</value>-->
</list>
</property>
</bean>
<import resource="spring-mybatis.xml"/>
<!--導(dǎo)入的是下方4.5配置文件-->
</beans>4.5 spring-mybatis.xml(添加到main文件夾 --> resources文件夾下面)
下方配置文件需要修改(注?。?!需要修改的地方已用注釋標(biāo)注):
<?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:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">
<!--1. 注解式開(kāi)發(fā) -->
<!--1) 注解驅(qū)動(dòng) -->
<!-- <context:annotation-config/>
<!–2) 用注解方式注入bean,并指定查找范圍:com.zking.oa及子子孫孫包–>
<context:component-scan base-package="com.jmh.mybatis"/>-->
<!--****************************** 需要修改01 ***************************************-->
<context:component-scan base-package="com.jmh.shiro" use-default-filters="true">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<!--<context:exclude-filter type="regex" expression=".+\.controller2\..*"/>-->
</context:component-scan>
<!-- 已在spring.xml中配置,只能引入一次 -->
<!--2. 引入外置jdbc配置文件 -->
<!--<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">-->
<!--<property name="location" value="classpath:jdbc.properties"/>-->
<!--</bean>-->
<!--3. dbcp2數(shù)據(jù)庫(kù)連接池配置-->
<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<!--初始連接數(shù)-->
<property name="initialSize" value="10"/>
<!--最大活動(dòng)連接數(shù)-->
<property name="maxTotal" value="100"/>
<!--最大空閑連接數(shù)-->
<property name="maxIdle" value="50"/>
<!--最小空閑連接數(shù)-->
<property name="minIdle" value="10"/>
<!--設(shè)置為-1時(shí),如果沒(méi)有可用連接,連接池會(huì)一直無(wú)限期等待,直到獲取到連接為止。-->
<!--如果設(shè)置為N(毫秒),則連接池會(huì)等待N毫秒,等待不到,則拋出異常-->
<property name="maxWaitMillis" value="-1"/>
</bean>
<!--4. spring和MyBatis整合 -->
<!--1) 創(chuàng)建sqlSessionFactory-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 指定數(shù)據(jù)源 -->
<property name="dataSource" ref="dataSource"/>
<!-- 指定mybatis核心配置文件 -->
<property name="configLocation" value="classpath:mybatis.cfg.xml"/>
<!-- 自動(dòng)掃描XxxMapping.xml文件,**任意路徑 -->
<!--****************************** 需要修改02 ***************************************-->
<property name="mapperLocations" value="classpath:com/jmh/shiro/**/mapper/*.xml"/>
<!-- 指定別名 -->
<!--****************************** 需要修改03 ***************************************-->
<property name="typeAliasesPackage" value="com.jmh.shiro.model"/>
</bean>
<!--2) 自動(dòng)掃描com/zking/oa/**/mapper下的所有XxxMapper接口(其實(shí)就是DAO接口),并實(shí)現(xiàn)這些接口,-->
<!-- 即可直接在程序中使用dao接口,不用再獲取sqlsession對(duì)象-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--basePackage 屬性是映射器接口文件的包路徑。-->
<!--你可以使用分號(hào)或逗號(hào) 作為分隔符設(shè)置多于一個(gè)的包路徑-->
<!--****************************** 需要修改04 ***************************************-->
<property name="basePackage" value="com/jmh/shiro/**/mapper"/><!--需修改-->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>
<!--1) 事務(wù)管理器 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!--2. 注解式事務(wù)配置開(kāi)始 -->
<tx:annotation-driven transaction-manager="transactionManager"/>
<!--3) 開(kāi)啟自動(dòng)代理 -->
<aop:aspectj-autoproxy/>
</beans>4.6 spring-mvc.xml(添加到main文件夾 --> webapp文件夾 --> WEB-INF文件夾下面)
下方配置文件需要修改(注?。?!需要修改的地方已用注釋標(biāo)注):
<?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: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.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 通過(guò)context:component-scan元素掃描指定包下的控制器-->
<!--1) 掃描com.zking.zf及子子孫孫包下的控制器(掃描范圍過(guò)大,耗時(shí))-->
<!--<context:component-scan base-package="com.zking.zf"/>-->
<!--1) use-dafault-filters="false"的情況下,根據(jù)表達(dá)式包含(include-filter)或排除(exclude-filter)指定包-->
<!--****************************** 需要修改01 ***************************************-->
<context:component-scan base-package="com.jmh.shiro" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
<!--<context:exclude-filter type="regex" expression=".+\.controller2\..*"/>-->
</context:component-scan>
<!--2) 此標(biāo)簽?zāi)J(rèn)注冊(cè)DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter -->
<!--兩個(gè)bean,這兩個(gè)bean是spring MVC為@Controllers分發(fā)請(qǐng)求所必須的。并提供了數(shù)據(jù)綁定支持,-->
<!--@NumberFormatannotation支持,@DateTimeFormat支持,@Valid支持,讀寫XML的支持(JAXB),讀寫JSON的支持(Jackson)-->
<mvc:annotation-driven></mvc:annotation-driven>
<!--3) ViewResolver -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- viewClass需要在pom中引入兩個(gè)包:standard.jar and jstl.jar -->
<property name="viewClass"
value="org.springframework.web.servlet.view.JstlView"></property>
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>
<!--4) 單獨(dú)處理圖片、樣式、js等資源 -->
<mvc:resources location="/static/css/" mapping="/static/css/**"/>
<mvc:resources location="/static/images/" mapping="/static/images/**"/>
<mvc:resources location="/static/js/" mapping="/static/js/**"/>
</beans>4.7 修改web.xml相關(guān)配置
可直接復(fù)制覆蓋你的web.xml文件
下方配置文件需要修改(注?。?!需要修改的地方已用注釋標(biāo)注):
1. 需要修改01(你要映射的.xml文件名)
2. 需要修改02 (中文亂碼過(guò)濾器配置(已在下方提供代碼資源))
3. 需要修改03 (那里面的.xml文件修改成上方4.6添加的spring-mvc.xml文件名即可)
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
<display-name>Archetype Created Web Application</display-name>
<!-- Spring和web項(xiàng)目集成start -->
<!-- spring上下文配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<!--****************************** 需要修改01 ***************************************-->
<param-value>classpath:spring.xml</param-value>
</context-param>
<!-- 讀取Spring上下文的監(jiān)聽(tīng)器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- Spring和web項(xiàng)目集成end -->
<!-- 防止Spring內(nèi)存溢出監(jiān)聽(tīng)器 -->
<listener>
<listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
</listener>
<!-- 中文亂碼處理 -->
<filter>
<filter-name>encodingFilter</filter-name>
<!--****************************** 需要修改02 ***************************************-->
<filter-class>com.jmh.shiro.utils.EncodingFiter</filter-class>
<!--web.xml 3.0的新特性,是否支持異步-->
<async-supported>true</async-supported>
<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 MVC servlet -->
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--此參數(shù)可以不配置,默認(rèn)值為:/WEB-INF/springmvc-servlet.xml-->
<init-param>
<param-name>contextConfigLocation</param-name>
<!--****************************** 需要修改03 ***************************************-->
<param-value>/WEB-INF/spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<!--web.xml 3.0的新特性,是否支持異步-->
<async-supported>true</async-supported>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>EncodingFiter
package com.jmh.ssm.utils;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.Map;
/**
* 中文亂碼處理
*
*/
public class EncodingFiter implements Filter {
private String encoding = "UTF-8";// 默認(rèn)字符集
public EncodingFiter() {
super();
}
public void destroy() {
}
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain)
throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) servletRequest;
HttpServletResponse response = (HttpServletResponse) servletResponse;
String method = request.getMethod();
if (method.equalsIgnoreCase("get")) {
Map<String, String[]> map = (Map<String, String[]>) request.getParameterMap();// 保存所有參數(shù)名=參數(shù)值(數(shù)組)的Map集合
for (String[] values : map.values()) {
for (int i = 0; i < values.length; i++) {
values[i] = new String(values[i].getBytes("ISO-8859-1"), this.encoding);
}
}
} else if (method.equalsIgnoreCase("post")) {
request.setCharacterEncoding(this.encoding);
}
response.setContentType("text/html;charset=" + this.encoding);
chain.doFilter(servletRequest, servletResponse);
}
public void init(FilterConfig filterConfig) throws ServletException {
String s = filterConfig.getInitParameter("encoding");// 讀取web.xml文件中配置的字符集
if (null != s && !s.trim().equals("")) {
this.encoding = s.trim();
}
}
}4.8 generatorConfig.xml(添加到main文件夾 --> resources文件夾下面)
下方配置文件需要修改(注?。?!需要修改的地方已用注釋標(biāo)注):
1. 需要修改01 (你的mysql jar包的放置地址路徑位置)
2. 需要修改02 (生成實(shí)體類的模塊位置比如xxx.xxx.xxx.model)
3. 需要修改03 (生成sql映射文件位置)
4. 需要修改04 (生成mapper接口位置)
5. 最后就是table標(biāo)簽需要修改的屬性值!一個(gè)table標(biāo)簽就是一張表可以這么理解
需要修改的table標(biāo)簽也就兩個(gè)屬性:
5.1 tableName="這里填寫的就是你要生成的表名稱"
5.2 domainObjectName="這里就是你要生成的表對(duì)應(yīng)的實(shí)體類名稱"
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >
<generatorConfiguration>
<!-- 引入配置文件 -->
<properties resource="jdbc.properties"/>
<!--指定數(shù)據(jù)庫(kù)jdbc驅(qū)動(dòng)jar包的位置-->
<!--****************************** 需要修改01 ***************************************-->
<classPathEntry location="E:\\mysql"/>
<!-- 一個(gè)數(shù)據(jù)庫(kù)一個(gè)context -->
<context id="infoGuardian">
<!-- 注釋 -->
<commentGenerator>
<property name="suppressAllComments" value="true"/><!-- 是否取消注釋 -->
<property name="suppressDate" value="true"/> <!-- 是否生成注釋代時(shí)間戳 -->
</commentGenerator>
<!-- jdbc連接 -->
<jdbcConnection driverClass="${jdbc.driver}"
connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}"/>
<!-- 類型轉(zhuǎn)換 -->
<javaTypeResolver>
<!-- 是否使用bigDecimal, false可自動(dòng)轉(zhuǎn)化以下類型(Long, Integer, Short, etc.) -->
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
<!-- 01 指定javaBean生成的位置 -->
<!-- targetPackage:指定生成的model生成所在的包名 -->
<!-- targetProject:指定在該項(xiàng)目下所在的路徑 -->
<!--****************************** 需要修改02 ***************************************-->
<javaModelGenerator targetPackage="com.jmh.shiro.model"
targetProject="src/main/java">
<!-- 是否允許子包,即targetPackage.schemaName.tableName -->
<property name="enableSubPackages" value="false"/>
<!-- 是否對(duì)model添加構(gòu)造函數(shù) -->
<property name="constructorBased" value="true"/>
<!-- 是否針對(duì)string類型的字段在set的時(shí)候進(jìn)行trim調(diào)用 -->
<property name="trimStrings" value="false"/>
<!-- 建立的Model對(duì)象是否 不可改變 即生成的Model對(duì)象不會(huì)有 setter方法,只有構(gòu)造方法 -->
<property name="immutable" value="false"/>
</javaModelGenerator>
<!-- 02 XxxMapper.xml指定sql映射文件生成的位置 -->
<!--****************************** 需要修改03 ***************************************-->
<sqlMapGenerator targetPackage="com.jmh.shiro.mapper"
targetProject="src/main/java">
<!-- 是否允許子包,即targetPackage.schemaName.tableName -->
<property name="enableSubPackages" value="false"/>
</sqlMapGenerator>
<!-- 03 生成XxxMapper接口 -->
<!-- type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper對(duì)象 -->
<!-- type="MIXEDMAPPER",生成基于注解的Java Model 和相應(yīng)的Mapper對(duì)象 -->
<!-- type="XMLMAPPER",生成SQLMap XML文件和獨(dú)立的Mapper接口 -->
<!--****************************** 需要修改04 ***************************************-->
<javaClientGenerator targetPackage="com.jmh.shiro.mapper"
targetProject="src/main/java" type="XMLMAPPER">
<!-- 是否在當(dāng)前路徑下新加一層schema,false路徑com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->
<property name="enableSubPackages" value="false"/>
</javaClientGenerator>
<!-- 配置表信息 -->
<!-- schema即為數(shù)據(jù)庫(kù)名 -->
<!-- tableName為對(duì)應(yīng)的數(shù)據(jù)庫(kù)表 -->
<!-- domainObjectName是要生成的實(shí)體類 -->
<!-- enable*ByExample是否生成 example類 -->
<table schema="" tableName="t_sys_user" domainObjectName="User"
enableCountByExample="false" enableDeleteByExample="false"
enableSelectByExample="false" enableUpdateByExample="false">
<!-- 忽略列,不生成bean 字段 -->
<!-- <ignoreColumn column="FRED" /> -->
<!-- 指定列的java數(shù)據(jù)類型 -->
<!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> -->
</table>
<table schema="" tableName="t_sys_permission" domainObjectName="Permission"
enableCountByExample="false" enableDeleteByExample="false"
enableSelectByExample="false" enableUpdateByExample="false">
<!-- 忽略列,不生成bean 字段 -->
<!-- <ignoreColumn column="FRED" /> -->
<!-- 指定列的java數(shù)據(jù)類型 -->
<!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> -->
</table>
<table schema="" tableName="t_sys_role" domainObjectName="Role"
enableCountByExample="false" enableDeleteByExample="false"
enableSelectByExample="false" enableUpdateByExample="false">
<!-- 忽略列,不生成bean 字段 -->
<!-- <ignoreColumn column="FRED" /> -->
<!-- 指定列的java數(shù)據(jù)類型 -->
<!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> -->
</table>
</context>
</generatorConfiguration>4.8.1 添加Maven自動(dòng)生成插件
命令如下:
mybatis-generator:generate -e
好吧!我還是當(dāng)個(gè)老保姆一步步帶你們?cè)趺刺砑雍冒?[表情委屈委屈]
4.8.1.1

4.8.1.2 點(diǎn)擊+號(hào)

4.8.1.3 選擇Maven

4.8.1.4 注意!復(fù)制命令的時(shí)候不要多復(fù)制空

4.8.1.5

4.8.1.6 ok!
下方就是生成成功啦 如果你沒(méi)有像圖中這個(gè)小企鵝的話你也可以忽略這個(gè)作用就是方便我們查看sql映射文件的代碼...如果你想要這個(gè)功能的話下載Mybatis插件“ free mybatis plugins”如果沒(méi)有這個(gè)插件的話就是版本問(wèn)題就下載Mybatis插件‘’ MybatisX ”

ok!ssm項(xiàng)目基本就搭建好了然后下方我們就測(cè)試一下吧
5. 使用junit and Tomcat分別測(cè)試是否搭建成功
5.1 junit測(cè)試
5.1.1 需要在Mapper層接口添加@Repository注解
@Repository 將DAO類聲明為Bean3
5.1.2 Service層代碼 需在service層接口添加@Transactional注解
可直接復(fù)制Mapper接口粘貼即可需修改@注解
@Transactional 注解配置事務(wù),個(gè)人感覺(jué)寫XML配置聲明式事務(wù)更加簡(jiǎn)單
@Transactional(readOnly = true) 在方法前面加上就代表是只讀事務(wù)
package com.jmh.ssm.service;
import com.jmh.ssm.model.User;
import org.springframework.stereotype.Repository;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Transactional
public interface IUserService {
int deleteByPrimaryKey(Integer userid);
int insert(User record);
int insertSelective(User record);
@Transactional(readOnly = true)
User selectByPrimaryKey(Integer userid);
int updateByPrimaryKeySelective(User record);
int updateByPrimaryKey(User record);
}5.1.3 Service.impl層代碼 需在Service.impl層接口實(shí)現(xiàn)類添加@Service() 注解
此時(shí)Service實(shí)現(xiàn)類需要依賴Mapper層接口 我們需要注入Mapper層接口添加@Resource注解
@Service() 通常作用在業(yè)務(wù)層
@Resource的裝配順序:
1、@Resource后面沒(méi)有任何內(nèi)容,默認(rèn)通過(guò)name屬性去匹配bean,找不到再按type去匹配
2、指定了name或者type則根據(jù)指定的類型去匹配bean
3、指定了name和type則根據(jù)指定的name和type去匹配bean,任何一個(gè)不匹配都將報(bào)錯(cuò)
package com.jmh.ssm.service.impl;
import com.jmh.ssm.mapper.UserMapper;
import com.jmh.ssm.model.User;
import com.jmh.ssm.service.IUserService;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
@Service
public class UserServiceImpl implements IUserService {
//注入
@Resource
private UserMapper userMapper;
@Override
public int deleteByPrimaryKey(Integer userid) {
return 0;
}
@Override
public int insert(User record) {
return 0;
}
@Override
public int insertSelective(User record) {
return 0;
}
@Override
public User selectByPrimaryKey(Integer userid) {
return userMapper.selectByPrimaryKey(userid);
}
@Override
public int updateByPrimaryKeySelective(User record) {
return 0;
}
@Override
public int updateByPrimaryKey(User record) {
return 0;
}
}5.1.4 使用junit單元測(cè)試
創(chuàng)建BaseTestCat類
創(chuàng)建BaseTestCat類需添加以下兩個(gè)注解:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:spring.xml"})spring.xml文件對(duì)應(yīng)你要映射的.xml文件名
package com.jmh.mybatis.service.impl;
import org.junit.Before;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:spring.xml"})
public class BaseTestCat {
@Before
public void setUp(){
}
}創(chuàng)建junit測(cè)試類需繼承上方BaseTestCat類 重寫B(tài)aseTestCat類里面的方法
package com.jmh.ssm.service.impl;
import com.jmh.ssm.model.User;
import com.jmh.ssm.service.IUserService;
import org.junit.Test;
import javax.annotation.Resource;
import static org.junit.Assert.*;
public class UserServiceImplTest extends BaseTestCat{
//注入
@Resource
private IUserService iUserService;
@Override
public void setUp() {
super.setUp();
}
@Test
public void deleteByPrimaryKey() {
}
@Test
public void insert() {
}
@Test
public void insertSelective() {
}
@Test
public void selectByPrimaryKey() {
User user = iUserService.selectByPrimaryKey(1);
System.out.println(user);
}
@Test
public void updateByPrimaryKeySelective() {
}
@Test
public void updateByPrimaryKey() {
}
}隨便測(cè)試一個(gè)方法成功就是成功!失敗就是失??!


5.2 Tomcat測(cè)試
5.2.1 前端代碼(在WEB-INF下面創(chuàng)建一個(gè)jsp文件夾 在jsp文件夾里面創(chuàng)建一個(gè)index.jsp頁(yè)面)
<%--
Created by IntelliJ IDEA.
User: 蔣明輝
Date: 2022/8/21
Time: 2:59
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>搭建SSM項(xiàng)目</title>
</head>
<body>
<h1>搭建SSM項(xiàng)目成功!</h1>
</body>
</html>5.2.2 Controller層代碼
package com.jmh.ssm.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/**
* Tomcat測(cè)試
*/
@Controller
public class SsmController {
@RequestMapping("/")//請(qǐng)求路徑:當(dāng)前/是打開(kāi)服務(wù)器自動(dòng)請(qǐng)求的第一個(gè)頁(yè)面
public String toIndex(){
return "index";//跳轉(zhuǎn)視圖名稱
}
}5.2.3 搭建Tomcat服務(wù)器









嘿嘿!現(xiàn)在最關(guān)鍵的時(shí)候到啦看看能不能第一時(shí)間訪問(wèn)index.jsp頁(yè)面啦

ok!訪問(wèn)成功 測(cè)試完畢
總結(jié)
到此這篇關(guān)于利用idea搭建SSM項(xiàng)目的文章就介紹到這了,更多相關(guān)idea搭建SSM項(xiàng)目?jī)?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中StringBuilder字符串類型的操作方法及API整理
Java中的StringBuffer類繼承于AbstractStringBuilder,用來(lái)創(chuàng)建非線程安全的字符串類型對(duì)象,下面即是對(duì)Java中StringBuilder字符串類型的操作方法及API整理2016-05-05
java Struts2框架下實(shí)現(xiàn)文件上傳功能
這篇文章主要為大家詳細(xì)介紹了java Struts2框架下實(shí)現(xiàn)文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
Spring 事務(wù)事件監(jiān)控及實(shí)現(xiàn)原理解析
本文首先會(huì)使用實(shí)例進(jìn)行講解Spring事務(wù)事件是如何使用的,然后會(huì)講解這種使用方式的實(shí)現(xiàn)原理。感興趣的朋友跟隨小編一起看看吧2018-09-09
基于Java?NIO編寫一個(gè)簡(jiǎn)單版Netty服務(wù)端
基于?NIO?實(shí)現(xiàn)的網(wǎng)絡(luò)框架,可以用少量的線程,處理大量的連接,更適用于高并發(fā)場(chǎng)景,所以被就將利用NIO編寫一個(gè)簡(jiǎn)單版Netty服務(wù)端,需要的可以參考下2024-04-04
Java實(shí)現(xiàn)模擬鍵盤鼠標(biāo)操作工具
在桌面自動(dòng)化、軟件測(cè)試、游戲開(kāi)發(fā)以及遠(yuǎn)程控制等領(lǐng)域中,模擬鍵盤和鼠標(biāo)操作是一項(xiàng)非常實(shí)用的技術(shù),本文將使用?Java?實(shí)現(xiàn)一個(gè)模擬鍵盤與鼠標(biāo)操作的工具,希望對(duì)大家有所幫助2025-03-03
Java Spring Security認(rèn)證與授權(quán)及注銷和權(quán)限控制篇綜合解析
Spring Security 是 Spring 家族中的一個(gè)安全管理框架,實(shí)際上,在 Spring Boot 出現(xiàn)之前,Spring Security 就已經(jīng)發(fā)展了多年了,但是使用的并不多,安全管理這個(gè)領(lǐng)域,一直是 Shiro 的天下2021-10-10
Spring中任務(wù)調(diào)度之解讀@Scheduled和@Schedules注解的使用
這篇文章主要介紹了Spring中任務(wù)調(diào)度之解讀@Scheduled和@Schedules注解的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04



