spring+springmvc+mybatis+angularjs java web项目

来源:互联网 发布:手机题库制作软件 编辑:程序博客网 时间:2024/05/17 12:55


1.springmvc框架


1.1 什么是springmvc

springmvcspring框架的一个模块,springmvcspring无需通过中间整合层进行整合

springmvc是一个基于mvc(软件设计模式)web框架。




第一步:发起请求到前端控制器(DispatcherServlet)

第二步:前端控制器请求HandlerMapping查找Handler

可以根据xml配置、注解进行查找

第三步:处理器映射器HandlerMapping向前端控制器返回Handler

第四步:前端控制器调用处理器适配器去执行Handler

第五步:处理器适配器去执行Handler

第六步:Handler执行完成给适配器返回ModelAndView

第七步:处理器适配器向前端控制器返回ModelAndView

ModelAndViewspringmvc框架的一个底层对象,包括Modelview

第八步:前端控制器请求视图解析器去进行视图解析

根据逻辑视图名解析成真正的视图(jsp)

第九步:视图解析器向前端控制器返回View

第十步:前端控制器进行视图渲染

视图渲染将模型数据(ModelAndView对象中)填充到request

第十一步:前端控制器向用户响应结果

  

组件:

1、前端控制器DispatcherServlet(不需要程序员开发)

作用接收请求,响应结果,相当于转发器,中央处理器。

有了DispatcherServlet减少了其它组件之间的耦合度。

 

2、处理器映射器HandlerMapping(不需要程序员开发)

作用:根据请求的url查找Handler

 

3、处理器适配器HandlerAdapter

作用:按照特定规则(HandlerAdapter要求的规则)去执行Handler

 

4、处理器Handler(需要程序员开发)

注意:编写Handler时按照HandlerAdapter的要求去做,这样适配器才可以去正确执行Handler

 

5、视图解析器View resolver(不需要程序员开发)

作用:进行视图解析,根据逻辑视图名解析成真正的视图(view

 

6、视图View(需要程序员开发jsp)

View是一个接口,实现类支持不同的View类型(jspfreemarkerpdf...


入门程序

2.1 需求

以案例作为驱动。

springmvcmybaits使用一个案例(商品订单管理)。

功能需求:商品列表查询

2.2 环境准备

数据库环境:mysql5.1

java环境:

jdk1.7.0_72

eclipse indigo

springmvc版本:spring3.2

 

需要spring3.2所有jar(一定包括spring-webmvc-3.2.0.RELEASE.jar

 


2.3 配置前端控制器

web.xml中配置前端控制器。



  <servlet>

    <description>spring mvc servlet</description>

    <servlet-name>springMvc</servlet-name>

    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    <init-param>

      <description>spring mvc 配置文件</description>

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

      <param-value>classpath:spring-mvc.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>


2.4 配置处理器适配器

classpath下的springmvc.xml中配置处理器适配器


此适配器能执行实现Controller接口的Handler


2.5 开发Handler

需要实现 controller接口,才能由org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter适配器执行。

public class ItemsController1implements Controller {

@Override

public ModelAndView handleRequest(HttpServletRequest request,

HttpServletResponse response)throws Exception {

//调用service查找 数据库,查询商品列表,这里使用静态数据模拟

List<Items> itemsList =new ArrayList<Items>();

//list中填充静态数据

Items items_1 =new Items();

items_1.setName("联想笔记本");

items_1.setPrice(6000f);

items_1.setDetail("ThinkPad T430联想笔记本电脑!");

Items items_2 =new Items();

items_2.setName("苹果手机");

items_2.setPrice(5000f);

items_2.setDetail("iphone6苹果手机!");

itemsList.add(items_1);

itemsList.add(items_2);

 //返回ModelAndView

ModelAndView modelAndView =  new ModelAndView();

//相当 于requestsetAttribut,在jsp页面中通过itemsList取数据

modelAndView.addObject("itemsList", itemsList);

//指定视图

modelAndView.setViewName("/WEB-INF/jsp/items/itemsList.jsp");

 return modelAndView;

}

 }

2.6 视图编写

 

2.7 配置Handler

将编写Handlerspring容器加载。


2.8 配置处理器映射器

classpath下的springmvc.xml中配置处理器映射器


2.9  配置视图解析器

 

需要配置解析jsp的视图解析器。


2.10 部署调试

 

访问地址:http://localhost:8080/springmvcfirst1208/queryItems.action


非注解的处理器映射器和适配器

3.1 非注解的处理器映射器

 

第一种处理器映射器:

org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping


<!-- 配置Handler -->

<bean id="itemsController1" name="/queryItems_test.action" class="cn.itcast.ssm.controller.ItemsController1" />

<!-- 处理器映射器 将上边bean的name作为url进行查找 ,需要在配置Handler时指定beanname(就是url) 有的映射器都实现 HandlerMapping接口。-->

<bean

class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping" />

  

另一个映射器:

org.springframework.web.servlet.handler.SimpleUrlHandlerMapping

<!-- 配置另外一个Handler -->

<bean id="itemsController2" class="cn.itcast.ssm.controller.ItemsController2" />

<!--简单url映射  -->

<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">

<property name="mappings">

<props>

<!-- 对itemsController2(controller中bean的id)进行url映射,url是/queryItems2.action -->

<prop key="/queryItems2.action">itemsController2</prop>

</props>

</property>

</bean>

3.2 非注解的处理器适配器

 

org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter

要求编写的Handler实现Controller接口。

 

org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter

要求编写的Handler实现HttpRequestHandler接口。


//使用此方法可以通过修改response,设置响应的数据格式,比如响应json数据/*

response.setCharacterEncoding("utf-8");

response.setContentType("application/json;charset=utf-8");

response.getWriter().write("json");


4.注解的处理器映射器和适配器

 

配置注解映射器和适配器。

<!--注解映射器 -->

<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>

<!--注解适配器 -->

<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>

以上内容都是作为了解,实际的开发过程中使用注解的方式

4.1 在Springmvc.xml中使用注解的方式配置适配器和映射器

<!--使用mvc:annotation-driven代替上边注解映射器和注解适配器配置

mvc:annotation-driven默认加载很多的参数绑定方法,

比如json转换解析器就默认加载了,如果使用mvc:annotation-driven不用配置上边的RequestMappingHandlerMappingRequestMappingHandlerAdapter实际开发时使用mvc:annotation-riven -<mvc:annotation-driven></mvc:annotation-driven>

注意:貌似不去配置好像也能起作用

4.2开发注解Handler

 

使用注解的映射器和注解的适配器。(注解的映射器和注解的适配器必须配对使用)

//使用Controller标识 它是一个控制器

@Controller

public class ItemsController3 {


//商品查询列表

//@RequestMapping实现 对queryItems方法和url进行映射,一个方法对应一个url

//一般建议将url和方法写成一样

@RequestMapping("/queryItems")

public ModelAndView queryItems()throws Exception{

//调用service查找 数据库,查询商品列表,这里使用静态数据模拟

List<Items> itemsList =new ArrayList<Items>();

//list中填充静态数据

Items items_1 =new Items();

items_1.setName("联想笔记本");

items_1.setPrice(6000f);

items_1.setDetail("ThinkPad T430 联想笔记本电脑!");

Items items_2 =new Items();

items_2.setName("苹果手机");

items_2.setPrice(5000f);

items_2.setDetail("iphone6苹果手机!");

itemsList.add(items_1);

itemsList.add(items_2);

//返回ModelAndView

ModelAndView modelAndView =  new ModelAndView();

//相当 于requestsetAttribut,在jsp页面中通过itemsList取数据

modelAndView.addObject("itemsList", itemsList);

//指定视图

modelAndView.setViewName("/WEB-INF/jsp/items/itemsList.jsp");

return modelAndView;

}

4.3 spring容器中加载Handler

 

<!--对于注解的Handler可以单个配置

实际开发中建议使用组件扫描

 -->

<!-- <bean class="cn.itcast.ssm.controller.ItemsController3" /> -->

<!--可以扫描controllerservice...

这里让扫描controller,指定controller的包

 -->

<context:component-scan base-package="cn.itcast.ssm.controller"></context:component-scan>

4.3部署调试

访问:http://localhost:8080/springmvcfirst1208/queryItems.action


SpringMVC实际开发中的总结

在web.xml中配置前端控制器以及引入Springmvc.xml配置文件-->使用注解的方式在Springmvc.xml配置文件添加处理器映射器、适配器、视图解析器;使用组件扫面的方式添加handler.-->开发Handler(controller)-->书写视图文件

视图解析器配置前缀和后缀:


程序中不用指定前缀和后缀:


5.springmvcmybatis整合


 

第一步:整合dao

mybatisspring整合,通过spring管理mapper接口。

使用mapper的扫描器自动扫描mapper接口在spring中进行注册。

 

第二步:整合service

通过spring管理service接口。

使用配置方式将service接口配置在spring配置文件中。

实现事务控制。

 

第三步:整合springmvc

由于springmvcspring的模块,不需要整合。


1.1 准备环境


数据库环境:mysql5.1

 

java环境:

jdk1.7.0_72

eclipse indigo

 

springmvc版本:spring3.2

 

所需要的jar包:

数据库驱动包:mysql5.1

mybatisjar

mybatisspring整合包

log4j

dbcp数据库连接池包

spring3.2所有jar

jstl

工程结构:



1.2 整合mybatis

 

mybatisspring进行整合。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:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="

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

http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 

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

http://www.springframework.org/schema/tx/spring-tx-3.0.xsd

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

http://www.springframework.org/schema/aop/spring-aop-3.0.xsd

">


<!-- 配置数据源 :数据源的配置文件可以在这里加载也可以在spring.xml中加载固定写法无需修改 -->

<bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">

<property name="url" value="${jdbc_url}" />

<property name="username" value="${jdbc_username}" />

<property name="password" value="${jdbc_password}" />


<!-- 初始化连接大小 -->

<property name="initialSize" value="0" />

<!-- 连接池最大使用连接数量 -->

<property name="maxActive" value="20" />

<!-- 连接池最大空闲 -->

<property name="maxIdle" value="20" />

<!-- 连接池最小空闲 -->

<property name="minIdle" value="0" />

<!-- 获取连接最大等待时间 -->

<property name="maxWait" value="60000" />


<!-- <property name="poolPreparedStatements" value="true" /> <property name="maxPoolPreparedStatementPerConnectionSize" value="33" /> -->


<property name="validationQuery" value="${validationQuery}" />

<property name="testOnBorrow" value="false" />

<property name="testOnReturn" value="false" />

<property name="testWhileIdle" value="true" />


<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->

<property name="timeBetweenEvictionRunsMillis" value="60000" />

<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->

<property name="minEvictableIdleTimeMillis" value="25200000" />


<!-- 打开removeAbandoned功能 -->

<property name="removeAbandoned" value="true" />

<!-- 1800秒,也就是30分钟 -->

<property name="removeAbandonedTimeout" value="1800" />

<!-- 关闭abanded连接时输出错误日志 -->

<property name="logAbandoned" value="true" />


<!-- 监控数据库 -->

<!-- <property name="filters" value="stat" /> -->

<property name="filters" value="mergeStat" />

</bean>


<!--sqlsessionFactory的配置 -->

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

<!-- 数据库连接池 -->

<property name="dataSource" ref="dataSource" />

<!-- 加载myBatis全局配置文件 需要修改 -->

<property name="mapperLocations" value="classpath:com/bky/mapping/*.xml" />

</bean>

    <!-- mapper扫描器  唯一修改的地方就是value的值:map类的全路径-->

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">

<!-- 扫描包路径,如果需要扫描多个包,中间使用半角逗号隔开 -->

<property name="basePackage" value="com.bky.dao" />

<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />

</bean>


<!-- 配置事务管理器 -->

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

<property name="dataSource" ref="dataSource" />

</bean>


<!-- 注解方式配置事物 -->

<!-- <tx:annotation-driven transaction-manager="transactionManager" /> -->

 

<!-- 拦截器方式配置事物 -->

<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="repair" propagation="REQUIRED" />

<tx:method name="delAndRepair" 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="datagrid*" propagation="SUPPORTS" />


<tx:method name="*" propagation="SUPPORTS" />

</tx:attributes>

</tx:advice>

<aop:config>

<aop:pointcut id="transactionPointcut" expression="execution(* com.bky.service..*Impl.*(..))"/>

<aop:advisor pointcut-ref="transactionPointcut" advice-ref="transactionAdvice" />

</aop:config>

<!-- 配置druid监控spring jdbc -->

<bean id="druid-stat-interceptor" class="com.alibaba.druid.support.spring.stat.DruidStatInterceptor">

</bean>

<bean id="druid-stat-pointcut" class="org.springframework.aop.support.JdkRegexpMethodPointcut" scope="prototype">

<property name="patterns">

<list>

<value>com.bky.service.*</value>

</list>

</property>

</bean>

<aop:config>

<aop:advisor advice-ref="druid-stat-interceptor" pointcut-ref="druid-stat-pointcut" />

</aop:config>

</beans>


spring-mvc.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" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" 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">


<!-- 自动扫描controller包下的所有类,使其认为spring mvc的控制器 -->

<context:component-scan base-package="com.bky.controller" />


<!-- 对模型视图名称的解析,即在模型视图名称添加前后缀 -->

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="#/" p:suffix=".jsp" />


<!-- 支持上传文件 -->  

    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"/>  

    <!-- 返回到页面编码设为UTF-8 -->

    <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" >  

  <property name="messageConverters">   

         <list>   

             <bean class = "org.springframework.http.converter.StringHttpMessageConverter">   

                <property name = "supportedMediaTypes">

                      <list>

                          <value>text/html;charset=UTF-8</value>   

                     </list>   

                </property>   

             </bean>   

         </list>   

   </property>  

</bean>  

<!--  

  <mvc:annotation-driven />

<bean class="org.springframework.http.converter.StringHttpMessageConverter">

    <property name="supportedMediaTypes">  

               <list>  

                   <value>text/plain;charset=UTF-8</value>  

                   <value>text/html;charset=UTF-8</value>  

               </list>  

           </property>  

</bean>-->

 </beans>

spring.xml配置文件(此配置文件的内容可以完全的书写在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:context="http://www.springframework.org/schema/context" 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

">

<!-- 引入属性文件 -->

<context:property-placeholder location="classpath:config.properties" />

<!-- 自动扫描(自动注入) -->

<context:component-scan base-package="com.bky.service..*" />

</beans>

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="com.bky.dao.UserDao">

<resultMap id="BaseResultMap" type="com.bky.model.User">

<id column="id" property="id" />

<result column="name" property="name" />

<result column="age" property="age" />

<result column="password" property="password" />

<result column="email" property="email" />

<result column="icon" property="icon" />

</resultMap>

<insert id="insert" parameterType="com.bky.model.User">

insert into t_user ( name,

age,password,email)

values ( #{name}, #{age},#{password},#{email})

</insert>

<!-- <insert id="insertSelective" parameterType="com.bky.model.Add" > insert 

into tadd <trim prefix="(" suffix=")" suffixOverrides="," > <if test="id 

!= null" > id, </if> <if test="tname != null" > tname, </if> <if test="tpwd 

!= null" > tpwd, </if> </trim> <trim prefix="values (" suffix=")" suffixOverrides="," 

> <if test="id != null" > #{id,jdbcType=VARCHAR}, </if> <if test="tname != 

null" > #{tname,jdbcType=VARCHAR}, </if> <if test="tpwd != null" > #{tpwd,jdbcType=VARCHAR}, 

</if> </trim> </insert> -->

<update id="updateByPrimaryKeySelective" parameterType="com.bky.model.User">

update t_user

<set>


<if test="name != null">

name = #{name,jdbcType=VARCHAR},

</if>

<if test="age != null">

age = #{age,jdbcType=VARCHAR},

</if>

<if test="password != null">

password = #{password,jdbcType=VARCHAR},

</if>

<if test="email != null">

email = #{email,jdbcType=VARCHAR},

</if>

</set>

where id = #{id,jdbcType=VARCHAR}

</update>

<update id="updateIcon" parameterType="com.bky.model.User">

update t_user

<set>


icon = #{icon,jdbcType=VARCHAR},


</set>

where id = #{id,jdbcType=VARCHAR}

</update>

<select id="selectByPrimaryKey" resultMap="BaseResultMap">

SELECT * FROM t_user

where id =#{id}

</select>

<delete id="deleteByPrimaryKey">

delete from t_user where id =#{id}


</delete>


<select id="getAll" resultMap="BaseResultMap">

SELECT * FROM t_user

</select>

<select id="getPageCount" resultType="java.lang.Integer"

parameterType="String">

SELECT count(*) FROM t_user

<if test="_parameter != null and _parameter != ''">

where name like #{userName,jdbcType=VARCHAR}

</if>

</select>

<select id="getUserByPage" resultMap="BaseResultMap"

parameterType="String">

SELECT * FROM t_user

<if test="userName != null and userName != ''">

where name like #{userName,jdbcType=VARCHAR}

</if>

<if test="start != null and pageSize != null">

limit #{start},#{pageSize}

</if>

</select>

</mapper>

效果图



1.springmvc框架


1.1 什么是springmvc

springmvcspring框架的一个模块,springmvcspring无需通过中间整合层进行整合

springmvc是一个基于mvc(软件设计模式)web框架。




第一步:发起请求到前端控制器(DispatcherServlet)

第二步:前端控制器请求HandlerMapping查找Handler

可以根据xml配置、注解进行查找

第三步:处理器映射器HandlerMapping向前端控制器返回Handler

第四步:前端控制器调用处理器适配器去执行Handler

第五步:处理器适配器去执行Handler

第六步:Handler执行完成给适配器返回ModelAndView

第七步:处理器适配器向前端控制器返回ModelAndView

ModelAndViewspringmvc框架的一个底层对象,包括Modelview

第八步:前端控制器请求视图解析器去进行视图解析

根据逻辑视图名解析成真正的视图(jsp)

第九步:视图解析器向前端控制器返回View

第十步:前端控制器进行视图渲染

视图渲染将模型数据(ModelAndView对象中)填充到request

第十一步:前端控制器向用户响应结果

  

组件:

1、前端控制器DispatcherServlet(不需要程序员开发)

作用接收请求,响应结果,相当于转发器,中央处理器。

有了DispatcherServlet减少了其它组件之间的耦合度。

 

2、处理器映射器HandlerMapping(不需要程序员开发)

作用:根据请求的url查找Handler

 

3、处理器适配器HandlerAdapter

作用:按照特定规则(HandlerAdapter要求的规则)去执行Handler

 

4、处理器Handler(需要程序员开发)

注意:编写Handler时按照HandlerAdapter的要求去做,这样适配器才可以去正确执行Handler

 

5、视图解析器View resolver(不需要程序员开发)

作用:进行视图解析,根据逻辑视图名解析成真正的视图(view

 

6、视图View(需要程序员开发jsp)

View是一个接口,实现类支持不同的View类型(jspfreemarkerpdf...


入门程序

2.1 需求

以案例作为驱动。

springmvcmybaits使用一个案例(商品订单管理)。

功能需求:商品列表查询

2.2 环境准备

数据库环境:mysql5.1

java环境:

jdk1.7.0_72

eclipse indigo

springmvc版本:spring3.2

 

需要spring3.2所有jar(一定包括spring-webmvc-3.2.0.RELEASE.jar

 


2.3 配置前端控制器

web.xml中配置前端控制器。



  <servlet>

    <description>spring mvc servlet</description>

    <servlet-name>springMvc</servlet-name>

    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    <init-param>

      <description>spring mvc 配置文件</description>

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

      <param-value>classpath:spring-mvc.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>


2.4 配置处理器适配器

classpath下的springmvc.xml中配置处理器适配器


此适配器能执行实现Controller接口的Handler


2.5 开发Handler

需要实现 controller接口,才能由org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter适配器执行。

public class ItemsController1implements Controller {

@Override

public ModelAndView handleRequest(HttpServletRequest request,

HttpServletResponse response)throws Exception {

//调用service查找 数据库,查询商品列表,这里使用静态数据模拟

List<Items> itemsList =new ArrayList<Items>();

//list中填充静态数据

Items items_1 =new Items();

items_1.setName("联想笔记本");

items_1.setPrice(6000f);

items_1.setDetail("ThinkPad T430联想笔记本电脑!");

Items items_2 =new Items();

items_2.setName("苹果手机");

items_2.setPrice(5000f);

items_2.setDetail("iphone6苹果手机!");

itemsList.add(items_1);

itemsList.add(items_2);

 //返回ModelAndView

ModelAndView modelAndView =  new ModelAndView();

//相当 于requestsetAttribut,在jsp页面中通过itemsList取数据

modelAndView.addObject("itemsList", itemsList);

//指定视图

modelAndView.setViewName("/WEB-INF/jsp/items/itemsList.jsp");

 return modelAndView;

}

 }

2.6 视图编写

 

2.7 配置Handler

将编写Handlerspring容器加载。


2.8 配置处理器映射器

classpath下的springmvc.xml中配置处理器映射器


2.9  配置视图解析器

 

需要配置解析jsp的视图解析器。


2.10 部署调试

 

访问地址:http://localhost:8080/springmvcfirst1208/queryItems.action


非注解的处理器映射器和适配器

3.1 非注解的处理器映射器

 

第一种处理器映射器:

org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping


<!-- 配置Handler -->

<bean id="itemsController1" name="/queryItems_test.action" class="cn.itcast.ssm.controller.ItemsController1" />

<!-- 处理器映射器 将上边bean的name作为url进行查找 ,需要在配置Handler时指定beanname(就是url) 有的映射器都实现 HandlerMapping接口。-->

<bean

class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping" />

  

另一个映射器:

org.springframework.web.servlet.handler.SimpleUrlHandlerMapping

<!-- 配置另外一个Handler -->

<bean id="itemsController2" class="cn.itcast.ssm.controller.ItemsController2" />

<!--简单url映射  -->

<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">

<property name="mappings">

<props>

<!-- 对itemsController2(controller中bean的id)进行url映射,url是/queryItems2.action -->

<prop key="/queryItems2.action">itemsController2</prop>

</props>

</property>

</bean>

3.2 非注解的处理器适配器

 

org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter

要求编写的Handler实现Controller接口。

 

org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter

要求编写的Handler实现HttpRequestHandler接口。


//使用此方法可以通过修改response,设置响应的数据格式,比如响应json数据/*

response.setCharacterEncoding("utf-8");

response.setContentType("application/json;charset=utf-8");

response.getWriter().write("json");


4.注解的处理器映射器和适配器

 

配置注解映射器和适配器。

<!--注解映射器 -->

<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>

<!--注解适配器 -->

<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>

以上内容都是作为了解,实际的开发过程中使用注解的方式

4.1 在Springmvc.xml中使用注解的方式配置适配器和映射器

<!--使用mvc:annotation-driven代替上边注解映射器和注解适配器配置

mvc:annotation-driven默认加载很多的参数绑定方法,

比如json转换解析器就默认加载了,如果使用mvc:annotation-driven不用配置上边的RequestMappingHandlerMappingRequestMappingHandlerAdapter实际开发时使用mvc:annotation-riven -<mvc:annotation-driven></mvc:annotation-driven>

注意:貌似不去配置好像也能起作用

4.2开发注解Handler

 

使用注解的映射器和注解的适配器。(注解的映射器和注解的适配器必须配对使用)

//使用Controller标识 它是一个控制器

@Controller

public class ItemsController3 {


//商品查询列表

//@RequestMapping实现 对queryItems方法和url进行映射,一个方法对应一个url

//一般建议将url和方法写成一样

@RequestMapping("/queryItems")

public ModelAndView queryItems()throws Exception{

//调用service查找 数据库,查询商品列表,这里使用静态数据模拟

List<Items> itemsList =new ArrayList<Items>();

//list中填充静态数据

Items items_1 =new Items();

items_1.setName("联想笔记本");

items_1.setPrice(6000f);

items_1.setDetail("ThinkPad T430 联想笔记本电脑!");

Items items_2 =new Items();

items_2.setName("苹果手机");

items_2.setPrice(5000f);

items_2.setDetail("iphone6苹果手机!");

itemsList.add(items_1);

itemsList.add(items_2);

//返回ModelAndView

ModelAndView modelAndView =  new ModelAndView();

//相当 于requestsetAttribut,在jsp页面中通过itemsList取数据

modelAndView.addObject("itemsList", itemsList);

//指定视图

modelAndView.setViewName("/WEB-INF/jsp/items/itemsList.jsp");

return modelAndView;

}

4.3 spring容器中加载Handler

 

<!--对于注解的Handler可以单个配置

实际开发中建议使用组件扫描

 -->

<!-- <bean class="cn.itcast.ssm.controller.ItemsController3" /> -->

<!--可以扫描controllerservice...

这里让扫描controller,指定controller的包

 -->

<context:component-scan base-package="cn.itcast.ssm.controller"></context:component-scan>

4.3部署调试

访问:http://localhost:8080/springmvcfirst1208/queryItems.action


SpringMVC实际开发中的总结

在web.xml中配置前端控制器以及引入Springmvc.xml配置文件-->使用注解的方式在Springmvc.xml配置文件添加处理器映射器、适配器、视图解析器;使用组件扫面的方式添加handler.-->开发Handler(controller)-->书写视图文件

视图解析器配置前缀和后缀:


程序中不用指定前缀和后缀:


5.springmvcmybatis整合


 

第一步:整合dao

mybatisspring整合,通过spring管理mapper接口。

使用mapper的扫描器自动扫描mapper接口在spring中进行注册。

 

第二步:整合service

通过spring管理service接口。

使用配置方式将service接口配置在spring配置文件中。

实现事务控制。

 

第三步:整合springmvc

由于springmvcspring的模块,不需要整合。


1.1 准备环境


数据库环境:mysql5.1

 

java环境:

jdk1.7.0_72

eclipse indigo

 

springmvc版本:spring3.2

 

所需要的jar包:

数据库驱动包:mysql5.1

mybatisjar

mybatisspring整合包

log4j

dbcp数据库连接池包

spring3.2所有jar

jstl

工程结构:



1.2 整合mybatis

 

mybatisspring进行整合。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:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="

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

http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 

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

http://www.springframework.org/schema/tx/spring-tx-3.0.xsd

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

http://www.springframework.org/schema/aop/spring-aop-3.0.xsd

">


<!-- 配置数据源 :数据源的配置文件可以在这里加载也可以在spring.xml中加载固定写法无需修改 -->

<bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">

<property name="url" value="${jdbc_url}" />

<property name="username" value="${jdbc_username}" />

<property name="password" value="${jdbc_password}" />


<!-- 初始化连接大小 -->

<property name="initialSize" value="0" />

<!-- 连接池最大使用连接数量 -->

<property name="maxActive" value="20" />

<!-- 连接池最大空闲 -->

<property name="maxIdle" value="20" />

<!-- 连接池最小空闲 -->

<property name="minIdle" value="0" />

<!-- 获取连接最大等待时间 -->

<property name="maxWait" value="60000" />


<!-- <property name="poolPreparedStatements" value="true" /> <property name="maxPoolPreparedStatementPerConnectionSize" value="33" /> -->


<property name="validationQuery" value="${validationQuery}" />

<property name="testOnBorrow" value="false" />

<property name="testOnReturn" value="false" />

<property name="testWhileIdle" value="true" />


<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->

<property name="timeBetweenEvictionRunsMillis" value="60000" />

<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->

<property name="minEvictableIdleTimeMillis" value="25200000" />


<!-- 打开removeAbandoned功能 -->

<property name="removeAbandoned" value="true" />

<!-- 1800秒,也就是30分钟 -->

<property name="removeAbandonedTimeout" value="1800" />

<!-- 关闭abanded连接时输出错误日志 -->

<property name="logAbandoned" value="true" />


<!-- 监控数据库 -->

<!-- <property name="filters" value="stat" /> -->

<property name="filters" value="mergeStat" />

</bean>


<!--sqlsessionFactory的配置 -->

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

<!-- 数据库连接池 -->

<property name="dataSource" ref="dataSource" />

<!-- 加载myBatis全局配置文件 需要修改 -->

<property name="mapperLocations" value="classpath:com/bky/mapping/*.xml" />

</bean>

    <!-- mapper扫描器  唯一修改的地方就是value的值:map类的全路径-->

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">

<!-- 扫描包路径,如果需要扫描多个包,中间使用半角逗号隔开 -->

<property name="basePackage" value="com.bky.dao" />

<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />

</bean>


<!-- 配置事务管理器 -->

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

<property name="dataSource" ref="dataSource" />

</bean>


<!-- 注解方式配置事物 -->

<!-- <tx:annotation-driven transaction-manager="transactionManager" /> -->

 

<!-- 拦截器方式配置事物 -->

<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="repair" propagation="REQUIRED" />

<tx:method name="delAndRepair" 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="datagrid*" propagation="SUPPORTS" />


<tx:method name="*" propagation="SUPPORTS" />

</tx:attributes>

</tx:advice>

<aop:config>

<aop:pointcut id="transactionPointcut" expression="execution(* com.bky.service..*Impl.*(..))"/>

<aop:advisor pointcut-ref="transactionPointcut" advice-ref="transactionAdvice" />

</aop:config>

<!-- 配置druid监控spring jdbc -->

<bean id="druid-stat-interceptor" class="com.alibaba.druid.support.spring.stat.DruidStatInterceptor">

</bean>

<bean id="druid-stat-pointcut" class="org.springframework.aop.support.JdkRegexpMethodPointcut" scope="prototype">

<property name="patterns">

<list>

<value>com.bky.service.*</value>

</list>

</property>

</bean>

<aop:config>

<aop:advisor advice-ref="druid-stat-interceptor" pointcut-ref="druid-stat-pointcut" />

</aop:config>

</beans>


spring-mvc.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" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" 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">


<!-- 自动扫描controller包下的所有类,使其认为spring mvc的控制器 -->

<context:component-scan base-package="com.bky.controller" />


<!-- 对模型视图名称的解析,即在模型视图名称添加前后缀 -->

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="#/" p:suffix=".jsp" />


<!-- 支持上传文件 -->  

    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"/>  

    <!-- 返回到页面编码设为UTF-8 -->

    <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" >  

  <property name="messageConverters">   

         <list>   

             <bean class = "org.springframework.http.converter.StringHttpMessageConverter">   

                <property name = "supportedMediaTypes">

                      <list>

                          <value>text/html;charset=UTF-8</value>   

                     </list>   

                </property>   

             </bean>   

         </list>   

   </property>  

</bean>  

<!--  

  <mvc:annotation-driven />

<bean class="org.springframework.http.converter.StringHttpMessageConverter">

    <property name="supportedMediaTypes">  

               <list>  

                   <value>text/plain;charset=UTF-8</value>  

                   <value>text/html;charset=UTF-8</value>  

               </list>  

           </property>  

</bean>-->

 </beans>

spring.xml配置文件(此配置文件的内容可以完全的书写在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:context="http://www.springframework.org/schema/context" 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

">

<!-- 引入属性文件 -->

<context:property-placeholder location="classpath:config.properties" />

<!-- 自动扫描(自动注入) -->

<context:component-scan base-package="com.bky.service..*" />

</beans>

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="com.bky.dao.UserDao">

<resultMap id="BaseResultMap" type="com.bky.model.User">

<id column="id" property="id" />

<result column="name" property="name" />

<result column="age" property="age" />

<result column="password" property="password" />

<result column="email" property="email" />

<result column="icon" property="icon" />

</resultMap>

<insert id="insert" parameterType="com.bky.model.User">

insert into t_user ( name,

age,password,email)

values ( #{name}, #{age},#{password},#{email})

</insert>

<!-- <insert id="insertSelective" parameterType="com.bky.model.Add" > insert 

into tadd <trim prefix="(" suffix=")" suffixOverrides="," > <if test="id 

!= null" > id, </if> <if test="tname != null" > tname, </if> <if test="tpwd 

!= null" > tpwd, </if> </trim> <trim prefix="values (" suffix=")" suffixOverrides="," 

> <if test="id != null" > #{id,jdbcType=VARCHAR}, </if> <if test="tname != 

null" > #{tname,jdbcType=VARCHAR}, </if> <if test="tpwd != null" > #{tpwd,jdbcType=VARCHAR}, 

</if> </trim> </insert> -->

<update id="updateByPrimaryKeySelective" parameterType="com.bky.model.User">

update t_user

<set>


<if test="name != null">

name = #{name,jdbcType=VARCHAR},

</if>

<if test="age != null">

age = #{age,jdbcType=VARCHAR},

</if>

<if test="password != null">

password = #{password,jdbcType=VARCHAR},

</if>

<if test="email != null">

email = #{email,jdbcType=VARCHAR},

</if>

</set>

where id = #{id,jdbcType=VARCHAR}

</update>

<update id="updateIcon" parameterType="com.bky.model.User">

update t_user

<set>


icon = #{icon,jdbcType=VARCHAR},


</set>

where id = #{id,jdbcType=VARCHAR}

</update>

<select id="selectByPrimaryKey" resultMap="BaseResultMap">

SELECT * FROM t_user

where id =#{id}

</select>

<delete id="deleteByPrimaryKey">

delete from t_user where id =#{id}


</delete>


<select id="getAll" resultMap="BaseResultMap">

SELECT * FROM t_user

</select>

<select id="getPageCount" resultType="java.lang.Integer"

parameterType="String">

SELECT count(*) FROM t_user

<if test="_parameter != null and _parameter != ''">

where name like #{userName,jdbcType=VARCHAR}

</if>

</select>

<select id="getUserByPage" resultMap="BaseResultMap"

parameterType="String">

SELECT * FROM t_user

<if test="userName != null and userName != ''">

where name like #{userName,jdbcType=VARCHAR}

</if>

<if test="start != null and pageSize != null">

limit #{start},#{pageSize}

</if>

</select>

</mapper>

效果图



0 0
原创粉丝点击