eclipse中ssm整合

小白在B站跟着狂神初步学习完ssm后,整理一篇ssm框架整合笔记,此次整合根据mvc模式分层整理,方便理解,不足之处希望大佬指出。

效果和资源

完成效果
首页
在这里插入图片描述
查询页和删除页
在这里插入图片描述
新增页
在这里插入图片描述
修改页
在这里插入图片描述
此次框架搭建脚手架所有代码(前后端,包括sql)
码云链接

整合步骤

  1. 建立web项目 ,在此步骤略去;
  2. 导入maven依赖 ,主要包括servlet,jsp,spring相关(包括织入包),mybatis,mysql,c3p0,junit,log4j等,同时也要加入资源加载和tomcat等插件;
    依赖:
//dependencies
<dependencies>

   	<dependency>
   		<groupId>junit</groupId>
   		<artifactId>junit</artifactId>
   		<version>4.12</version>
   		<scope>test</scope>
   	</dependency>

<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
   	<dependency>
   		<groupId>mysql</groupId>
   		<artifactId>mysql-connector-java</artifactId>
   		<version>8.0.16</version>
   	</dependency>

   	<dependency>
   		<groupId>org.mybatis</groupId>
   		<artifactId>mybatis</artifactId>
   		<version>3.5.2</version>
   	</dependency>

<!-- https://mvnrepository.com/artifact/log4j/log4j -->
   	<dependency>
   		<groupId>log4j</groupId>
   		<artifactId>log4j</artifactId>
   		<version>1.2.17</version>
   	</dependency>

<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<!-- spring最大的jar包,其他自动导入 -->

   	<dependency>
   		<groupId>org.springframework</groupId>
   		<artifactId>spring-webmvc</artifactId>
   		<version>5.2.0.RELEASE</version>
   	</dependency>
<!-- spring操作数据库-->

   	<dependency>
   		<groupId>org.springframework</groupId>
   		<artifactId>spring-jdbc</artifactId>
   		<version>5.2.0.RELEASE</version>
   	</dependency>
<!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver AOP织入 -->
   	<dependency>
   		<groupId>org.aspectj</groupId>
   		<artifactId>aspectjweaver</artifactId>
   		<version>1.9.6</version>
   		<scope>runtime</scope>
   	</dependency>
<!-- spring整合mybatis-->
   	<dependency>
   		<groupId>org.mybatis</groupId>
   		<artifactId>mybatis-spring</artifactId>
   		<version>2.0.2</version>
   	</dependency>
   	<!-- sevlet -->
   	<dependency>
   		<groupId>javax.servlet</groupId>
   		<artifactId>javax.servlet-api</artifactId>
   		<version>3.1.0</version>
   		<scope>provided</scope>
   	</dependency>
   	<dependency>
   		<groupId>javax.servlet.jsp</groupId>
   		<artifactId>jsp-api</artifactId>
   		<version>2.2</version>
   		<scope>provided</scope>
   	</dependency>
   	<dependency>
   		<groupId>javax.servlet</groupId>
   		<artifactId>jstl</artifactId>
   		<version>1.2</version>
   	</dependency>
   	
   	<!-- https://mvnrepository.com/artifact/com.mchange/c3p0 -->
   	<dependency>
   		<groupId>com.mchange</groupId>
   		<artifactId>c3p0</artifactId>
   		<version>0.9.5.5</version>
   	</dependency>
   </dependencies>

打包方式:

	<build>
   	<resources>
   <!--  加载src/main/resources下配置文件-->
   		<resource>
   			<directory>src/main/resources</directory>
   			<includes>
   				<include>**/*.properties</include>
   				<include>**/*.xml</include>
   			</includes>
   		</resource>
   
   <!--  加载src/main/java下配置文件-->
   		<resource>
   			<directory>src/main/java</directory>
   			<includes>
   				<include>**/*.properties</include>
   				<include>**/*.xml</include>
   			</includes>
   		</resource>
   	</resources>
   	<plugins>
   		<!-- 控制编译版本 -->
   		<plugin>
   			<groupId>org.apache.maven.plugins</groupId>
   			<artifactId>maven-compiler-plugin</artifactId>
   			<version>3.7.0</version>
   			<configuration>
   				<source>1.8</source>
   				<target>1.8</target>
   			</configuration>
   		</plugin>
   		<!-- tomcat插件控制 -->
   		<plugin>
   			<groupId>org.apache.tomcat.maven</groupId>
   			<artifactId>tomcat7-maven-plugin</artifactId>
   			<version>2.2</version>
   			<configuration>
   				<port>8098</port>
   				<uriEncoding>UTF-8</uriEncoding>
   				<path>/ssm</path> <!-- 访问项目的根路径 /:表示的是tomcat的webapp下的root目录就是内个tomcat首页 -->
   			</configuration>
   		</plugin>
   	</plugins>
   </build>

tomcat插件方便项目通过maven启动。
3. 编写web.xml ,主要包括springmvc核心DispatcherServlet,spring自带乱码过滤,session有效时间,欢迎页,其中DispatcherServlet要绑定spring总的核心配置文件;

<?xml version="1.0" encoding="UTF-8"?>
<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" id="WebApp_ID" version="3.0">

 <!-- DispatcherServlet -->
 <servlet>
 <servlet-name>springmvc</servlet-name>
 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
 <init-param>
 <param-name>contextConfigLocation</param-name>
 <param-value>classpath:applicationcontext.xml</param-value>
 </init-param>
 <load-on-startup>1</load-on-startup>
 </servlet>
 <servlet-mapping>
 <servlet-name>springmvc</servlet-name>
 <url-pattern>/</url-pattern>
 </servlet-mapping>
 
 <!--乱码过滤  -->
 <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>
 
 <!--Session过期时间  -->
 <session-config>
 <session-timeout>15</session-timeout>
 </session-config>
 
 <display-name>ssm</display-name>
 <welcome-file-list>
   <welcome-file>index.jsp</welcome-file>
 </welcome-file-list>
</web-app>
  1. 编写DispatcherServlet要绑定spring总的核心配置文件applicationcontext.xml ,为了方便理解,此处applicationcontext.xml只起到引入作用,引入spring-dao.xml,spring-service.xml,spring-mvc.xml
<?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:aop="http://www.springframework.org/schema/aop"
   xmlns:context="http://www.springframework.org/schema/context"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
       https://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/aop
       https://www.springframework.org/schema/aop/spring-aop.xsd
       http://www.springframework.org/schema/context
       https://www.springframework.org/schema/context/spring-context.xsd">
       
  <import resource="classpath:spring-dao.xml"/>
  <import resource="classpath:spring-service.xml"/>
  <import resource="classpath:spring-mvc.xml"/>
   
</beans>

6.准备mybatis,编写mybatis-config.xml,数据库准备略去,在spring整合mybatis时其实可以完全将mybatis的配置交给spring,但为了突显使用了mybatis在此显示配置mybatis的部分功能,主要包括mybatis相关设置,别名

<?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="LOG4J" />
   	<!--开启缓存  -->
   	<setting name="cacheEnabled" value="true"/>
   </settings>
   <!--获取类型别名  -->
   <typeAliases>
   	<package name="com.yuke.entity" />
   </typeAliases>
</configuration>

mybatis中log4j设置

 ### set log levels 将debug等级的日志输出到console和file在两个地方###
log4j.rootLogger =DEBUG,console,file 

### 输出到控制台 ###
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern = [%c]-%m%n

### 输出到日志文件 ###
log4j.appender.file = org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.File = ./logs/log.log
log4j.appender.file.Append = true
log4j.appender.file.Threshold = DEBUG
log4j.appender.file.layout = org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 日志输出级别 ###
log4j.logger.org.mybatis=DEBUG
log4j.logger.org.java.sql=DEBUG
log4j.logger.org.java.sql.Statement=DEBUG
log4j.logger.org.java.sql.ResultSet=DEBUG
log4j.logger.org.java.sql.PreparedStatement=DEBUG

建好扫描包结构entity层:com.yuke.entity
实体层

  1. 整合mybatis,编写spring-dao.xml 主要包括连接池,mybatis核心sqlSessionFactory,sqlsession
<?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:aop="http://www.springframework.org/schema/aop"
   xmlns:context="http://www.springframework.org/schema/context"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
       https://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/aop
       https://www.springframework.org/schema/aop/spring-aop.xsd
       http://www.springframework.org/schema/context
       https://www.springframework.org/schema/context/spring-context.xsd">
       
	<!--1.关联数据库配置文件  -->
	<context:property-placeholder location="classpath:db.properties"/>

    <!--2. 加载数据库连接池,常见连接池:dbcp(半自动化,不能自动连接)c3p0(自动化加载配置文件,自动设置在对象中) druid  hikari-->
   <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
   <property name="driverClass" value="${jdbc.driver}"/>
   <property name="jdbcUrl" value="${jdbc.url}"/>
   <property name="user" value="${jdbc.username}"/>
   <property name="password" value="${jdbc.password}"/>
   
   <!-- c3p0私有属性 -->
   <!-- 最大最小连接池 -->
   <property name="maxPoolSize" value="30"></property>
   <property name="minPoolSize" value="10"></property>
   <!--关闭连接后不自动commit  -->
   <property name="autoCommitOnClose" value="false"></property>
   <!--  获取连接超时-->
   <property name="checkoutTimeout" value="10000"></property>
   <!--  连接失败重试次数-->
   <property name="acquireRetryAttempts" value="2"></property>
   </bean>
   
   <!--  3.sqlSessionFactory-->
   <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
   <property name="dataSource" ref="dataSource"/>
   <!-- 绑定mybatis配置文件 -->
   <property name="configLocation" value="classpath:mybatis-config.xml"/>
   </bean>
   
   <!--4, 配置dao接口扫描包,动态实现Dao接口可以注入到spring容器中(充当之前的sqlsession) -->
   <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
   <!--  注入sqlsessionFactroy-->
   <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
   <!-- 要扫描的包 -->
   <property name="basePackage" value="com.yuke.dao"/>
   </bean>
</beans>

建好扫描包结构dao层:com.yuke.dao,同时创建com.yuke.dao对应的mybatis中的mapper(建议不要想着偷懒利用注解完成所有数据库操作,一行sql语句可以通过注解方便解决,复杂查询等最好使用xml配置);建好数据库配置文件db.properties
dao层
在这里插入图片描述

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.yuke.dao.BookMapper">
	<select id="selectBookByMap" resultType="books" parameterType="map">
		select * from books where 1=1
		<if test="bookname != null">
			and bookname like "%"#{bookname}"%"
		</if>
		<if test="bookcount != null">
			and bookcount=#{bookcount}
		</if>
	</select>
</mapper>
jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT
jdbc.username=root
jdbc.password=Gepoint

字段前面记得加jdbc

  1. 整合service,实现sqlsession 主要包括注入接口,aop实现事务提交,此次在注入接口时利用的是注解,也可以用使用配置文件;
<?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:aop="http://www.springframework.org/schema/aop"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:tx="http://www.springframework.org/schema/tx"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
       https://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/aop
       https://www.springframework.org/schema/aop/spring-aop.xsd
       http://www.springframework.org/schema/tx
       https://www.springframework.org/schema/tx/spring-tx.xsd
       http://www.springframework.org/schema/context
       https://www.springframework.org/schema/context/spring-context.xsd">
       
       <!--1.扫描service层下的包  -->
       <context:component-scan base-package="com.yuke.service"/>
       
        <!-- 2.将所有的业务类注入到spring,可以通过注解实现 @Service @Autowired-->
       <!-- <bean id="bookServiceImpl" class="com.yuke.service.BookServiceImpl"> -->
       <!-- <property name="bookMapper" ref="bookMapper"/> -->
       <!-- </bean> -->
       <!-- 3.声明式事务配置 -->
       <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
       <!--  注入数据源-->
       <property name="dataSource" ref="dataSource"/>
       </bean>
   	<!--4.织入事务  -->
   	<!--结合AOP实现事务的织入  -->
   	<!--  配置事务通知-->
   	<tx:advice id="txAdvice"
   	transaction-manager="transactionManager">
    	<!--给那些方法配置事务  -->
    	<!-- 配置事务传播特性  propagation-->
   	<tx:attributes>
   		<tx:method name="*" propagation="REQUIRED" />
   	</tx:attributes>
   	</tx:advice> 
   	<!-- 配置事务切入 -->
   	<aop:config>
   		<aop:pointcut
   			expression="execution(* com.yuke.dao.*.*(..))" id="txpointcut" />
   		<aop:advisor advice-ref="txAdvice"
   		pointcut-ref="txpointcut" />
   	</aop:config>
</beans>

创建service层扫描包结构
在这里插入图片描述
后期通过注解注入接口**@Service @Autowired**
在这里插入图片描述

  1. 最后 整合controllerspring-mvc.xml ,主要包括springmvc中注解驱动,视图解析
<?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
       https://www.springframework.org/schema/context/spring-context.xsd
       http://www.springframework.org/schema/mvc
       https://www.springframework.org/schema/mvc/spring-mvc.xsd">
       
 	<!--1.注解驱动  -->
 	<mvc:annotation-driven/>
 	<!-- 2.静态资源过滤 -->
 	<mvc:default-servlet-handler/>
 	<!--3.扫描包:controller  -->
 	<context:component-scan base-package="com.yuke.controller"/>
 	
 	<!--4.视图解析器  -->
 	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
 	<property name="prefix" value="/WEB-INF/pages/"/>
 	<property name="suffix" value=".jsp"/>
 	</bean>
 	
</beans>

创建扫描包结构controller和视图解析包结构
在这里插入图片描述在这里插入图片描述
在此框架大致搭建完毕,当然也有许多功能没有加入,可以根据自己需要添加。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值