zoukankan      html  css  js  c++  java
  • SSM框架整合(Spring+SpringMVC+MyBatis+Oracle)

    1.开发环境搭建以及创建Maven Web项目

         参看之前的博文:http://www.cnblogs.com/cainiaomahua/p/6306476.html

    2.SSM整合

         这次整合有2个配置文件,分别是spring-mybatis.xml,包含spring和mybatis的配置文件,还有个是spring-mvc的配置文件,此外有2个资源文件:jdbc.propertis和log4j.properties。

         完整目录结构如下:

         

         使用框架的版本:

              Spring 4.0.2 RELEASE

              Spring MVC 4.0.2 RELEASE

              MyBatis 3.2.6

        2.1  Maven引入需要的JAR包

               在pom.xml中引入jar包(此处引入jar包,可以复制代码,也可以使用视图的方式,参考此链接:http://www.360doc.com/content/14/0517/18/9560593_378558295.shtml)

    复制代码
      1 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      2     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
      3     <modelVersion>4.0.0</modelVersion>
      4     <groupId>org.storm</groupId>
      5     <artifactId>storm</artifactId>
      6     <version>0.0.1-SNAPSHOT</version>
      7     <name>storm</name>
      8     <url>http://maven.apache.org</url>
      9 
     10     <properties>
     11         <!-- Spring版本号 -->
     12         <spring.version>4.0.2.RELEASE</spring.version>
     13         <!-- mybatis版本号 -->
     14         <mybatis.version>3.2.6</mybatis.version>
     15         <!-- log4j日志文件管理包版本 -->
     16         <slf4j.version>1.7.7</slf4j.version>
     17         <log4j.version>1.2.17</log4j.version>
     18     </properties>
     19 
     20     <dependencies>
     21         <dependency>
     22             <groupId>junit</groupId>
     23             <artifactId>junit</artifactId>
     24             <version>4.11</version>
     25             <!-- 表示开发的时候引入,发布的时候不会加载此包 -->
     26             <scope>test</scope>
     27         </dependency>
     28 
     29         <!-- Spring核心包 -->
     30         <dependency>
     31             <groupId>org.springframework</groupId>
     32             <artifactId>spring-core</artifactId>
     33             <version>4.0.2.RELEASE</version>
     34         </dependency>
     35         <dependency>
     36             <groupId>org.springframework</groupId>
     37             <artifactId>spring-web</artifactId>
     38             <version>4.0.2.RELEASE</version>
     39         </dependency>
     40         <dependency>
     41             <groupId>org.springframework</groupId>
     42             <artifactId>spring-oxm</artifactId>
     43             <version>4.0.2.RELEASE</version>
     44         </dependency>
     45         <dependency>
     46             <groupId>org.springframework</groupId>
     47             <artifactId>spring-tx</artifactId>
     48             <version>4.0.2.RELEASE</version>
     49         </dependency>
     50         <dependency>
     51             <groupId>org.springframework</groupId>
     52             <artifactId>spring-jdbc</artifactId>
     53             <version>4.0.2.RELEASE</version>
     54         </dependency>
     55         <dependency>
     56             <groupId>org.springframework</groupId>
     57             <artifactId>spring-webmvc</artifactId>
     58             <version>4.0.2.RELEASE</version>
     59         </dependency>
     60         <dependency>
     61             <groupId>org.springframework</groupId>
     62             <artifactId>spring-aop</artifactId>
     63             <version>4.0.2.RELEASE</version>
     64         </dependency>
     65         <dependency>
     66             <groupId>org.springframework</groupId>
     67             <artifactId>spring-context-support</artifactId>
     68             <version>4.0.2.RELEASE</version>
     69         </dependency>
     70         <dependency>
     71             <groupId>org.springframework</groupId>
     72             <artifactId>spring-test</artifactId>
     73             <version>4.0.2.RELEASE</version>
     74         </dependency>
     75 
     76         <!-- mybatis核心包 -->
     77         <dependency>
     78             <groupId>org.mybatis</groupId>
     79             <artifactId>mybatis</artifactId>
     80             <version>3.2.6</version>
     81         </dependency>
     82 
     83         <!-- mybatis/spring包 -->
     84         <dependency>
     85             <groupId>org.mybatis</groupId>
     86             <artifactId>mybatis-spring</artifactId>
     87             <version>1.2.2</version>
     88         </dependency>
     89 
     90         <!-- 引入java ee jar 包 -->
     91         <dependency>
     92             <groupId>javax</groupId>
     93             <artifactId>javaee-api</artifactId>
     94             <version>7.0</version>
     95         </dependency>
     96 
     97         <!-- 导入oracle包 -->
     98         <dependency>
     99             <groupId>com.oracle</groupId>
    100             <artifactId>ojdbc</artifactId>
    101             <version>6</version>
    102         </dependency>
    103 
    104         <!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 -->
    105         <dependency>
    106             <groupId>commons-dbcp</groupId>
    107             <artifactId>commons-dbcp</artifactId>
    108             <version>1.2.2</version>
    109         </dependency>
    110 
    111         <!-- JSTL标签类 -->
    112         <dependency>
    113             <groupId>jstl</groupId>
    114             <artifactId>jstl</artifactId>
    115             <version>1.2</version>
    116         </dependency>
    117 
    118         <!-- 日志文件管理包 -->
    119         <!-- log start -->
    120         <dependency>
    121             <groupId>log4j</groupId>
    122             <artifactId>log4j</artifactId>
    123             <version>1.2.17</version>
    124         </dependency>
    125 
    126         <!-- 格式化对象,方便输出日志 -->
    127         <dependency>
    128             <groupId>com.alibaba</groupId>
    129             <artifactId>fastjson</artifactId>
    130             <version>1.1.41</version>
    131         </dependency>
    132         <dependency>
    133             <groupId>org.slf4j</groupId>
    134             <artifactId>slf4j-api</artifactId>
    135             <version>1.7.7</version>
    136         </dependency>
    137         <dependency>
    138             <groupId>org.slf4j</groupId>
    139             <artifactId>slf4j-log4j12</artifactId>
    140             <version>1.7.7</version>
    141         </dependency>
    142         <!-- log end -->
    143         <!-- 映入JSON -->
    144         <dependency>
    145             <groupId>org.codehaus.jackson</groupId>
    146             <artifactId>jackson-mapper-asl</artifactId>
    147             <version>1.9.13</version>
    148         </dependency>
    149 
    150         <!-- 上传组件包 -->
    151         <dependency>
    152             <groupId>commons-fileupload</groupId>
    153             <artifactId>commons-fileupload</artifactId>
    154             <version>1.3.1</version>
    155         </dependency>
    156         <dependency>
    157             <groupId>commons-io</groupId>
    158             <artifactId>commons-io</artifactId>
    159             <version>2.4</version>
    160         </dependency>
    161         <dependency>
    162             <groupId>commons-codec</groupId>
    163             <artifactId>commons-codec</artifactId>
    164             <version>1.9</version>
    165         </dependency>
    166     </dependencies>
    167     <build>
    168         <finalName>storm</finalName>
    169         <plugins>
    170             <plugin>
    171                 <groupId>org.eclipse.jetty</groupId>
    172                 <artifactId>jetty-maven-plugin</artifactId>
    173                 <version>9.2.8.v20150217</version>
    174                 <configuration>
    175                     <httpConnector>
    176                         <port>8090</port>
    177                     </httpConnector>
    178                     <stopKey>shutdown</stopKey>
    179                     <stopPort>9966</stopPort>
    180                 </configuration>
    181             </plugin>
    182         </plugins>
    183     </build>
    184     <packaging>war</packaging>
    185 </project>
    复制代码

       2.2   整合SpringMVC

       2.2.1   配置spring-mvc.xml

       配置里面的注释也很详细,主要是自动扫描控制器,视图模式,注解的启动这三个。

    复制代码
     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <beans xmlns="http://www.springframework.org/schema/beans"
     3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
     4     xmlns:context="http://www.springframework.org/schema/context"
     5     xmlns:mvc="http://www.springframework.org/schema/mvc"
     6     xsi:schemaLocation="
     7         http://www.springframework.org/schema/beans 
     8         http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
     9         http://www.springframework.org/schema/context 
    10         http://www.springframework.org/schema/context/spring-context-3.1.xsd
    11         http://www.springframework.org/schema/mvc
    12         http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
    13     <!-- 自动扫描,使SpringMVC认为包下用了@Controller注解的类是控制器 -->
    14     <context:component-scan base-package="com.cn.hnust.controller" />
    15     <!-- 扩充了注解驱动,可以将请求参数绑定到控制器参数 -->
    16     <mvc:annotation-driven />
    17     <!-- 静态资源处理 css js imgs -->
    18     <mvc:resources location="/resources/**" mapping="/resources" />
    19     <!-- 避免IE执行AJAX时,返回JSON出现下载文件 -->
    20     <bean id="mappingJacksonHttpMessageConverter"
    21         class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
    22         <property name="supportedMediaTypes">
    23             <list>
    24                 <value>text/html;charset=UTF-8</value>
    25             </list>
    26         </property>
    27     </bean>
    28 
    29     <!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 -->
    30     <bean
    31         class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
    32         <property name="messageConverters">
    33             <list>
    34                 <!-- JSON转换器 -->
    35                 <ref bean="mappingJacksonHttpMessageConverter" />
    36             </list>
    37         </property>
    38     </bean>
    39 
    40     <!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 -->
    41     <bean id="multipartResolver"
    42         class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    43         <!-- 默认编码 -->
    44         <property name="defaultEncoding" value="utf-8"></property>
    45         <!-- 文件大小最大值 -->
    46         <property name="maxUploadSize" value="10485760000"></property>
    47         <!-- 内存中的最大值 -->
    48         <property name="maxInMemorySize" value="40960"></property>
    49         <!-- 启用是为了推迟文件解析,以便捕获文件大小异常 -->
    50         <property name="resolveLazily" value="true"></property>
    51     </bean>
    52 
    53     <!-- 配置ViewResolver。可用多个ViewResolver。使用order属性排序。 InternalResourceViewResolver 
    54         放在最后 -->
    55     <bean
    56         class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">
    57         <property name="order" value="1"></property>
    58         <property name="mediaTypes">
    59             <map>
    60                 <!-- 告诉视图解析器,返回的类型是json格式 -->
    61                 <entry key="json" value="application/json"></entry>
    62                 <entry key="xml" value="application/xml"></entry>
    63                 <entry key="htm" value="text/htm"></entry>
    64             </map>
    65         </property>
    66         <property name="defaultViews">
    67             <list>
    68                 <!-- ModelAndView里的数据变成JSON -->
    69                 <bean
    70                     class="org.springframework.web.servlet.view.json.MappingJacksonJsonView"></bean>
    71             </list>
    72         </property>
    73         <property name="ignoreAcceptHeader" value="true"></property>
    74     </bean>
    75     <!-- 定义跳转的文件的前后缀,视图模式配置 -->
    76     <bean
    77         class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    78         <!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 -->
    79         <property name="prefix" value="/WEB-INF/jsp/"></property>
    80         <property name="suffix" value=".jsp"></property>
    81     </bean>
    82 </beans>
    复制代码

       2.2.2   配置web.xml文件

        配置的spring-mvc的Servlet就是为了完成SpringMVC+MAVEN的整合。

        web.xml  

    复制代码
     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     3     xmlns="http://java.sun.com/xml/ns/javaee"
     4     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
     5     version="3.0">
     6     <display-name>Archetype Created Web Application</display-name>
     7     <!-- Spring和MyBatis的配置文件 -->
     8     <!-- <context-param>
     9         <param-name>contextConfigLocation</param-name>
    10         <param-value>classpath:spring-mybatis.xml</param-value>
    11     </context-param> -->
    12     <!-- 编码过滤器 -->
    13     <filter>
    14         <filter-name>encodingFilter</filter-name>
    15         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    16         <async-supported>true</async-supported>
    17         <init-param>
    18             <param-name>encoding</param-name>
    19             <param-value>UTF-8</param-value>
    20         </init-param>
    21     </filter>
    22     <filter-mapping>
    23         <filter-name>encodingFilter</filter-name>
    24         <url-pattern>/*</url-pattern>
    25     </filter-mapping>
    26     <!-- Spring监听器 -->
    27     <!-- <listener>
    28         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    29     </listener> -->
    30     <!-- 防止Spring内存溢出监听器 -->
    31     <!-- <listener>
    32         <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
    33     </listener> -->
    34 
    35     <!-- Spring MVC servlet -->
    36     <servlet>
    37         <servlet-name>SpringMVC</servlet-name>
    38         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    39         <!-- 下面init-param是自定义servlet.xml配置文件的位置和名称,默认为WEB-INF目录下,名称为[<servlet-name>]-servlet.xml,如spring-servlet.xml -->
    40         <init-param>
    41             <param-name>contextConfigLocation</param-name>
    42             <param-value>classpath:spring-mvc.xml</param-value>
    43         </init-param>
    44         <load-on-startup>1</load-on-startup>
    45         <async-supported>true</async-supported>
    46     </servlet>
    47     <servlet-mapping>
    48         <servlet-name>SpringMVC</servlet-name>
    49         <!-- 此处可以配置成*.do,对应struts的后缀习惯 -->
    50         <url-pattern>/</url-pattern>
    51     </servlet-mapping>
    52     <welcome-file-list>
    53         <welcome-file>/index.jsp</welcome-file>
    54     </welcome-file-list>
    55 </web-app>
    复制代码

       2.2.3   Log4j的配置

           为了方便调试,一般都会使用日志来输出信息,Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。

          Log4j的配置很简单,而且也是通用的,下面给出一个基本的配置,换到其他项目中也无需做多大的调整。

          log4j.properties

    复制代码
     1 #定义LOG输出级别
     2 log4j.rootLogger=INFO,Console,File
     3 #定义日志输出目的地为控制台
     4 log4j.appender.Console=org.apache.log4j.ConsoleAppender
     5 log4j.appender.Console.Target=System.out
     6 #可以灵活地指定日志输出格式,下面一行是指定具体的格式
     7 log4j.appender.Console.layout=org.apache.log4j.PatternLayout
     8 log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n
     9 
    10 #文件大小达到指定尺寸的时候产生一个新的文件
    11 log4j.appender.File=org.apache.log4j.RollingFileAppender
    12 #指定输出目录
    13 log4j.appender.File.File=logs/ssm.log
    14 #定义文件最大大小
    15 log4j.appender.File.MaxFileSize=10MB
    16 #输出所有日志,如果换成DEBUG表示输出DEBUG以上级别日志
    17 log4j.appender.File.Threshold=ALL
    18 log4j.appender.File.layout=org.apache.log4j.PatternLayout  
    19 log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH:mm:ss}][%c]%m%n 
    复制代码

         2.2.4  使用Jetty测试

         Student类对应于数据库中表的属性

    复制代码
     1 package com.cn.hnust.pojo;
     2 
     3 public class Student {
     4     private Integer id;
     5 
     6     private String stu_name;
     7 
     8     private Integer gender;
     9 
    10     private Integer age;
    11 
    12     private String address;
    13 
    14     public Integer getId() {
    15         return id;
    16     }
    17 
    18     public void setId(Integer id) {
    19         this.id = id;
    20     }
    21 
    22     public String getStu_name() {
    23         return stu_name;
    24     }
    25 
    26     public void setStu_name(String stu_name) {
    27         this.stu_name = stu_name;
    28     }
    29 
    30     public Integer getGender() {
    31         return gender;
    32     }
    33 
    34     public void setGender(Integer gender) {
    35         this.gender = gender;
    36     }
    37 
    38     public Integer getAge() {
    39         return age;
    40     }
    41 
    42     public void setAge(Integer age) {
    43         this.age = age;
    44     }
    45 
    46     public String getAddress() {
    47         return address;
    48     }
    49 
    50     public void setAddress(String address) {
    51         this.address = address;
    52     }
    53 
    54     @Override
    55     public String toString() {
    56         return "Student [id=" + id + ", stu_name=" + stu_name + ", gender="
    57                 + gender + ", age=" + age + ", address=" + address + "]";
    58     }
    59 }
    复制代码

        控制器类

    复制代码
     1 package com.cn.hnust.controller;
     2 
     3 import java.io.File;
     4 import java.io.IOException;
     5 import java.util.Map;
     6 
     7 import javax.annotation.Resource;
     8 import javax.servlet.http.HttpServletRequest;
     9 
    10 import org.apache.commons.io.FileUtils;
    11 import org.slf4j.Logger;
    12 import org.slf4j.LoggerFactory;
    13 import org.springframework.http.HttpStatus;
    14 import org.springframework.http.ResponseEntity;
    15 import org.springframework.stereotype.Controller;
    16 import org.springframework.ui.Model;
    17 import org.springframework.web.bind.annotation.PathVariable;
    18 import org.springframework.web.bind.annotation.RequestMapping;
    19 import org.springframework.web.bind.annotation.RequestMethod;
    20 import org.springframework.web.bind.annotation.RequestParam;
    21 import org.springframework.web.bind.annotation.ResponseBody;
    22 import org.springframework.web.multipart.MultipartFile;
    23 
    24 import com.cn.hnust.pojo.Student;
    25 import com.cn.hnust.service.IStudentService;
    26 
    27 @Controller
    28 @RequestMapping("/student")
    29 public class StudentController {
    30     private static Logger log = LoggerFactory
    31             .getLogger(StudentController.class);
    32 
    33     @Resource
    34     private IStudentService studentService;
    35 
    36     // /student/test?id=1
    37     @RequestMapping(value = "/test", method = RequestMethod.GET)
    38     public String test(HttpServletRequest request, Model model) {
    39         int studentId = Integer.parseInt(request.getParameter("id"));
    40         System.out.println("test studentId:" + studentId);
    41         Student student = null;
    42         if (studentId == 1) {
    43             student = new Student();
    44             student.setAge(19);
    45             student.setId(1);
    46             student.setGender(1);
    47             student.setAddress("北京七里省际大厦3栋4402");
    48             student.setStu_name("江泽");
    49         }
    50 
    51         log.debug(student.toString());
    52         model.addAttribute("student", student);
    53         return "index";
    54     }
    55 }
    复制代码

        运行测试

        

        

        控制台没有报错

        

         在浏览器中输入:http://localhost:8090/student/test?id=1      (端口号根据你的设置有关,自己调查)

         到此 SpringMVC+Maven 整合完毕

        2.3 Spring与MyBatis的整合

               取消2.2.2 web.xml中注释的代码,下面是去除后的代码

    复制代码
     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     3     xmlns="http://java.sun.com/xml/ns/javaee"
     4     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
     5     version="3.0">
     6     <display-name>Archetype Created Web Application</display-name>
     7     <!-- Spring和MyBatis的配置文件 -->
     8     <context-param>
     9         <param-name>contextConfigLocation</param-name>
    10         <param-value>classpath:spring-mybatis.xml</param-value>
    11     </context-param>
    12     <!-- 编码过滤器 -->
    13     <filter>
    14         <filter-name>encodingFilter</filter-name>
    15         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    16         <async-supported>true</async-supported>
    17         <init-param>
    18             <param-name>encoding</param-name>
    19             <param-value>UTF-8</param-value>
    20         </init-param>
    21     </filter>
    22     <filter-mapping>
    23         <filter-name>encodingFilter</filter-name>
    24         <url-pattern>/*</url-pattern>
    25     </filter-mapping>
    26     <!-- Spring监听器 -->
    27     <listener>
    28         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    29     </listener>
    30     <!-- 防止Spring内存溢出监听器 -->
    31     <listener>
    32         <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
    33     </listener>
    34 
    35     <!-- Spring MVC servlet -->
    36     <servlet>
    37         <servlet-name>SpringMVC</servlet-name>
    38         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    39         <!-- 下面init-param是自定义servlet.xml配置文件的位置和名称,默认为WEB-INF目录下,名称为[<servlet-name>]-servlet.xml,如spring-servlet.xml -->
    40         <init-param>
    41             <param-name>contextConfigLocation</param-name>
    42             <param-value>classpath:spring-mvc.xml</param-value>
    43         </init-param>
    44         <load-on-startup>1</load-on-startup>
    45         <async-supported>true</async-supported>
    46     </servlet>
    47     <servlet-mapping>
    48         <servlet-name>SpringMVC</servlet-name>
    49         <!-- 此处可以配置成*.do,对应struts的后缀习惯 -->
    50         <url-pattern>/</url-pattern>
    51     </servlet-mapping>
    52     <welcome-file-list>
    53         <welcome-file>/index.jsp</welcome-file>
    54     </welcome-file-list>
    55 </web-app>
    复制代码

         2.3.1、建立JDBC属性文件

           jdbc.properties(文件编码修改为utf-8)   根据自己数据库配置url  username  password

    复制代码
     1 #连接数据库
     2 #jdbc.driver=net.sf.log4jdbc.DriverSpy
     3 #jdbc.url=jdbc:log4jdbc:oracle:thin:@192.168.0.125:1521:xe
     4 jdbc.driver=oracle.jdbc.OracleDriver
     5 jdbc.url=jdbc:oracle:thin:@192.168.0.125:1521:xe
     6 jdbc.username=orcl
     7 jdbc.password=orcl
     8 
     9 #dbcp settings
    10 dbcp.maxIdle=5
    11 dbcp.maxActive=50
    复制代码

        2.3.2、建立spring-mybatis.xml配置文件

        这个文件就是用来完成spring和mybatis的整合的。主要的就是自动扫描,自动注入,配置数据库。注释也很详细,大家看看就明白了。

        spring-mybatis.xml

    复制代码
     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <beans xmlns="http://www.springframework.org/schema/beans"
     3     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
     4     xmlns:context="http://www.springframework.org/schema/context"
     5     xmlns:mvc="http://www.springframework.org/schema/mvc"
     6     xsi:schemaLocation="
     7         http://www.springframework.org/schema/beans 
     8         http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
     9         http://www.springframework.org/schema/context 
    10         http://www.springframework.org/schema/context/spring-context-3.1.xsd
    11         http://www.springframework.org/schema/mvc
    12         http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd">
    13     <!-- 自动扫描 -->
    14     <context:component-scan base-package="com.cn.hnust" />
    15     
    16     <!-- 使用annotation 自动注册bean, 并保证@Required、@Autowired的属性被注入 -->
    17     <!--<context:component-scan base-package="com.cn.hnust">
    18         <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    19     </context:component-scan>-->
    20     
    21     <!-- 引入配置文件 -->
    22     <bean id="propertyConfigurer"
    23         class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    24         <property name="location" value="classpath:jdbc.properties" />
    25     </bean>
    26 
    27     <!-- 数据源配置, 使用应用中的DBCP数据库连接池 -->
    28     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
    29         destroy-method="close">
    30         <!-- Connection Info -->
    31         <property name="driverClassName" value="${jdbc.driver}" />
    32         <property name="url" value="${jdbc.url}" />
    33         <property name="username" value="${jdbc.username}" />
    34         <property name="password" value="${jdbc.password}" />
    35 
    36         <!-- Connection Pooling Info -->
    37         <property name="maxActive" value="${dbcp.maxActive}" />
    38         <property name="maxIdle" value="${dbcp.maxIdle}" />
    39         <property name="defaultAutoCommit" value="false" />
    40         <!-- 连接Idle一个小时后超时 -->
    41         <property name="timeBetweenEvictionRunsMillis" value="3600000" />
    42         <property name="minEvictableIdleTimeMillis" value="3600000" />
    43     </bean>
    44 
    45     <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
    46     <bean id="sqlSessionFactory"
    47         class="org.mybatis.spring.SqlSessionFactoryBean">
    48         <property name="dataSource" ref="dataSource"/>
    49         <!-- 自动扫描mapping.xml文件 -->
    50         <property name="mapperLocations" value="classpath:com/cn/hnust/mapping/*.xml"></property>
    51     </bean>
    52     <!-- DAO接口所在包名,Spring会自动查找其下的类 -->
    53     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    54         <property name="basePackage" value="com.cn.hnust.dao"></property>
    55         <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
    56     </bean>
    57     
    58     <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->  
    59     <bean id="transactionManager"  
    60         class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
    61         <property name="dataSource" ref="dataSource" />  
    62     </bean> 
    63 </beans>
    复制代码

        2.4   JUnit测试

        创建实体类、MyBatis映射文件以及DAO接口

        DAO接口类

    复制代码
     1 package com.cn.hnust.dao;
     2 
     3 import com.cn.hnust.pojo.Student;
     4 
     5 public interface IStudentDao {
     6     int deleteByPrimaryKey(Integer id);
     7     
     8     int insert(Student record);
     9     
    10     int insertSelective(Student record);
    11     
    12     Student selectByPrimaryKey(Integer id);
    13     
    14     int updateByPrimaryKeySelective(Student record);
    15     
    16     int updateByPrimaryKey(Student record);
    17 }
    复制代码

        实现增删改查的xml配置文件

    复制代码
     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <!DOCTYPE mapper
     3   PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
     4   "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
     5 <mapper namespace="com.cn.hnust.dao.IStudentDao">
     6     <resultMap type="com.cn.hnust.pojo.Student" id="BaseResultMap">
     7         <id column="id" property="id" jdbcType="INTEGER" />
     8         <result column="stu_name" property="stu_name" jdbcType="VARCHAR" />
     9         <result column="age" property="age" jdbcType="INTEGER" />
    10         <result column="gender" property="gender" jdbcType="INTEGER" />
    11         <result column="address" property="address" jdbcType="VARCHAR" />
    12     </resultMap>
    13     <sql id="Base_Column_List">
    14         id,stu_name,age,gender,address
    15     </sql>
    16     <select id="selectByPrimaryKey" resultMap="BaseResultMap"
    17         parameterType="java.lang.Integer">
    18         select
    19         <include refid="Base_Column_List"></include>
    20         from student
    21         where id = #{id,jdbcType=INTEGER}
    22     </select>
    23     <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
    24         delete from
    25         student
    26         where id = #{id,jdbcType=INTEGER}
    27     </delete>
    28     <insert id="insert" parameterType="com.cn.hnust.pojo.Student">
    29         insert into
    30         student(id,stu_name,age,gender,address)
    31         values
    32         (#{id,jdbcType=INTEGER},#{stu_name,jdbcType=VARCHAR},#{age,jdbcType=INTEGER},#{gender,jdbcType=INTEGER},#{address,jdbcType=VARCHAR})
    33     </insert>
    34     <insert id="insertSelective" parameterType="com.cn.hnust.pojo.Student">
    35         insert into student
    36         <trim prefix="(" suffix=")" suffixOverrides=",">
    37             <if test="id != null">
    38                 id,
    39             </if>
    40             <if test="stu_name != null">
    41                 stu_name,
    42             </if>
    43             <if test="age != null">
    44                 age,
    45             </if>
    46             <if test="gender != null">
    47                 gender,
    48             </if>
    49             <if test="address != null">
    50                 address,
    51             </if>
    52         </trim>
    53         <trim prefix="values (" suffix=")" suffixOverrides=",">
    54             <if test="id != null">
    55                 #{id,jdbcType=INTEGER},
    56             </if>
    57             <if test="stu_name != null">
    58                 #{stu_name,jdbcType=VARCHAR},
    59             </if>
    60             <if test="age != null">
    61                 #{age,jdbcType=INTEGER},
    62             </if>
    63             <if test="gender != null">
    64                 #{gender,jdbcType=INTEGER},
    65             </if>
    66             <if test="address != null">
    67                 #{address,jdbcType=VARCHAR},
    68             </if>
    69         </trim>
    70     </insert>
    71     <update id="updateByPrimaryKeySelective" parameterType="com.cn.hnust.pojo.Student">
    72         update student
    73         <set >
    74             <if test="stu_name != null">
    75                 stu_name = #{stu_name,jdbcType=VARCHAR},
    76             </if>
    77             <if test="age != null">
    78                 age = #{age,jdbcType=INTEGER},
    79             </if>
    80             <if test="gender != null">
    81                 gender = #{gender,jdbcType=INTEGER},
    82             </if>
    83             <if test="address != null">
    84                 address = #{address,jdbcType=VARCHAR},
    85             </if>
    86         </set>
    87         where id = #{id,jdbcType=INTEGER}
    88     </update>
    89     <update id="updateByPrimaryKey" parameterType="com.cn.hnust.pojo.Student">
    90         update student
    91         set stu_name = #{stu_name,jdbcType=VARCHAR},
    92             age = #{age,jdbcType=INTEGER},
    93             gender = #{gender,jdbcType=INTEGER},
    94             address = #{address,jdbcType=VARCHAR}
    95         where id = #{id,jdbcType=INTEGER}
    96     </update>
    97 </mapper>
    复制代码

        建立Service接口和实现类

    复制代码
    1 package com.cn.hnust.service;
    2 
    3 import com.cn.hnust.pojo.Student;
    4 
    5 public interface IStudentService {
    6     public Student getStudentById(int studentId);
    7 }
    复制代码

        

        

    复制代码
     1 package com.cn.hnust.service.impl;
     2 
     3 import javax.annotation.Resource;
     4 
     5 import org.springframework.stereotype.Service;
     6 
     7 import com.cn.hnust.dao.IStudentDao;
     8 import com.cn.hnust.pojo.Student;
     9 import com.cn.hnust.service.IStudentService;
    10 
    11 @Service("studentService")
    12 public class StudentServiceImpl implements IStudentService {
    13 
    14     @Resource
    15     private IStudentDao studentDao;
    16 
    17     @Override
    18     public Student getStudentById(int studentId) {
    19         return this.studentDao.selectByPrimaryKey(studentId);
    20     }
    21 
    22 }
    复制代码

        建立UserController类

    复制代码
      1 package com.cn.hnust.controller;
      2 
      3 import java.io.File;
      4 import java.io.IOException;
      5 import java.util.Map;
      6 
      7 import javax.annotation.Resource;
      8 import javax.servlet.http.HttpServletRequest;
      9 
     10 import org.apache.commons.io.FileUtils;
     11 import org.slf4j.Logger;
     12 import org.slf4j.LoggerFactory;
     13 import org.springframework.http.HttpStatus;
     14 import org.springframework.http.ResponseEntity;
     15 import org.springframework.stereotype.Controller;
     16 import org.springframework.ui.Model;
     17 import org.springframework.web.bind.annotation.PathVariable;
     18 import org.springframework.web.bind.annotation.RequestMapping;
     19 import org.springframework.web.bind.annotation.RequestMethod;
     20 import org.springframework.web.bind.annotation.RequestParam;
     21 import org.springframework.web.bind.annotation.ResponseBody;
     22 import org.springframework.web.multipart.MultipartFile;
     23 
     24 import com.cn.hnust.pojo.Student;
     25 import com.cn.hnust.service.IStudentService;
     26 
     27 @Controller
     28 @RequestMapping("/student")
     29 public class StudentController {
     30     private static Logger log = LoggerFactory
     31             .getLogger(StudentController.class);
     32 
     33     @Resource
     34     private IStudentService studentService;
     35 
     36     // /student/test?id=1
     37     @RequestMapping(value = "/test", method = RequestMethod.GET)
     38     public String test(HttpServletRequest request, Model model) {
     39         int studentId = Integer.parseInt(request.getParameter("id"));
     40         System.out.println("test studentId:" + studentId);
     41         Student student = null;
     42         if (studentId == 1) {
     43             student = new Student();
     44             student.setAge(19);
     45             student.setId(1);
     46             student.setGender(1);
     47             student.setAddress("北京七里省际大厦3栋4402");
     48             student.setStu_name("江泽");
     49         }
     50 
     51         log.debug(student.toString());
     52         model.addAttribute("student", student);
     53         return "index";
     54     }
     55 
     56     // /student/showStudent?id=1
     57     @RequestMapping(value = "/showStudent", method = RequestMethod.GET)
     58     public String toIndex(HttpServletRequest request, Model model) {
     59         int studentId = Integer.parseInt(request.getParameter("id"));
     60         System.out.println("toIndex studentId:" + studentId);
     61         Student student = this.studentService.getStudentById(studentId);
     62         log.debug(student.toString());
     63         model.addAttribute("student", student);
     64         return "showStudent";
     65     }
     66 
     67     // /student/showStudent2?id=1
     68     @RequestMapping(value = "/showStudent2", method = RequestMethod.GET)
     69     public String toIndex2(@RequestParam("id") String id, Model model) {
     70         int studentId = Integer.parseInt(id);
     71         System.out.println("toIndex2 studentId:" + studentId);
     72         Student student = this.studentService.getStudentById(studentId);
     73         log.debug(student.toString());
     74         model.addAttribute("student", student);
     75         return "showStudent";
     76     }
     77 
     78     // /student/showStudent3/{id}
     79     @RequestMapping(value = "/showStudent3/{id}", method = RequestMethod.GET)
     80     public String toIndex3(@RequestParam("id") String id,
     81             Map<String, Object> model) {
     82         int studentId = Integer.parseInt(id);
     83         System.out.println("toIndex3 studentId:" + studentId);
     84         Student student = this.studentService.getStudentById(studentId);
     85         log.debug(student.toString());
     86         model.put("student", student);
     87         return "showStudent";
     88     }
     89 
     90     // /student{id}
     91     @RequestMapping(value = "/{id}", method = RequestMethod.GET)
     92     public @ResponseBody
     93     Student getStudentInJson(@PathVariable String id, Map<String, Object> model) {
     94         int studentId = Integer.parseInt(id);
     95         System.out.println("getStudentInJson studentId:" + studentId);
     96         Student student = this.studentService.getStudentById(studentId);
     97         log.info(student.toString());
     98         return student;
     99     }
    100 
    101     // /student/{id}
    102     @RequestMapping(value = "/jsontype/{id}", method = RequestMethod.GET)
    103     public ResponseEntity<Student> getStudentInJson2(@PathVariable String id,
    104             Map<String, Object> model) {
    105         int studentId = Integer.parseInt(id);
    106         System.out.println("getStudentInJson2 studentId:" + studentId);
    107         Student student = this.studentService.getStudentById(studentId);
    108         log.info(student.toString());
    109         return new ResponseEntity<Student>(student, HttpStatus.OK);
    110     }
    111 
    112     // 文件上传
    113     @RequestMapping(value = "/upload")
    114     public String showUploadPage() {
    115         return "student_admin/file";
    116     }
    117 
    118     @RequestMapping(value = "/doUpload", method = RequestMethod.GET)
    119     public String doUploadFile(@RequestParam("file") MultipartFile file)
    120             throws IOException {
    121         if (!file.isEmpty()) {
    122             log.info("Process file:{}", file.getOriginalFilename());
    123         }
    124         FileUtils.copyInputStreamToFile(file.getInputStream(), new File("F:\",
    125                 System.currentTimeMillis() + file.getOriginalFilename()));
    126         return "sucess";
    127     }
    128 }
    复制代码

        新建jsp页面

        file.jsp

    复制代码
     1 <%@ page language="java" contentType="text/html;charset=utf-8"
     2     pageEncoding="utf-8" %>
     3 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org//TR/html4/loose.dtd">
     4 <html>
     5 <head>
     6     <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
     7     <title>Insert title here</title>
     8 </head>
     9 <body>
    10     <h1>上传文件</h1>
    11     <form action="/student/doUpload" method="post" enctype="multipart/form-data">
    12         <input type="file" name="file"/>
    13         <input type="submit" value="上传文件"/>
    14     </form>
    15 </body>
    16 </html>
    复制代码

        index.jsp

    复制代码
     1 <%@ page language="java" import="java.util.*"
     2     pageEncoding="utf-8" %>
     3 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
     4 <html>
     5 <body>
     6 <h2>Hello zou</h2>
     7 <br>
     8 <a href="jsp/showStudent.jsp">跳转</a>
     9 </body>
    10 </html>
    复制代码

        showUser.jsp

    复制代码
     1 <%@ page language="java" import="java.util.*"
     2     pageEncoding="utf-8" %>
     3 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
     4 <html>
     5 <head>
     6     <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
     7     <title>Testing</title>
     8 </head>
     9 <body>
    10     ${student.stu_name}
    11 </body>
    12 </html>
    复制代码

        success.jsp

    复制代码
     1 <%@ page language="java" contentType="text/html;charset=utf-8"
     2     pageEncoding="utf-8" %>
     3 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org//TR/html4/loose.dtd">
     4 <html>
     5 <head>
     6     <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
     7     <title>success</title>
     8 </head>
     9 <body>
    10     <h1>success</h1>
    11 </body>
    12 </html>
    复制代码

        部署项目

        输入地址:http://localhost:8090/student/jsontype/2

        

  • 相关阅读:
    vb教程图文并茂
    一个文本框的andriod教程
    5月18日,完成导入数据,但是从命令行显示数据乱码,程序已经正常工作
    android 文件读写权限的设定
    raw目录的位置是D:android_projectsqrscanappsrcmain es aw
    一个在raw里面放着数据库文件的网上例子
    P1446 [HNOI2008]Cards [Burnside引理]
    UVA11255 Necklace [Polya定理]
    Polya 定理入门[Burnside引理,Polya定理,欧拉函数]
    P2831 愤怒的小鸟 [状压dp/模拟退火]
  • 原文地址:https://www.cnblogs.com/weixupeng/p/8540563.html
Copyright © 2011-2022 走看看