eclipse下安排安装ssm图文教程(web版)

eclipse下安排安装ssm图文教程(web版)

一、安所需jar包

1.1  mybatis安装包

 图片 1

 

可进来GitHub的https://github.com/mybatis/mybatis-3/releases下载所需版本,本文版本是mybatis-3.4.2

Mybatis实现缓存的jar包:

图片 2

 

1.2  spring安装包

 图片 3

补充:spring配置aop的aspect包

 图片 4

好入spring官网的http://projects.spring.io/spring-framework/

下载所要版本,本文版本是spring-framework-4.3.0.RELEASE

 

1.3  springMVC安装包

 图片 5

图片 6

springMVC是为spring应用也根基的,没有官网提供下载,可以百度下载。

 图片 7

hibernate-validator(springMVC校验所需包)

 

1.4 ssm的框架中的连包还是扩展包

 图片 8

springMVC实现json交互所需jar包:与江湖的jar任选其同一

 图片 9

文本上传的jar包:

 图片 10

Mybatis和spring连接,mysql数据库连接的jar包:

 图片 11

 

特别注意:可能出现雷同的包导入多只版本引发冲突,请根据自己的景保留一个适当的本子

 

二、安步骤

2.1 创建动态web项目

品类组织如下:

 图片 12

 

2.2  创建并部署mybatis的基本配置文件SqlMapConfig.xml

布局如下:

<?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"&gt; 

<configuration>  

<!–全局setting配置,根据需要添加–>

 

 

 

<!– With this configuration, can now
be used anywhere that

a package where MyBatis will search for
beans –>

<!– 配置别名 –>

<typeAliases>  

 <!– 批量扫描别名 –>

 <package name=“com.test.ssm.custom”/> 

</typeAliases>

 

<!– Register all interfaces in a
package as mappers –>

<!– 配置mapper

 由于应用spring和mybatis的整合包进行mapper扫描,这里虽无欲安排了。

 必须按照:mapper.xml和mapper接口必须和名且在平等目录下

 –> 

<!–

<mappers>  

<package
name=”org.mybatis.builder”/>

</mappers> –>

</configuration>

 

2.3  创建spring的配置spring-*.xml(*包括:dao、service、transaction)的脑袋信息

布局如下:

<?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:tx=“http://www.springframework.org/schema/tx”

    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/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

        http://www.springframework.org/schema/context

        http://www.springframework.org/schema/context/spring-context.xsd

        http://www.springframework.org/schema/mvc

        http://www.springframework.org/schema/mvc/spring-mvc.xsd”>

        

</beans>

 

2.4  配置spring管理mybatis的dao配置文件spring-dao.xml

配置(不分包头部信息)如下:

<!– 加载指定properties文件
–>

<context:property-placeholder location=“classpath:db.properties” />

 

<!– 配置数据库连接 –>

<!– 配置数据源dbcp –>

<bean id=“dataSource” class=“org.apache.commons.dbcp.BasicDataSource”

destroy-method=“close”>

<!– results in a
setDriverClassName(String) call –>

<property name=“driverClassName” value=“${jdbc.driverClassName}” />

<property name=“url” value=“${jdbc.url}” />

<property name=“username” value=“${jdbc.username}” />

<property name=“password” value=“${jdbc.password}” />

</bean>

 

<!– 加载指定的properties文件
–>

    <context:property-placeholder location=“classpath:db.properties”/>

 

<!– 配置sqlSessionFactory
–>

<bean id=“sqlSessionFactory”  class=“org.mybatis.spring.SqlSessionFactoryBean”>

  <!– 数据库连接池 –>

  <property name=“dataSource” ref=“dataSource”/>

  <!– 加载mybatis的大局配置文件 –>

  <property name=“configLocation” value=“classpath:mybatis/SqlMapConfig.xml”/>

</bean>

 

<!– mapper扫描器 –>

<bean class=“org.mybatis.spring.mapper.MapperScannerConfigurer”>

<!–
扫描包路径,如果用扫描多单包,中间以应用半角逗号隔开 –>

<property name=“basePackage” value=“com.test.ssm.mapper,com.test.ssm.mapper2” />

<!–
此属性在对应之好像中定义在也String类型,所传入值为String类型
–>

<property name=“sqlSessionFactoryBeanName” value=“sqlSessionFactory” />

<!–
下方的援bean会失败是由:在org.mybatis.spring.mapper.MapperScannerConfigurer

受到的性sqlSessionFactory类型为org.apache.ibatis.session.SqlSessionFactory,而
依赖的sqlSessionFactory的类为org.mybatis.spring.SqlSessionFactoryBean,

两者的型不相同,所有无法借助
–>

<!– <property
name=”sqlSessionFactory” ref=”sqlSessionFactory”/>
–>

</bean>

 

补充:db.properties配置如下:

jdbc.driverClassName =
com.mysql.jdbc.Driver

jdbc.url = jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=UTF-8

jdbc.username = root

jdbc.password =

 

2.5  配置spring管理service的service配置文件spring-service.xml

布置(不包含头部信息)如下:

 <!– 可以扫描controller、service、…
这里扫描controller,指定serviceImpl的包 –>

   <context:component-scan base-package=“com.test.ssm.serviceImpl”></context:component-scan>

   

   <!– 商品管理的Service –>

  <!–  <bean id=”itemsService”
class=”com.test.ssm.serviceImpl.ItemsServiceImpl”/> –>

 

2.6  配置spring管理作业的transaction配置文件spring-transaction.xml

布置(不带有头部信息)如下:

 <!– 事务管理器

           对mybatis操作数据库事务控制,spring使用JDBC的事体控制

    –>

   <bean id=“transactionManager” class=“org.springframework.jdbc.datasource.DataSourceTransactionManager”>

     <!– 数据源

      dataSource在applicationContext-dao.xml配置了

      –>

     <property name=“dataSource” ref=“dataSource”/>

   </bean>

   

   <!–
通知受指定的事务管理器transactionManager –>

   <tx:advice id=“txAdvice” transaction-manager=“transactionManager”>

     <tx:attributes>

      <!– 传播行为 –>

      <tx:method name=“save\ propagation=“REQUIRED”*/>

      <tx:method name=“delete\ propagation=“REQUIRED”*/>

      <tx:method name=“insert\ propagation=“REQUIRED”*/>

      <tx:method name=“update\ propagation=“REQUIRED”*/>

      <tx:method name=“get\ propagation=“SUPPORTS” read-only=“true”*/>

      <tx:method name=“select\ propagation=“SUPPORTS” read-only=“true”*/>

     </tx:attributes>

   </tx:advice>

   

   <!– aop调用 txAdvice–>

   <aop:config>

     <aop:advisor advice-ref=“txAdvice” pointcut=“execution(\
com.test.ssm.serviceImpl.*.*(..))”*/>

   </aop:config>

 

2.7  创建并安排springMVC的配置文件springMVC.xml

配置如下:

 <!– 可以扫描controller、service、…
这里扫描controller,指定controller的包 –>

<context:component-scan base-package=“com.test.ssm.controller” />

  

  <!– 注解的映射器 –>

<!– <bean
class=”org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping”/>
–>

<!– 注解的适配器 –>

<!– <bean
class=”org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter”/>
–>

 

<!–
使用mvc:annotation-driven可以替代注解的适配器以及注释映射器
mvc:annotation-driven默认加载了无数的参数绑定方法,比如json转换解析器就默认加载了

骨子里支出时利用下方的mvc:annotation-driven
–>

  <mvc:annotation-driven></mvc:annotation-driven>

  

  <!– 视图解析器 (ViewResolver)
解析jsp视图,默认使用jstl标签,classpath下如果发生jstl的包 –>

  <bean class=“org.springframework.web.servlet.view.InternalResourceViewResolver”>

    <!– 定义视图前缀和后缀
–>

    <property name=“prefix” value=“/WEB-INF/jsp/”/>

    <property name=“suffix” value=“.jsp”/>

  </bean>

 

2.8  配置web容器web.xml

安排如下:

<?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”>

  <display-name>ssmTest2</display-name>

  <welcome-file-list>

    <welcome-file>index.html</welcome-file>

    <welcome-file>index.htm</welcome-file>

    <welcome-file>index.jsp</welcome-file>

    <welcome-file>default.html</welcome-file>

    <welcome-file>default.htm</welcome-file>

    <welcome-file>default.jsp</welcome-file>

  </welcome-file-list>

  

  <!– 配置前端控制器 –>

  <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:spring/springmvc.xml</param-value>

   </init-param>

  </servlet>

  <!– 配置前端控制器映射器
–>

  <servlet-mapping>

   <servlet-name>springMVC</servlet-name>

   <url-pattern>*.action</url-pattern>

  </servlet-mapping>

  

  <!– 加载spring容器 –>

  <context-param>

   <param-name>contextConfigLocation</param-name>

   <param-value>classpath:spring/applicationContext-*.xml</param-value>

  </context-param>

  <listener>

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

  </listener>

  

</web-app>

2.9  配置log4j的properties配置文件

配备如下:

# Global logging configuration

log4j.rootLogger=DEBUG, stdout

# MyBatis logging configuration…

log4j.logger.org.mybatis.example.BlogMapper=TRACE

# Console output…

log4j.appender.stdout=org.apache.log4j.ConsoleAppender

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

log4j.appender.stdout.layout.ConversionPattern=%5p [%t] – %m%n

 

2.10  创建补全项目布局

类型布局如下:

 图片 13

 

2.11 使用tomcat运行测试

测试接近如下:

 图片 14

 

 

三、花色实例测试

3.1 需求分析

根据商品id获取商品信息

 

3.2 确定动态代理方和布置文件

 图片 15

上面之mapper包是通过逆向代码工程变更的

ItemsMapper2.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.test.ssm.mapper2.ItemsMapper2” >

 <select id=“getItemsById” parameterType=“int” 

  resultType=“itemsCustom”>

   select * from items it where
it.id=${value}

 </select>

</mapper>

 

3.3 根据ItemsMapper2.xml的部署文件书写ItemsMapper2的借口方法

方法如下:

package com.test.ssm.mapper.mapper2;

 

import com.test.ssm.custom.ItemsCustom;

 

/**

 * 商品代理对象类

 * @author 龙

 * 2017/3/16

 */

public interface ItemsMapper2
{

  //根据货品id获取商品信息

  public ItemsCustom
getItemsById(int id);

}

 

3.4  ItemsService调用和ItemServiceImplement方法实现

ItemsService调用:

package com.test.ssm.service;

 

import com.test.ssm.custom.ItemsCustom;

 

/**

 * 商品对象业务接口类

 * @author 龙

 * 2017/3/16

 */

public interface ItemsService
{

//根据货品id获取商品信息

public ItemsCustom getItemsById(int id);

}

 

ItemServiceImplement方法实现:

package
com.test.ssm.serviceImpl;

 

import
org.springframework.beans.factory.annotation.Autowired;

import
org.springframework.stereotype.Service;

 

import
com.test.ssm.custom.ItemsCustom;

import
com.test.ssm.mapper2.ItemsMapper2;

import
com.test.ssm.service.ItemsService;

 

/**

 * 商品对象业务实现类似

 * @author 龙

 * 2017/3/16

 */

@Service(“itemsService”)

public class ItemsServiceImpl implements
ItemsService {

@Autowired

ItemsMapper2 itemsMapper2;

//根据商品id获取商品信息

@Override

public ItemsCustom getItemsById(int id)
{

//调用Items代理对象的getItemsById(id)方法

return
itemsMapper2.getItemsById(id);

}

 

}

 

3.5 前端控制部分ItemsController实现

ItemsController实现:

package
com.test.ssm.controller;

 

import
org.springframework.beans.factory.annotation.Autowired;

import
org.springframework.stereotype.Controller;

import
org.springframework.ui.Model;

import
org.springframework.web.bind.annotation.RequestMapping;

 

import
com.test.ssm.custom.ItemsCustom;

import
com.test.ssm.service.ItemsService;

 

/**

 * 商品控制类

 * @author 龙

 * 2017/3/16

 */

@Controller

@RequestMapping(“/items”)

public class ItemsController {

@Autowired

    ItemsService itemsService;

 

@RequestMapping(“/itemsSerach”)

public String ItemsCustomSearch(Model
model,Integer id){

ItemsCustom itemsCustom =
itemsService.getItemsById(id);

model.addAttribute(“ItemsCustom”,itemsCustom);

return “items/itemsTest”;

}

}

 

3.6 前端显示页面itemsTest.jsp

itemsTest.jsp内容如下:

<%@ page language=“java” contentType=“text/html;
charset=UTF-8”

    pageEncoding=“UTF-8”%>

<%@ taglib uri=“http://java.sun.com/jsp/jstl/core” prefix=“c”%>

<%@ taglib uri=“http://java.sun.com/jsp/jstl/fmt” prefix=“fmt” %>

<!DOCTYPE html PUBLIC “-//W3C//DTD HTML
4.01 Transitional//EN” “http://www.w3.org/TR/html4/loose.dtd"&gt;

<html>

<head>

<meta http-equiv=“Content-Type” content=“text/html;
charset=UTF-8”
>

<title>商品信息测试类</title>

</head>

<body>

<table>

 <tr>

  <td>商品名称</td>

  <td>商品价位</td>

  <td>生产日期</td>

  <td>商品描述</td>

  <td>操作</td>

 </tr>

<c:if test=${ItemsCustom != null
}>

  <tr>

   <td><input type=“text” name=“name” id=“itemsName” value=${ItemsCustom.name
}/></td>

   <td><input type=“text” name=“price” id=“itemsPrice” value=${ItemsCustom.price
}/></td>

   <td><input type=“text” name=“createtime” id=“itemsDate” 

   value=<fmt:formatDate value=’${ItemsCustom.createtime}’
pattern=‘yyyy-MM-dd’/>/></td>

   <td><input type=“text” name=“detail” id=“itemsDetail” value=${ItemsCustom.detail
}/></td>

   <td><input type=“text” name=“pic” id=“itemsPic” value=${ItemsCustom.pic
}/></td>

  </tr>

</c:if>

</table>

</body>

</html>

 

3.7 测试成功

测试实例:

http://localhost:8080/ssmTest2/items/itemsSerach.action?id=10527

测试结果:

 图片 16

上述为私有搭建ssm测试实例,如产生欠缺还伸手赐教!

 

 

网站地图xml地图