`
sophia828
  • 浏览: 9762 次
社区版块
存档分类
最新评论

5.框架连通测试(Spring+Mybatis)

 
阅读更多

    前两篇博客已经把Spring和Mybatis基础配置完成,接下来需要测试下 页面<--->服务器<--->数据库之间是否正确连通。

 

  • 1. 截止目前为止,各个配置文件的内容
  • pom.xml:
  • <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    	<modelVersion>4.0.0</modelVersion>
    	<groupId>com.qyuz</groupId>
    	<artifactId>myecom</artifactId>
    	<packaging>war</packaging>
    	<version>0.0.1-SNAPSHOT</version>
    	<name>myecom</name>
    	<url>http://maven.apache.org</url>
    
    	<dependencies>
    	 <!-- spring mvc相关的包-->
            <dependency>
            	<groupId>org.springframework</groupId>
            	<artifactId>spring-webmvc</artifactId>
            	<version>4.3.0.RELEASE</version>
            </dependency>
            
             <!-- spring 事物管理相关的包-->
            <dependency>
            	<groupId>org.springframework</groupId>
            	<artifactId>spring-tx</artifactId>
            	<version>4.3.0.RELEASE</version>
            </dependency>
            
            <!-- spring 数据库链接相关的包-->
            <dependency>
            	<groupId>org.springframework</groupId>
            	<artifactId>spring-jdbc</artifactId>
            	<version>4.3.0.RELEASE</version>
            </dependency>
            <dependency>
    			<groupId>springframework</groupId>
    			<artifactId>spring-orm</artifactId>
    			<version>1.2.5</version>
    		</dependency>
    		
    		<!-- Spring 面向切面AOP相关用到的包,Spring 3.0以前的版本不需要手动引入,之后则需要引入,如下 -->
            <dependency>
            	<groupId>org.aspectj</groupId>
            	<artifactId>aspectjweaver</artifactId>
            	<version>1.8.9</version>
            </dependency>
           
             <!-- HttpServletRequest 等用 -->
            <dependency>
            	<groupId>javax.servlet</groupId>
            	<artifactId>servlet-api</artifactId>
            	<version>2.5</version>
            </dependency>
            
    	   <!-- 单元测试用 -->
    		<dependency>
    			<groupId>junit</groupId>
    			<artifactId>junit</artifactId>
    			<version>3.8.1</version>
    			<scope>test</scope>
    		</dependency>
    		
    		
    		<!-- mysql驱动,链接mysql必须要有的包 -->
    		<dependency>
    			<groupId>mysql</groupId>
    			<artifactId>mysql-connector-java</artifactId>
    			<version>5.1.39</version>
    		</dependency>
    		
    		
    		<!-- 数据库连接池 -->
    		<dependency>
    			<groupId>commons-dbcp</groupId>
    			<artifactId>commons-dbcp</artifactId>
    			<version>1.4</version>
    		</dependency>
    		
    		
            <!-- mybatis -->
            <dependency>
            	<groupId>org.mybatis</groupId>
            	<artifactId>mybatis</artifactId>
            	<version>3.4.1</version>
            </dependency>
            
             
            <!-- 把mybatis和spring结合起来的包 -->
            <dependency>
            	<groupId>org.mybatis</groupId>
            	<artifactId>mybatis-spring</artifactId>
            	<version>1.3.0</version>
            </dependency>
    	</dependencies>	
    	
    	<build>
    		<finalName>myecom</finalName>
    	</build>
    </project>
     
  • 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" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0">
      
      <!-- 整合mybatis -->
      <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:config/spring-mybatis.xml</param-value>
      </context-param>
    
      <!-- 编码过滤器 -->
      <filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <async-supported>true</async-supported>
        <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>
      
      <!-- spring 启动 -->
      <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:config/springmvc-servlet.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
      </servlet>
      
      <servlet-mapping>
        <servlet-name>springmvc</servlet-name>
        <url-pattern>*.do</url-pattern>
      </servlet-mapping>
      
       <!-- 监听 -->
      <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
      </listener>
      
    </web-app>
  •  
  • springmvc-servlet.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:p="http://www.springframework.org/schema/p"
        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-3.0.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd"> 
       
        <!-- 默认的注解映射的支持 -->  
        <mvc:annotation-driven />
         
        <!-- 自动扫描该包,将注解的类变为bean,并注入上下文直接使用-->  
        <context:component-scan base-package="com.qyuz.controller"  />
        
        <!-- 定义跳转的文件的前后缀 ,视图模式配置 -->  
        <bean  
            class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
            <!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 -->  
            <property name="prefix" value="/WEB-INF/views/" />
            <property name="suffix" value=".jsp" />
        </bean>
    </beans>
     
  • spring-mybatis.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:mvc="http://www.springframework.org/schema/mvc"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
                http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
                http://www.springframework.org/schema/mvc
                http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
                http://www.springframework.org/schema/context
                http://www.springframework.org/schema/context/spring-context-3.0.xsd
                http://www.springframework.org/schema/aop
                http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
                http://www.springframework.org/schema/tx
                http://www.springframework.org/schema/tx/spring-tx-3.0.xsd ">
        
        <!-- 自动扫描该包,将注解的类变为bean,并注入上下文直接使用-->  
        <context:component-scan base-package="com.qyuz.service.*"  />
        
        <!-- 由于包的兼容性问题, 这里不能用 ${jdbc.driver}类似的形式赋值了-->
        <!--  context:property-placeholder location="classpath:config/jdbc.properties" ignore-unresolvable="true"/>-->
        
        <!-- 1.数据库配置信息 -->
        <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
            <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
            <!--这里需要注意的是'$' 要用 '&amp;'代替 -->
            <property name="url" value="jdbc:mysql://localhost:3306/ecom?useUnicode=true&amp;characterEncoding=utf-8"/>
            <property name="username" value="jxh"/>
            <property name="password" value="123456"/>
            <property name="validationQuery" value="SELECT 1"/>
            <property name="testWhileIdle" value="true"/>
            <property name="timeBetweenEvictionRunsMillis" value="3600000"/>
            <property name="minEvictableIdleTimeMillis" value="1800000"/>
            <property name="testOnBorrow" value="true"/>
        </bean>
        
        <!-- 2.sessionFactory 将spring和mybatis整合 -->
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
            <property name="dataSource" ref="dataSource" />  
             <!--property name="configLocation" value="classpath:config/mybatis.cfg.xml" -->
            <property name="mapperLocations" value="classpath:mapper/*.xml" />
        </bean>
        
        <!-- 3.自动扫描 将Mapper接口生成代理注入到Spring-->
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer" autowire="byName">  
            <property name="basePackage" value="com.qyuz.dao" />  
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />  
        </bean>    
        
        <!-- 4.配置事物 (事务管理)transaction manager, use JtaTransactionManager for global tx --> 
        <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
            <property name="dataSource" ref="dataSource" />  
        </bean>
        
        <!-- 5.设置事物的传播行为种类 -->
        <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
            <tx:attributes>
                <tx:method name="add*" propagation="REQUIRED" />
                <tx:method name="append*" propagation="REQUIRED" />
                <tx:method name="insert*" propagation="REQUIRED" />
                <tx:method name="save*" propagation="REQUIRED" />
                <tx:method name="update*" propagation="REQUIRED" />
                <tx:method name="modify*" propagation="REQUIRED" />
                <tx:method name="edit*" propagation="REQUIRED" />
                <tx:method name="delete*" propagation="REQUIRED" />
                <tx:method name="remove*" propagation="REQUIRED" />
                
                <tx:method name="get*" propagation="SUPPORTS" />
                <tx:method name="find*" propagation="SUPPORTS" />
                <tx:method name="load*" propagation="SUPPORTS" />
                <tx:method name="search*" propagation="SUPPORTS" />           
                <tx:method name="*" propagation="SUPPORTS" />
            </tx:attributes>
        </tx:advice>
        
        <!-- 6.定义一个切面,在定义的切面上加入事物 -->
        <aop:config>
            <aop:pointcut id="transactionPointcut" expression="execution(* com.qyuz.service..*Impl.*(..))" />
            <aop:advisor pointcut-ref="transactionPointcut" advice-ref="transactionAdvice" />
        </aop:config>
    </beans>
     
  • 2.新建测试部分
  • ①数据库新建test表格并初始化数据:
  • -- ----------------------------
    -- Table structure for test
    -- ----------------------------
    DROP TABLE IF EXISTS `test`;
    CREATE TABLE `test` (
      `pagename` varchar(255) DEFAULT NULL,
      `id` int(11) NOT NULL AUTO_INCREMENT,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
    
    -- ----------------------------
    -- Records of test
    -- ----------------------------
    INSERT INTO `test` VALUES ('testpage', '1');
     
  • ②新建TestDao.java层接口和TestDaoMapper.xml
  • public interface TestDao {
    	public String getPageAtDao();
    }
     
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="com.qyuz.dao.TestDao">
        <select id="getPageAtDao" resultType="string">
        	select pagename from test limit 0,1
        </select>
    </mapper>
     
  • ③新建ITestService.java层和TestServiceImpl.java
  • public interface ITestService {
    	public String getPage();
    }
  • import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    
    import com.qyuz.dao.TestDao;
    import com.qyuz.service.ITestService;
    
    @Service
    public class TestServiceImpl implements ITestService{
    	
    	@Autowired
    	TestDao dao;
    
    	@Override
    	public String getPage() {
    		// TODO Auto-generated method stub
    		return dao.getPageAtDao();
    	}
    
    }
     
  • ④新建TestController.java
  • import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    
    import com.qyuz.service.ITestService;
    
    @Controller
    public class TestController {
    	
    	@Autowired
    	ITestService service;
    
    	@RequestMapping("/test")
    	public String test(){
    		return service.getPage();
    	}
    
    }
     
  • ⑤WEB-INF/views/下新建testpage.jsp页面
  • <%@ page language="java" contentType="text/html; charset=UTF-8"
    	pageEncoding="UTF-8"%>
    <html>
    <body>
    <h2>测试网页,成功!</h2>
    </body>
    </html>
     
  • ⑥最后,右击项目run as -> run on server,启动之后,在浏览器中输入http://localhost:8080/myecom/test.do 回车,显示如下:

     测试成功,基础框架搭建成功! 

  • 大小: 10.7 KB
分享到:
评论

相关推荐

    Spring boot+vue3+element plus实现后台管理系统

    前后端分离项目,Spring boot作为后端,vue框架实现前端,后端整合swagger3测试工具,jwt实现验证码生成,awt生成图形验证码,整合邮箱验证,使用mybatis-generator自动生成实体类以及mapper,设置有拦截器验证登录...

    整合dubbo、maven、spring、mybatis的服务提供者消费者调用错误示例

    在基于Maven的项目中,我们使用Spring作为依赖注入框架,MyBatis作为持久层框架,而Dubbo作为服务治理框架,使得服务提供者和消费者之间能够进行解耦。在服务消费者端,我们创建一个代理对象来调用服务提供者的方法...

    中国移动业务管理系统(struts+spring+hibernate)源码

    在实际应用中,SSH框架通常会配合其他组件,如MyBatis(用于替代部分Hibernate的SQL操作)、Log4j(日志记录)和JUnit(单元测试)等,共同构建强大的企业级应用。在本案例中,"阳光酒店管理系统(源码+文档)"可能是...

    Java源码 SpringMVC Mybatis Shiro Bootstrap Rest Webservice

    1. Springmvc + Mybatis集成、SpringSecurity权限控制、Spring AOP事务处理。 2. Wink Rest服务、Webservice服务:jaxws、CXF等 3. IO 流上传下载文件,多线程操作 4. 发送邮件,配置邮件服务器,发基于html、纯...

    基于SSM框架的物流配送管理系统设计与实现.pdf

    SSM框架(Spring+Struts+Mybatis)是一种广泛应用于Java Web开发的集成框架,用于构建高效、灵活的业务系统。本文以中国联通秦皇岛分公司与上海德邦物流的合作优化为背景,探讨了如何利用SSM框架设计和实现一个物流...

    基于spring mvc的流浪猫狗救助网站

    流浪猫狗救助网站毕业设计使用了基于spring mvc,spring,mybatis,ssm框架的组合。 分为前端和后端两部分。 主要功能包括: 领养中心,团队活动,领养管理,流浪猫狗管理,志愿者申请,领养列表等。 该网站主要...

    毕业设计-基于SpringBoot的理财管理系统设计与实现

    该毕业设计使用了当前较为流行的spring boot,spring,spring mvc,mybatis,shiro框架分页处理使用了pagehelper进行操作,前台使用了模板语言thymeleaf,界面较为炫酷,适合年轻朋友。开发工具采用的是IDEA。 该...

    完善的网上支付代码可以直接使用

    此外,Spring还提供了与各种数据库集成的能力,如JDBC模板和ORM框架(如Hibernate、MyBatis),使得数据存储和查询更为便捷。在支付系统中,这些工具用于存储交易记录、用户信息、订单状态等关键数据。 在文件名...

    RabbitMQ+SSM整合

    本项目是关于如何将RabbitMQ与Spring、SpringMVC和Mybatis这三大流行框架进行整合,实现一套完整的数据增删改查功能。 首先,我们需要了解RabbitMQ的基本概念。RabbitMQ基于AMQP(Advanced Message Queuing ...

    中国联通计费账务管理系统

    MyBatis或Hibernate等ORM框架则用于简化数据库操作,提高开发效率。对于分布式环境,可能还会使用到Zookeeper进行服务发现和配置管理,以及Dubbo或Spring Cloud实现微服务架构。 系统的测试和优化也是必不可少的...

    javassm源码可二次开发联通日租卡

    Java SSM框架是指Spring、SpringMVC、MyBatis三个框架的集成。它是一种轻量级的Java EE框架组合方案,被广泛应用于企业级应用开发中。 - **Spring**:负责管理对象的生命周期及依赖注入(Dependency Injection),...

    java个人总结范文.pdf

    - 持续学习新技术,如Spring、Hibernate、MyBatis等,提升个人技术能力,为公司创造更大价值。 - 期望通过自我提升,能在未来的工作中发挥更大的作用。 在过去的项目中,我还接触了联通116114门户网站开发,学会了...

    基于SSM+Mysql的个性化点餐配送系统(源码+论文+ppt+开题报告+需求分析+演示视频).zip

    2、后端主要采用MySQL数据库和Spring、SpringMVC、Mybatis框架组合(SSM)。 3、提供包括但不限于商品及类别管理、购物车、订单管理、配送管理、财务管理等功能。 4、后端提供WEB交互界面。 5、设计过程合理、设计...

    JAVA话费充值系统.rar

    这个Java话费充值系统的设计和实现涉及到Java Web开发、数据库设计、支付接口集成、安全性控制等多个方面的知识,对于开发者来说,需要熟悉Spring Boot、MyBatis等开发框架,以及SQL、JSON等数据交互格式,同时还...

    基于NetBeans的管理系统案例代码

    Spring Security或者Apache Shiro这样的安全框架可能被用来实现这些功能,提供认证(Authentication)和授权(Authorization)机制。 至于文件名“系统源代码”,可能包含以下部分: 1. 主程序类(Main Class):...

    基于SSM的个性化点餐配送系统(源代码+数据库+文档+PPT)

    2、后端主要采用MySQL数据库和Spring、SpringMVC、Mybatis框架组合(SSM)。 3、提供包括但不限于商品及类别管理、购物车、订单管理、配送管理、财务管理等功能。 4、后端提供WEB交互界面。 5、设计过程合理、设计...

    企业中台技术架构解决方案.pdf

    - **控制层**:使用Spring MVC等框架实现编码过滤、异常处理和会话管理。 - **业务处理**:包括分布式服务层、业务模型层、事务控制和业务处理层,实现微服务化和事务管理。 - **数据访问**:使用DAO、Mybatis等...

    李成豪简历1

    在框架应用上,他对Spring框架有一定了解,特别是IOC容器、AOP,同时对MyBatis、SpringMVC和SpringBoot有基本认识。他还熟悉Linux常用命令,能适应Linux开发环境。 在校园生活中,李成豪积极参与各种组织和志愿活动...

    复习题.doc

    在Linux系统中,`ping`命令用于测试网络连通性,可以验证两台计算机之间的网络连接是否可达。`keys *`在Redis中用于返回所有匹配模式的键,可以进行模糊匹配。`expire`命令设置键的过期时间,`del`命令删除指定键,...

Global site tag (gtag.js) - Google Analytics