100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > SSM框架整合步骤(Spring+SpringMVC+MyBatis)

SSM框架整合步骤(Spring+SpringMVC+MyBatis)

时间:2022-09-24 02:41:07

相关推荐

SSM框架整合步骤(Spring+SpringMVC+MyBatis)

SSM

1.创建maven工程2.导入maven坐标3.编写实体类4.编写Mapper接口5.编写Service接口6.编写Service接口实现7.编写Controller8.编写添加页面9.编写列表页面10.编写相应配置文件数据库连接信息文件:jdbc.propertiesSpring配置文件:applicationContext.xmlSpringMVC配置文件:spring-mvc.xmlMyBatis映射文件:AccountMapper.xmlMyBatis核心文件:sqlMapConfig.xmlweb.xml:web.xml 11.测试

1.创建maven工程

此处省略很多很多字…

2.导入maven坐标

<dependencies><!-- spring相关--><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.0.5.RELEASE</version></dependency><dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId><version>1.8.4</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.0.5.RELEASE</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>5.0.5.RELEASE</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.0.5.RELEASE</version></dependency><!-- servlet和jsp相关--><dependency><groupId>javax.servlet</groupId><artifactId>servlet-api</artifactId><version>2.5</version></dependency><dependency><groupId>javax.servlet.jsp</groupId><artifactId>jsp-api</artifactId><version>2.0</version></dependency><!-- mybatis相关--><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.6</version></dependency><dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>1.3.1</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.6</version></dependency><dependency><groupId>com.mchange</groupId><artifactId>c3p0</artifactId><version>0.9.5.2</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><dependency><groupId>jstl</groupId><artifactId>jstl</artifactId><version>1.2</version></dependency></dependencies>

3.编写实体类

public class Account {private Integer id;private String name;private Double money;//get和set方法省略}

4.编写Mapper接口

public interface AccountMapper {public void save(Account account);public List<Account> findAll();}

5.编写Service接口

public interface AccountService {public void save(Account account);public List<Account> findAll();}

6.编写Service接口实现

@Service("accountService")public class AccountServiceImpl implements AccountService {@Autowiredprivate AccountMapper accountMapper;@Overridepublic void save(Account account) {accountMapper.save(account);}@Overridepublic List<Account> findAll() {return accountMapper.findAll();}}

7.编写Controller

@Controller@RequestMapping("/account")public class AccountController {@Autowiredprivate AccountService accountService;//保存@RequestMapping(value = "/save",produces = "text/html;charset=UTF-8")@ResponseBodypublic String save(Account account){accountService.save(account);return "保存成功";}//查询@RequestMapping("/findAll")public ModelAndView findAll(){List<Account> accountList = accountService.findAll();ModelAndView modelAndView=new ModelAndView();modelAndView.addObject("accountList",accountList);modelAndView.setViewName("accountList");return modelAndView;}}

8.编写添加页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head><title>Title</title></head><body><h1>添加账户信息表单</h1><form name="accountForm" action="${pageContext.request.contextPath}/account/save" method="post">账户名称:<input type="text" name="name"><br>账户金额:<input type="text" name="money"><br><input type="submit" value="保存"><br></form></body></html>

9.编写列表页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %><%@taglib prefix="c" uri="/jsp/jstl/core" %><html><head><title>Title</title></head><body><table><tr><th>账户id</th><th>账户名称</th><th>账户金额</th></tr><c:forEach items="${accountList}" var="account"><tr><td>${account.id}</td><td>${account.name}</td><td>${account.money}</td></tr></c:forEach></table></body></html>

10.编写相应配置文件

数据库连接信息文件:jdbc.properties

jdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://localhost:3306/testjdbc.username=rootjdbc.password=root

Spring配置文件:applicationContext.xml

<!-- 组件扫描 扫面servive和mapper--><context:component-scan base-package="com.itzhuo"><!--排除controller的扫描--><context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/></context:component-scan><!-- 加载properties文件--><context:property-placeholder location="classpath:jdbc.properties"/><!-- 配置数据源信息--><bean id="dataSource" class="com.mchange.boPooledDataSource"><property name="driverClass" value="${jdbc.driver}"/><property name="jdbcUrl" value="${jdbc.url}"/><property name="user" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/></bean> <!-- 配置sessionFactory--><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSource"/><!-- 加载mybatis核心文件--><property name="configLocation" value="classpath:sqlMapConfig-spring.xml"/></bean><!-- 扫描mapper所在的包 为mapper创建实现类--><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="com.itzhuo.mapper"/></bean><!-- 声明式事务控制--><!--平台事务管理器--><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"/></bean><!--配置事务增强--><tx:advice id="txAdvice"><tx:attributes><tx:method name="*"/></tx:attributes></tx:advice><!--事务的aop织入--><aop:config><aop:advisor advice-ref="txAdvice" pointcut="execution(* com.itzhuo.service.impl.*.*(..))"/></aop:config>

SpringMVC配置文件:spring-mvc.xml

<!-- 组件扫描--><context:component-scan base-package="com.itzhuo.controller"/><!-- 配置mvc注解驱动--><mvc:annotation-driven/><!-- 内部资源视图解析器--><bean id="resourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="prefix" value="/WEB-INF/pages/"/><property name="suffix" value=".jsp"/></bean><!-- 开发静态资源访问权限--><mvc:default-servlet-handler/>

MyBatis映射文件:AccountMapper.xml

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper PUBLIC "-////DTD Mapper 3.0//EN" "/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.itzhuo.mapper.AccountMapper"><insert id="save" parameterType="account">insert into account values(#{id},#{name},#{money})</insert><select id="findAll" resultType="account">select * from account</select></mapper>

MyBatis核心文件:sqlMapConfig.xml

<!--定义别名--><typeAliases><package name="com.itzhuo.domain"/></typeAliases>

web.xml:web.xml

<!-- spring监听器--><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><!-- springmvc的前端控制器--><servlet><servlet-name>DispatcherServlet</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring-mvc.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>DispatcherServlet</servlet-name><url-pattern>/</url-pattern></servlet-mapping><!-- 乱码过滤器--><filter><filter-name>CharacterEncodingFilter</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>CharacterEncodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping>

11.测试

启动Tomcat打开浏览器输入http://localhost:8080/save.jsp

保存

浏览器输入http://localhost:8080/account/findAll

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。