设为首页 收藏本站
查看: 846|回复: 0

[经验分享] SpringMVC与Mybatis集成开发环境搭建

[复制链接]

尚未签到

发表于 2016-11-26 07:57:01 | 显示全部楼层 |阅读模式
SpringMVC与Mybatis集成开发环境搭建

 
1、导入相关JAR包

DSC0000.png
 

2、构建项目目录

DSC0001.png
 
 

3、配置文件


  • web.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <web-app id="WebApp_ID" version="2.4"
    xmlns="http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
    <display-name>SpringMVC_Mybatis</display-name>
    <!-- 配置请求转发处理 -->
    <servlet>
    <servlet-name>dispatcherServlet</servlet-name>
    <servlet-class>
    org.springframework.web.servlet.DispatcherServlet
    </servlet-class>
    <init-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
    /WEB-INF/web-config.xml,
    /WEB-INF/service-config.xml
    </param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
    <servlet-name>dispatcherServlet</servlet-name>
    <url-pattern>*.do</url-pattern>
    </servlet-mapping>
    </web-app>

     
  • web-config.xml
    <?xml version="1.0" encoding="UTF-8" ?>
    <beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    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">
    <!-- 配置数据源 -->
    <bean id="jdbcDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">  
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />  
    <property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:xe" />  
    <property name="username" value="scott" />  
    <property name="password" value="tiger" />  
    </bean>  
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="jdbcDataSource" />  
    <property name="configLocation" value="classpath:mybatis-config.xml" />
    </bean>
    <!-- 让MapperFactoryBean来管理dao -->
    <bean id="userDao" class="org.mybatis.spring.mapper.MapperFactoryBean">
    <property name="mapperInterface" value="cn.richinfo.dao.UserDao" />
    <property name="sqlSessionFactory" ref="sqlSessionFactory" />
    </bean>
    <!-- Controller 方法调用规则定义 -->
    <bean id="paraMethodResolver"
    class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
    <property name="paramName" value="action" />
    <property name="defaultMethodName" value="list"/>
    </bean>
    <!-- 页面View层基本信息设定 -->
    <bean id="viewResolver"
    class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />
    <property name="suffix" value=".jsp" />
    </bean>
    <!-- servlet映射列表,所有控制层Controller的servlet在这里定义 -->
    <bean id="urlMapping"
    class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
    <property name="mappings">
    <props>
    <prop key="user.do">userController</prop>
    </props>
    </property>
    </bean>
    <bean id="userController" class="cn.richinfo.controller.UserController" >
    <property name="userService" ref="userService" />
    </bean>
    </beans>

     
  • service-config.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"
    xsi:schemaLocation="
    http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
    <bean id="userService" class="cn.richinfo.service.UserService">
    <property name="userDao" ref="userDao" />
    </bean>
    </beans>

     
  • mybatis-config.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">  
    <configuration>
    <typeAliases>
    <typeAlias alias="User" type="cn.richinfo.pojo.User" />
    </typeAliases>
    <mappers>  
    <mapper resource="mappers/UserMapper.xml"/>  
    </mappers>  
    </configuration>
     
  • UserMapper.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="cn.richinfo.dao.UserDao">  
    <insert id="insertUser" parameterType="User">
    INSERT INTO spring_user(user_id , user_name)
    VALUES (spring_user_sq.nextval , #{userName})  
    </insert>
    </mapper>

     
  • UserController.java
    package cn.richinfo.controller;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import org.springframework.web.servlet.ModelAndView;
    import org.springframework.web.servlet.mvc.Controller;
    import cn.richinfo.pojo.User;
    import cn.richinfo.service.UserService;
    public class UserController implements Controller {
    private UserService userService;
    public UserService getUserService() {
    return userService;
    }
    public void setUserService(UserService userService) {
    this.userService = userService;
    }
    @Override
    public ModelAndView handleRequest(HttpServletRequest request,
    HttpServletResponse response) throws Exception {
    System.out.println("UserController.handleRequest()");
    request.setAttribute("userName", request.getParameter("userName"));
    User user = new User();
    user.setUserName(request.getParameter("userName"));
    userService.saveUser(user);
    return new ModelAndView("index");
    }
    }

     
  • UserService.java
    package cn.richinfo.service;
    import cn.richinfo.dao.UserDao;
    import cn.richinfo.pojo.User;
    public class UserService {
    private UserDao userDao;
    public UserDao getUserDao() {
    return userDao;
    }
    public void setUserDao(UserDao userDao) {
    this.userDao = userDao;
    }
    public void saveUser(User user) {
    System.out.println("userService : 存储用户...");
    userDao.save(user);
    }
    }

     
  • UserDao.java
    package cn.richinfo.dao;
    import cn.richinfo.pojo.User;
    public interface UserDao {
    public void insertUser(User user);
    }

     
  • User.java
    package cn.richinfo.pojo;
    public class User {
    private int userId;
    private String userName;
    public int getUserId() {
    return userId;
    }
    public void setUserId(int userId) {
    this.userId = userId;
    }
    public String getUserName() {
    return this.userName;
    }
    public void setUserName(String userName) {
    this.userName = userName;
    }
    @Override
    public String toString()  {
    return "{'userId' : " + this.userId + ", 'userName' : " + this.userName + "}";
    }
    }

     
  • index.jsp
    <%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>用户名</title>
    </head>
    <body>
    <label >${requestScope.userName }</label>
    </body>
    </html>
     

  • ### 创建数据库表
    create table spring_user
    (
    user_id number,
    user_name varchar(20) not null,
    constraint spring_user_id_pk primary key(user_id)
    )
    ### 自动主键生成
    create sequence spring_user_sq start with 1 increment by 1
     

    请求:http://localhost:9000/SpringMVC_Mybatis/user.do?userName=liyang

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-305631-1-1.html 上篇帖子: Mybatis系列(六)接口式编程 下篇帖子: mybatis分页实现2
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表