spring mvc注解例子

 弃用了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}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值