eclipse下布置安装ssm图像和文字化教育程(web版)

eclipse下陈设安装ssm图像和文字教程(web版)

一、设置所需jar包

1.1  mybatis安装包

 MyBatis 1

 

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

Mybatis达成缓存的jar包:

MyBatis 2

 

1.2  spring安装包

 MyBatis 3

补充:spring配置aop的aspect包

 MyBatis 4

能够进去spring官网的http://projects.spring.io/spring-framework/

下载所需版本,本文版本是spring-framework-四.三.0.RELEASE

 

1.3  springMVC安装包

 MyBatis 5

MyBatis 6

springMVC是以spring应用为根基的,未有官网提供下载,能够百度下载。

 MyBatis 7

hibernate-validator(springMVC校验所需包)

 

一.四 ssm的框架间的连年包或扩展包

 MyBatis 8

springMVC达成json交互所需jar包:与人间的jar任选其1

 MyBatis 9

文件上传的jar包:

 MyBatis 10

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

 MyBatis 11

 

尤其注意:可能现身1样的包导入多少个版本引发争辩,请依据本身的气象保留二个妥当的版本

 

二、安装步骤

贰.一 创立动态web项目

花色布局如下:

 MyBatis 12

 

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接口必须同名且在1如既往目录下

 –> 

<!–

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

 

贰.肆  配置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 =

 

二.伍  配置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”/> –>

 

二.陆  配置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>

MyBatis, 

贰.七  创立并安插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>

二.玖  配置log四j的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

 

贰.10  创立补全项目布局

项目结构如下:

 MyBatis 13

 

2.1一 使用tomcat运转测试

测试接近如下:

 MyBatis 14

 

 

三、项目实例测试

叁.一 要求分析

基于商品id获取商品新闻

 

三.二 明确动态代理方法和配置文件

 MyBatis 15

上面的mapper包是因而逆向代码工程变更的

ItemsMapper二.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.三 依据ItemsMapper二.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);

}

 

三.四  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);

}

 

}

 

三.伍 前端控制部分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”;

}

}

 

叁.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>

 

三.柒 测试成功

测试实例:

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

测试结果:

 MyBatis 16

以上为私有搭建ssm测试实例,如有不足还请赐教!

 

 

网站地图xml地图