转自:http://www.blogjava.net/pengo/archive/2010/11/28/339229.html

弃用了struts,用spring mvc框架做了几个项目,感觉都不错,而且使用了注解方式,可以省掉一大堆配置文件。本文主要介绍使用注解方式配置的spring mvc,之前写的spring3.0 mvc和rest小例子没有介绍到数据层的内容,现在这一篇补上。下面开始贴代码。

文中用的框架版本:spring 3,hibernate 3,没有的,自己上网下。

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_2_5.xsd" id="WebApp_ID" version="2.5">   
  <display-name>s3h3</display-name>   
   <context-param>     
     <param-name>contextConfigLocation</param-name>     
     <param-value>classpath:applicationContext*.xml</param-value>     
 </context-param>     
  <listener>     
     <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>     
 </listener>     
  
 <servlet>     
     <servlet-name>spring</servlet-name>     
     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>     
     <load-on-startup>1</load-on-startup>     
 </servlet>     
 <servlet-mapping>     
     <servlet-name>spring</servlet-name>  <!-- 这里在配成spring,下边也要写一个名为spring-servlet.xml的文件,主要用来配置它的controller -->   
     <url-pattern>*.do</url-pattern>     
 </servlet-mapping>     
  <welcome-file-list>   
    <welcome-file>index.jsp</welcome-file>   
  </welcome-file-list>   
</web-app>  

spring-servlet,主要配置controller的信息

<?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"
   xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-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   
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">   
     
  <context:annotation-config />   
       <!--把标记了@Controller注解的类转换为bean -->     
      <context:component-scan base-package="com.mvc.controller"/>     
  <!--启动Spring MVC的注解功能,完成请求和注解POJO的映射 -->     
      <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>     
        
       <!--对模型视图名称的解析,即在模型视图名称添加前后缀 -->     
       <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
          p:prefix="/WEB-INF/view/"p:suffix=".jsp"/>     
           
       <bean id="multipartResolver"
          class="org.springframework.web.multipart.commons.CommonsMultipartResolver"
          p:defaultEncoding="utf-8"/>     
 </beans>  

applicationContext.xml代码

<?xml version="1.0" encoding="UTF-8"?>   
<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:aop="http://www.springframework.org/schema/aop"xmlns:context="http://www.springframework.org/schema/context"
 xmlns:p="http://www.springframework.org/schema/p"xmlns:tx="http://www.springframework.org/schema/tx"
 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/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">   
  
 <context:annotation-config />   
 <context:component-scan base-package="com.mvc"/>  <!--自动扫描所有注解该路径 -->   
  
 <context:property-placeholder location="classpath:/hibernate.properties"/>   
  
 <bean id="sessionFactory"
  class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">   
  <property name="dataSource"ref="dataSource"/>   
  <property name="hibernateProperties">   
   <props>   
    <prop key="hibernate.dialect">${dataSource.dialect}</prop>   
    <prop key="hibernate.hbm2ddl.auto">${dataSource.hbm2ddl.auto}</prop>   
    <prop key="hibernate.hbm2ddl.auto">update</prop>   
   </props>   
  </property>   
  <property name="packagesToScan">   
   <list>   
    <value>com.mvc.entity</value><!--扫描实体类,也就是平时所说的model -->   
   </list>   
    </property>   
 </bean>   
  
 <bean id="transactionManager"
  class="org.springframework.orm.hibernate3.HibernateTransactionManager">   
  <property name="sessionFactory"ref="sessionFactory"/>   
  <property name="dataSource"ref="dataSource"/>   
 </bean>   
  
 <bean id="dataSource"
  class="org.springframework.jdbc.datasource.DriverManagerDataSource">   
  <property name="driverClassName"value="${dataSource.driverClassName}"/>   
  <property name="url"value="${dataSource.url}"/>   
  <property name="username"value="${dataSource.username}"/>   
  <property name="password"value="${dataSource.password}"/>   
 </bean>   
 <!--Dao的实现 -->   
 <bean id="entityDao"class="com.mvc.dao.EntityDaoImpl">     
  <property name="sessionFactory"ref="sessionFactory"/>   
 </bean>   
 <tx:annotation-driven transaction-manager="transactionManager"/>   
 <tx:annotation-driven mode="aspectj"/>   
     
    <aop:aspectj-autoproxy/>     
</beans>  

hibernate.properties数据库连接配置

dataSource.password=123  
dataSource.username=root   
dataSource.databaseName=test   
dataSource.driverClassName=com.mysql.jdbc.Driver   
dataSource.dialect=org.hibernate.dialect.MySQL5Dialect   
dataSource.serverName=localhost:3306  
dataSource.url=jdbc:mysql://localhost:3306/test   
dataSource.properties=user=${dataSource.username};databaseName=${dataSource.databaseName};serverName=${dataSource.serverName};password=${dataSource.password}   
dataSource.hbm2ddl.auto=update  

配置已经完成,下面开始例子
先在数据库建表,例子用的是mysql数据库

CREATE TABLE  `test`.`student` (   
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,   
  `name` varchar(45) NOT NULL,   
  `psw` varchar(45) NOT NULL,   
  PRIMARY KEY (`id`)   
)  

建好表后,生成实体类

package com.mvc.entity;   
  
import java.io.Serializable;   
  
import javax.persistence.Basic;   
import javax.persistence.Column;   
import javax.persistence.Entity;   
import javax.persistence.GeneratedValue;   
import javax.persistence.GenerationType;   
import javax.persistence.Id;   
import javax.persistence.Table;   
  
@Entity  
@Table(name = "student")   
public class Student implements Serializable {   
    private static final long serialVersionUID = 1L;   
    @Id  
    @Basic(optional = false)   
    @GeneratedValue(strategy = GenerationType.IDENTITY)   
    @Column(name = "id", nullable = false)   
    private Integer id;   
    @Column(name = "name")   
    private String user;   
    @Column(name = "psw")   
    private String psw;   
    public Integer getId() {   
        return id;   
    }   
    public void setId(Integer id) {   
        this.id = id;   
    }   
       
    public String getUser() {   
        return user;   
    }   
    public void setUser(String user) {   
        this.user = user;   
    }   
    public String getPsw() {   
        return psw;   
    }   
    public void setPsw(String psw) {   
        this.psw = psw;   
    }   
}  

Dao层实现

package com.mvc.dao;   
  
import java.util.List;   
  
public interface EntityDao {   
    public List<Object> createQuery(final String queryString);   
    public Object save(final Object model);   
    public void update(final Object model);   
    public void delete(final Object model);   
}  
package com.mvc.dao;   
  
import java.util.List;   
  
import org.hibernate.Query;   
import org.springframework.orm.hibernate3.HibernateCallback;   
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;   
  
public class EntityDaoImpl extends HibernateDaoSupport implements EntityDao{   
    public List<Object> createQuery(final String queryString) {   
        return (List<Object>) getHibernateTemplate().execute(   
                new HibernateCallback<Object>() {   
                    public Object doInHibernate(org.hibernate.Session session)   
                            throws org.hibernate.HibernateException {   
                        Query query = session.createQuery(queryString);   
                        List<Object> rows = query.list();   
                        return rows;   
                    }   
                });   
    }   
    public Object save(final Object model) {   
        return  getHibernateTemplate().execute(   
                new HibernateCallback<Object>() {   
                    public Object doInHibernate(org.hibernate.Session session)   
                            throws org.hibernate.HibernateException {   
                        session.save(model);   
                        return null;   
                    }   
                });   
    }   
    public void update(final Object model) {   
        getHibernateTemplate().execute(new HibernateCallback<Object>() {   
            public Object doInHibernate(org.hibernate.Session session)   
                    throws org.hibernate.HibernateException {   
                session.update(model);   
                return null;   
            }   
        });   
    }   
    public void delete(final Object model) {   
        getHibernateTemplate().execute(new HibernateCallback<Object>() {   
            public Object doInHibernate(org.hibernate.Session session)   
                    throws org.hibernate.HibernateException {   
                session.delete(model);   
                return null;   
            }   
        });   
    }   
}  

Dao在applicationContext.xml注入

<bean id="entityDao"class="com.mvc.dao.EntityDaoImpl">  
  <property name="sessionFactory"ref="sessionFactory"/>
 </bean>

Dao只有一个类的实现,直接供其它service层调用,如果你想更换为其它的Dao实现,也只需修改这里的配置就行了。
开始写view页面,WEB-INF/view下新建页面student.jsp,WEB-INF/view这路径是在spring-servlet.xml文件配置的,你可以配置成其它,也可以多个路径。student.jsp代码

<%@ page language="java" contentType="text/html; charset=UTF-8"  
    pageEncoding="UTF-8"%>  
<%@ include file="/include/head.jsp"%>  
<!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>  
<script language="javascript"src="<%=request.getContextPath()%><!--   
/script/jquery.min.js">  
// --></script>  
<style><!--   
table{  border-collapse:collapse;  }   
td{  border:1px solid #f00;  }   
--></style><style mce_bogus="1">table{  border-collapse:collapse;  }   
td{  border:1px solid #f00;  }</style>  
<script type="text/javascript"><!--   
function add(){   
    window.location.href="<%=request.getContextPath() %>/student.do?method=add";   
}   
  
function del(id){   
$.ajax( {   
    type : "POST",   
    url : "<%=request.getContextPath()%>/student.do?method=del&id=" + id,   
    dataType: "json",   
    success : function(data) {   
        if(data.del == "true"){   
            alert("删除成功!");   
            $("#" + id).remove();   
        }   
        else{   
            alert("删除失败!");   
        }   
    },   
    error :function(){   
        alert("网络连接出错!");   
    }   
});   
}   
// --></script>  
</head>  
<body>  
  
<input id="add" type="button" onclick="add()" value="添加"/>  
<table >  
    <tr>  
        <td>序号</td>  
        <td>姓名</td>  
        <td>密码</td>  
        <td>操作</td>  
    </tr>  
    <c:forEach items="${list}" var="student">  
    <tr id="<c:out value="${student.id}"/>">  
        <td><c:out value="${student.id}"/></td>  
        <td><c:out value="${student.user}"/></td>  
        <td><c:out value="${student.psw}"/></td>  
        <td>  
            <input type="button" value="编辑"/>        
            <input type="button" onclick="del('<c:out value="${student.id}"/>')" value="删除"/>  
        </td>  
    </tr>  
    </c:forEach>  
       
</table>  
</body>  
</html>  

student_add.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"  
    pageEncoding="UTF-8"%>  
<%@ include file="/include/head.jsp"%>  
<!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>  
<mce:script type="text/javascript"><!--
function turnback(){   
    window.location.href="<%=request.getContextPath() %>/student.do";   
}   
// --></mce:script>  
</head>  
<body>  
<form method="post"action="<%=request.getContextPath() %>/student.do?method=save">  
<div><c:out value="${addstate}"></c:out></div>  
<table>  
    <tr><td>姓名</td><td><input id="user"name="user"type="text"/></td></tr>  
    <tr><td>密码</td><td><input id="psw"name="psw"type="text"/></td></tr>  
    <tr><td colSpan="2"align="center"><input type="submit"value="提交"/><input type="button"onclick="turnback()"value="返回"/> </td></tr>  
</table>  
  
</form>  
</body>  
</html>  

controller类实现,只需把注解写上,spring就会自动帮你找到相应的bean,相应的注解标记意义,不明白的,可以自己查下@Service,@Controller,@Entity等等的内容。

package com.mvc.controller;   
  
import java.util.List;   
  
import javax.servlet.http.HttpServletRequest;   
import javax.servlet.http.HttpServletResponse;   
  
import org.apache.commons.logging.Log;   
import org.apache.commons.logging.LogFactory;   
import org.springframework.beans.factory.annotation.Autowired;   
import org.springframework.stereotype.Controller;   
import org.springframework.ui.ModelMap;   
import org.springframework.web.bind.annotation.RequestMapping;   
import org.springframework.web.bind.annotation.RequestMethod;   
import org.springframework.web.bind.annotation.RequestParam;   
import org.springframework.web.servlet.ModelAndView;   
  
import com.mvc.entity.Student;   
import com.mvc.service.StudentService;   
  
@Controller  
@RequestMapping("/student.do")   
public class StudentController {   
    protected final transient Log log = LogFactory   
    .getLog(StudentController.class);   
    @Autowired  
    private StudentService studentService;   
    public StudentController(){   
           
    }   
       
    @RequestMapping  
    public String load(ModelMap modelMap){   
        List<Object> list = studentService.getStudentList();   
        modelMap.put("list", list);   
        return "student";   
    }   
       
    @RequestMapping(params = "method=add")   
    public String add(HttpServletRequest request, ModelMap modelMap) throws Exception{   
        return "student_add";   
    }   
       
    @RequestMapping(params = "method=save")   
    public String save(HttpServletRequest request, ModelMap modelMap){   
        String user = request.getParameter("user");   
        String psw = request.getParameter("psw");   
        Student st = new Student();   
        st.setUser(user);   
        st.setPsw(psw);   
        try{   
            studentService.save(st);   
            modelMap.put("addstate", "添加成功");   
        }   
        catch(Exception e){   
            log.error(e.getMessage());   
            modelMap.put("addstate", "添加失败");   
        }   
           
        return "student_add";   
    }   
       
    @RequestMapping(params = "method=del")   
    public void del(@RequestParam("id") String id, HttpServletResponse response){   
        try{   
            Student st = new Student();   
            st.setId(Integer.valueOf(id));   
            studentService.delete(st);   
            response.getWriter().print("{\"del\":\"true\"}");   
        }   
        catch(Exception e){   
            log.error(e.getMessage());   
            e.printStackTrace();   
        }   
    }   
}  

service类实现

package com.mvc.service;   
  
import java.util.List;   
  
import org.springframework.beans.factory.annotation.Autowired;   
import org.springframework.stereotype.Service;   
import org.springframework.transaction.annotation.Transactional;   
  
import com.mvc.dao.EntityDao;   
import com.mvc.entity.Student;   
  
@Service  
public class StudentService {   
 @Autowired  
 private EntityDao entityDao;   
    
 @Transactional  
 public List<Object> getStudentList(){   
  StringBuffer sff = new StringBuffer();   
  sff.append("select a from ").append(Student.class.getSimpleName()).append(" a ");   
  List<Object> list = entityDao.createQuery(sff.toString());   
  return list;   
 }   
    
 public void save(Student st){   
  entityDao.save(st);   
 }   
 public void delete(Object obj){   
  entityDao.delete(obj);   
 }   

转载于:https://www.cnblogs.com/summer520/p/3432748.html

springmvc注解小示例(转)相关推荐

  1. ajax - SpringMVC、iBATIS-sqlmap、ajax小示例

    下面纯属个人开发小示例: html: <ul class="apply_list"><li class="a1"><label f ...

  2. SpringMVC 数据绑定全面示例(复杂对象,数组等)

    SpringMVC 数据绑定全面示例(复杂对象,数组等) Spring restful的文章 http://www.xdemo.org/spring-restful/ 项目下载:http://pan. ...

  3. SpringMVC注解@initbinder解决类型转换问题

    SpringMVC注解@initbinder解决类型转换问题 参考文章: (1)SpringMVC注解@initbinder解决类型转换问题 (2)https://www.cnblogs.com/an ...

  4. 学习:springMVC注解

    引言 在项目中,组长说我们的@Autowired注解都是黄的 后来,组长说加上@SuppressWarnings来抑制警告信息 @SuppressWarnings 注解目标 其注解目标为类.字段.函数 ...

  5. springmvc学习笔记(10)-springmvc注解开发之商品改动功能

    springmvc学习笔记(10)-springmvc注解开发之商品改动功能 springmvc学习笔记(10)-springmvc注解开发之商品改动功能 标签: springmvc springmv ...

  6. SpringMVC+RestFul详细示例实战教程(实现跨域访问)

    一.理解 REST REST(Representational State Transfer),中文翻译叫"表述性状态转移".是 Roy Thomas Fielding 在他200 ...

  7. C#通过获取快捷方式指向目标的小示例触碰WMI

    C#通过获取快捷方式指向目标的小示例触碰WMI .Net本身没有封装对快捷方式的操作类,所以要在C#中操作快捷方式,需要借助"外力".市面上常见的方法是通过Windows Scri ...

  8. SpringMVC注解驱动标签做了什么操作

    怎样开启注解驱动 SpringMVC开启注解驱动 <!-- mvc的注解驱动 --><mvc:annotation-driven/> <mvc:annotation-dr ...

  9. js ajax数据的获取小示例 天气信息填充表格

    AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术. 现在大家写写了一个简单的ajax获取数据的小示例,希望能帮助需要帮助的. html代码: 1 <table border ...

最新文章

  1. Matlab Robotic Toolbox V9.10工具箱(六):puma560 动力学建模与仿真
  2. 【每周CV论文推荐】 初学者必须精读的5篇深度学习优化相关文章
  3. windows远程下载
  4. Cert manager自动签发/更新证书
  5. 性能测试流程-各阶段的工作
  6. android添加删除项目,编写android计算器添加删除按钮,出现很抱歉,XX项目已停止运行。...
  7. 华为徐直军:华为云成为智能世界五朵云之一,2021年大力支持伙伴持续创新
  8. minetest Window编译运行
  9. 使用 PlantUML 绘制时序图
  10. tensorflow之tf.slice()
  11. 【路径规划】基于matlab GUI粒子群算法机器人避障路径规划【含Matlab源码 923期】
  12. jquery实现进度条
  13. signature=f81ed620b6d6e6cb4bbe5a4d79d445b8,Lubricating compositions
  14. Flash 101-第1部分:锤子和凿子
  15. 一个可供创业公司借鉴的持续集成技术实践
  16. 关于网线水晶头的接法详解
  17. 吐血整理出来的大数据知识点,你掌握多少?
  18. 查看网卡ip linux,教你如何查看本机ip地址?
  19. 基于策略梯度的强化学习方法及算法理论基础
  20. AIX 挂载NFS错误nfsmnthelp: 1831-019之解决

热门文章

  1. mysql 注入 绕过防火墙_绕过阿里云防火墙继续扫描探测和SQL注入
  2. 运行时错误7内存溢出_分别从运行时和GC的角度看JAVA8内存管理
  3. 博客教程中百度网盘地址
  4. POJ2941 SDUT2371Homogeneous squares
  5. 中文(英译) 爱情一句话哲理
  6. 安卓 sharedpreferences可以被其它activity读取_Google|再见 SharedPreferences 拥抱 Jetpack DataStore...
  7. tesorflow 填充‘same’与‘valid’
  8. PostGIS之路——几何对象编辑(二)
  9. linux下挂载iso镜像的方法
  10. Lintcode--6(767)--翻转数组