`
一纸红颜岂值倾尽天下
  • 浏览: 29190 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

springmvc+hibernate集成

阅读更多

springmvc+hibernate集成

 

1、控制器

package com.ai.customer.controller;

import java.io.IOException;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

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.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import org.springframework.web.context.request.ServletWebRequest;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.support.RequestContext;

import com.ai.customer.model.CustomerInfo;
import com.ai.customer.service.ICustomerService;

/*
 * @Controller
 * 控制器 
 * 
 * @Service
 * 用于标注业务层组件
 * 
 * @Repository
 * 用于标注数据访问组件,即DAO组件
 * 
 * @Component
 *  泛指组件,当组件不好归类的时候我们可以使用这个注解进行标注,(现在可以都用此注解)
 *  同上其实跟@Service/@Repository/@Controller 一样只不过它们 利用分层 好区分
 * 
 * @Autowired\@Resource
 *  自动注入 实现的的是 setXxx()方法  getXxx()方法
 * 
 * @RequestMapping(value='xxx.do',method=RequestMethod.GET/RequestMethod.POST/..)
 * value访问路径/method请发的方法,注:请求方法一旦设定只能使用指定的方法访问
 *  在类前面定义,则将url和类绑定。
 *  在方法前面定义,则将url和类的方法绑定
 * 
 * @RequestParam("name") ==uname
 *  一般用于将指定的请求参数付给方法中形参
 * 
 * @Scope 
 * 创建 bean的作用域 singleton-->多例  Property-->多例   还有request 等等
 * 使用reqeust 需要在web.xml 配置监听器 具体去网上搜索
 *  
 */


@Controller
public class CustomerAction {

	@Autowired
	private ICustomerService  customerService;
	
	@RequestMapping(value="/login.do")
	public String postLogingMethod(HttpServletRequest reqeust){
		System.out.println("访问到了控制器");
		System.out.println(customerService);
		CustomerInfo cus=customerService.queryCustomer().get(0);
		System.out.println("身份证Id"+cus.getCardid());
		reqeust.getSession().setAttribute("cus", cus);
		return "page/admin/index";
	}
	
	
	/*
	 * @RequestParam 使用
	 * @RequestParam("name") ==uname 一般用于将指定的请求参数付给方法中形参
	 */
	@RequestMapping("/param.do" )
	public String paramMethod(@RequestParam("name")String uname){
		System.out.println("uname:"+uname);
		//重定向 页面
		return "redirect:index.jsp";
	}
	
	
	/*
	 *  页面传递过来的参数 自动赋值 xxx.do?name=张三&customerid=12342423 post get请求皆可
	 *  ajax $.xxx("xxx.do",{name:'张三',customerid:'123435345'},function(data){});
	 */
	@RequestMapping("/rq.do")
	public String allMethod(String customerid,String name){
		System.out.println(customerid+":"+name);
		return "index";
	}
	
	
	/*
	 * 封装实体对象 表单提交数据 表单中cus.name名
	 * <input type="text" name="cus.name">
	 * <input type="text" name="cus.customerid">
	 */
	@RequestMapping("/cus.do")
	public String setCustomer(CustomerInfo cus){
		System.out.println(cus.getCustomerid()+":"+cus.getName());
		return "index";
	}
	
	
	/*springmvc 中获取request对象
	 * 1、可以直接在方法中定义 getReqeust(CustomerInfo cus,HttpServletRequest req)
	 * 
	 * 2、使用注解Autowired
	 * 	@Autowired
	 * private HttpServletRequest request;
	 * 
	 * 3、使用如下方法
	 * ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes)RequestContextHolder.getRequestAttributes();
     * servletRequestAttributes.getRequest();
	 * 
	 */
	@RequestMapping("/reqeust.do")
	public String getReqeust(CustomerInfo cus,HttpServletRequest req){
		//获取reqeust对象
		req.setAttribute("cus", cus);
		//获取session对象
		req.getSession();
		return "index";
	}
	
	
	/* 获取reponse 可以使用如下方法 也可以使用:在方法中传递
	 *  getResponse(String name,String customerid,HttpservletResponse response)
	 */
	@RequestMapping("/response.do")
	public void  getResponse(String name,String customerid,HttpServletResponse response){

		response.setContentType("text/html;charset=utf-8");
		
		System.out.println(name+":"+customerid);
		try {
			response.getWriter().write(customerid.toString());
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	
	
	
	/*ModelAndView 与 ModelMap 的区别
	 * 
	 * ModelAndView 
	 * 作用一 :设置转向地址/对象必须手动创建(主要区别)
	 * 
	 * 作用二:用于传递控制方法处理结果数据到结果页面,
	 * 也就是说我们把需要在结果页面上需要的数
	 * 据放到ModelAndView对象中即可,他
	 * 的作用类似于request对象的setAttr
	 * ibute方法的作用,用来在一个请求过程中
	 * 传递处理的数据。通过以下方法向页面传递 参数:addObject(String key,Object value); 
	 * 
	 * 
	 * ModelMap
	 *一、 ModelMap的实例是由bboss mvc框架自动创建并作为控制器方法参数传入,
	 * 用户无需自己创建。
	 * 
	 * 二、ModelMap对象主要用于传递控制方法处理数据到结果页面,也就是说我们把结果页面上需要的数据放到ModelMap对象中即可,
	 * 他的作用类似于request对象的setAttribute方法的作用,用来在一个请求过程中传递处理的数据。通过以下方法向页面传递参数:
	 * addAttribute(String key,Object value);
	 * 在页面上可以通过el变量方式$key或者bboss的一系列数据展示标签获取并展示modelmap中的数据。
	 * modelmap本身不能设置页面跳转的url地址别名或者物理跳转地址,那么我们可以通过控制器方法的返回值来设置跳转url地址
	 * 别名或者物理跳转地址。 
	 */

	@RequestMapping("/modelmap.do")
    public String modelMapMethod(String name,ModelMap model) {   
          //将数据放置到ModelMap对象model中,第二个参数可以是任何java类型   
          model.addAttribute("modelMap",name);   
          //返回跳转地址   
          return "index";   
    }  

	@RequestMapping("/modelandmap.do")
    public ModelAndView modelAndMapMethod(String name) {   
          //构建ModelAndView实例,并设置跳转地址   
          ModelAndView view = new ModelAndView("index");   
          //将数据放置到ModelAndView对象view中,第二个参数可以是任何java类型   
          view.addObject("modelAndMap",name);   
         //返回ModelAndView对象view   
          return view;   
    }  

	
}

 2、dao接口

package com.ai.customer.dao;

import java.util.List;

import com.ai.customer.model.CustomerInfo;

public interface ICustomerDao {

	//查询Customer
	public List<CustomerInfo> queryCustomer();
	public String all();
}

 3、dao接口实现

package com.ai.customer.daoimpl;

import java.util.List;

import org.hibernate.Hibernate;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Repository;

import com.ai.customer.dao.ICustomerDao;
import com.ai.customer.model.CustomerInfo;

@Repository
public class CustomerDao implements ICustomerDao {

	
	@Autowired
	private SessionFactory sessionFactory;
	
//	public void setSessionFactory(SessionFactory sessionFactory) {
//		this.sessionFactory = sessionFactory;
//	}

	public List<CustomerInfo> queryCustomer() {
		
		//System.out.println(sessionFactory);

		//Configuration config=new Configuration().configure("config/hibernet/hibernate.cfg.xml");
		
		//SessionFactory f=config.buildSessionFactory();
		
		Session session=sessionFactory.openSession();
		
		List<CustomerInfo> cus=session.createQuery("from CustomerInfo").list();
		
		session.close();
		
		
		return cus;
	}

	public String all(){
		
		return "注解成功";
	}
	
	public static void main(String[] args) {

		
		Configuration config=new Configuration().configure("config/hibernet/hibernate.cfg.xml");
		
		SessionFactory f=config.buildSessionFactory();
		
		Session session=f.openSession();
		
		List<CustomerInfo> cus=session.createQuery("from CustomerInfo").list();
		
		session.close();
		
		System.out.println(cus.get(0).getCustomerid());
		
		
//		System.out.println(f.getCurrentSession().createQuery("from CustomerInfo").list());
	}
}

 4、实体类

package com.ai.customer.model;

import java.io.Serializable;

public class CustomerInfo implements Serializable {


	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;


	private String customerid;//个人编号
	
	private String cardid;//身份证id
	
	private String name;//姓名
	
	private String sex;//性别(男、女)
	
	private String birthDate;//出生日期
	
	private String householdRegister;//户籍所在地址
	
	private String photo;//照片
	
	private String regTime;
	
	private String loginCount;
	
	private String lastLoginTime;

	public String getCustomerid() {
		return customerid;
	}

	public void setCustomerid(String customerid) {
		this.customerid = customerid;
	}

	public String getCardid() {
		return cardid;
	}

	public void setCardid(String cardid) {
		this.cardid = cardid;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getSex() {
		return sex;
	}

	public void setSex(String sex) {
		this.sex = sex;
	}

	public String getBirthDate() {
		return birthDate;
	}

	public void setBirthDate(String birthDate) {
		this.birthDate = birthDate;
	}

	public String getHouseholdRegister() {
		return householdRegister;
	}

	public void setHouseholdRegister(String householdRegister) {
		this.householdRegister = householdRegister;
	}

	public String getPhoto() {
		return photo;
	}

	public void setPhoto(String photo) {
		this.photo = photo;
	}

	public String getRegTime() {
		return regTime;
	}

	public void setRegTime(String regTime) {
		this.regTime = regTime;
	}

	public String getLoginCount() {
		return loginCount;
	}

	public void setLoginCount(String loginCount) {
		this.loginCount = loginCount;
	}

	public String getLastLoginTime() {
		return lastLoginTime;
	}

	public void setLastLoginTime(String lastLoginTime) {
		this.lastLoginTime = lastLoginTime;
	}

	public static long getSerialversionuid() {
		return serialVersionUID;
	}
}

 5、customerinfo.hbm.xml映射文件

<!DOCTYPE hibernate-mapping PUBLIC 
   "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
   "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
   
   <hibernate-mapping>
   
   	<class name="com.ai.customer.model.CustomerInfo" table="customerInfo">
   	
   		<id name="customerid" column="customerid" type="java.lang.String">
   			<generator class="assigned"/>
   		</id>
   	
	   	<property name="cardid" type="java.lang.String"/>
	   	<property name="name" type="java.lang.String"/>
	   	<property name="sex" type="java.lang.String"/>
	   	<property name="birthDate" type="java.lang.String"/>
	   	<property name="householdRegister" type="java.lang.String"/>
	   	<property name="photo" type="java.lang.String"/>
	   	<property name="regTime" type="java.lang.String"/>
	   	<property name="loginCount" type="java.lang.String"/>
	   	<property name="lastLoginTime" type="java.lang.String"/>   	
   	</class>
   
   </hibernate-mapping>

 6、service接口实现

package com.ai.customer.service;

import java.util.List;

import com.ai.customer.model.CustomerInfo;

public interface ICustomerService {

	//查询Customer
	public List<CustomerInfo> queryCustomer();
	
	public String all();
}

 7、接口实现

package com.ai.customer.serviceImpl;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Repository;
import org.springframework.stereotype.Service;

import com.ai.customer.dao.ICustomerDao;
import com.ai.customer.model.CustomerInfo;
import com.ai.customer.service.ICustomerService;

@Service
public class CustomerService implements ICustomerService{

	@Autowired
	private ICustomerDao customerDao;
	

	public List<CustomerInfo> queryCustomer() {
		return customerDao.queryCustomer();
	}



	public String all() {
		// TODO Auto-generated method stub
		return customerDao.all();
	}

}

 8、JDBC类

package com.ai.util;

import java.beans.PropertyVetoException;
import java.io.*;
import java.sql.*;
import java.util.Properties;

import org.apache.log4j.Logger;

import com.mchange.v2.c3p0.ComboPooledDataSource;


public class JDBCUtil {
	
	private static Logger log=Logger.getLogger(JDBCUtil.class);
	//使用c3p0 连接池
	private static ComboPooledDataSource ds;
	static {
		
		ds=new ComboPooledDataSource();
		
		//加载驱动
		try {
			ds.setDriverClass(getProperties("jdbc.driver"));
		} catch (PropertyVetoException e) {
			log.error("加载驱动失败",e);
			e.printStackTrace();
		}
		//数据库连接
		ds.setJdbcUrl(getProperties("jdbc.url"));
		//用户
		ds.setUser(getProperties("jdbc.username"));
		//密码
		ds.setPassword(getProperties("jdbc.password"));
		//初始化开几个连接
		ds.setInitialPoolSize(Integer.parseInt(getProperties("jdbc.initialPoolSize")));
		//最大开几个
		ds.setMaxPoolSize(Integer.parseInt(getProperties("jdbc.maxPoolSize")));
		//最小开几个
		ds.setMinPoolSize(Integer.parseInt(getProperties("jdbc.minPoolSize")));
		//设置等待时间
		ds.setMaxIdleTime(Integer.parseInt(getProperties("jdbc.maxIdleTime")));
	}

	
	public final static Connection getConnection(){
		
		try {
			return ds.getConnection();
		} catch (SQLException e) {
			log.error("获取连接失败",e);
			e.printStackTrace();
		}
		return null;
	}
	
	
	//关闭连接
	public final static void closeConntion(ResultSet re,PreparedStatement psnt,Connection conn){
		
		
		if(re!=null)
			try {
				re.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			
		if(psnt!=null)
			try {
				psnt.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			
		if(conn!=null)
			try {
				conn.close();
			} catch (SQLException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
	}
	
	
	// 读取连接数据文件
	public final static String getProperties(String name){
		InputStream  str=Thread.currentThread().getContextClassLoader().getResourceAsStream("config/hibernet/jdbc.properties");
		Properties properties=new Properties();
		try {
			properties.load(str);
			return properties.getProperty(name);
		} catch (FileNotFoundException e) {
			e.printStackTrace();
			log.error("读取jdbc.properties文件不存在",e);
		} catch (IOException e) {
			e.printStackTrace();
			log.error("读取jdbc.properties文件异常",e);
		}
		return "";
	}
	
	
	
	public static String query(){
		
		
		Connection conn=JDBCUtil.getConnection();
		
		PreparedStatement psnt=null;
		
		ResultSet re=null;
		
		String sql="select * from customerinfo";
		try {
			psnt=conn.prepareStatement(sql);
			
			re=psnt.executeQuery();
			
			if(re.next()){
				return re.getString("customerid");
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			closeConntion(re, psnt, conn);
		}
		return "";
	}
	
	
	public static void main(String[] args) {
		
		System.out.println(JDBCUtil.query());
//		System.out.println(getConnection());
//		System.out.println(getProperties("driver"));
//		System.out.println(getProperties("username"));
//		System.out.println(getProperties("password"));
//		System.out.println(getProperties("url"));
		
	}
}

 9、hibernate.cfg.xml配置文件

<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
    
    <hibernate-configuration> 
	    <!--表明以下的配置是针对session-factory配置的,SessionFactory是Hibernate中的一个类,这个类主要负责保存HIbernate的配置信息,以及对Session的操作-->
		<session-factory>
	
		<!--hibernate.dialect 只是Hibernate使用的数据库方言,就是要用Hibernate连接那种类型的数据库服务器。-->
			<property name="dialect">
				org.hibernate.dialect.MySQLDialect
			</property>
			<property name="connection.url">
				jdbc:mysql://localhost:3306/data
			</property>
			<property name="connection.username">root</property>
			<property name="connection.password">123456</property>
			<property name="connection.driver_class">
				com.mysql.jdbc.Driver
			</property>
			
		<!--数据库连接池的大小-->
		<property name="hibernate.connection.pool.size">10</property>
		
		<!--是否在后台显示Hibernate用到的SQL语句,开发时设置为true,便于差错,程序运行时可以在Eclipse的控制台显示Hibernate的执行Sql语句。项目部署后可以设置为false,提高运行效率-->
		<property name="hibernate.show_sql">true</property>
		
		<!--jdbc.fetch_size是指Hibernate每次从数据库中取出并放到JDBC的Statement中的记录条数。Fetch Size设的越大,读数据库的次数越少,速度越快,Fetch Size越小,读数据库的次数越多,速度越慢-->
		<property name="jdbc.fetch_size">50</property>
		
		<!--jdbc.batch_size是指Hibernate批量插入,删除和更新时每次操作的记录数。Batch Size越大,批量操作的向数据库发送Sql的次数越少,速度就越快,同样耗用内存就越大-->
		<property name="jdbc.batch_size">23</property>
		
		<!--jdbc.use_scrollable_resultset是否允许Hibernate用JDBC的可滚动的结果集。对分页的结果集。对分页时的设置非常有帮助-->
		<property name="jdbc.use_scrollable_resultset">false</property>
		
		<!--connection.useUnicode连接数据库时是否使用Unicode编码-->
		<property name="Connection.useUnicode">true</property>
		
		<!--connection.characterEncoding连接数据库时数据的传输字符集编码方式,最好设置为gbk,用gb2312有的字符不全-->
		<property name="connection.characterEncoding">gbk</property>
	
		
		
		<!--连接池的最小连接数-->
		<property name="hibernate.c3p0.min_size">5</property>
		
		<!--最大连接数-->
		<property name="hibernate.c3p0.max_size">500</property>
		
		<!--连接超时时间-->
		<property name="hibernate.c3p0.timeout">1800</property>
		
		<!--statemnets缓存大小-->
		<property name="hibernate.c3p0.max_statements">0</property>
		
		<!--每隔多少秒检测连接是否可正常使用  -->
		<property name="hibernate.c3p0.idle_test_period">121</property>
		
		<!--当池中的连接耗尽的时候,一次性增加的连接数量,默认为3-->
		<property name="hibernate.c3p0.acquire_increment">5</property>
		
		<property name="hibernate.c3p0.validate">true</property>
	
		<mapping resource="com/ai/customer/model/CustomerInfo.hbm.xml" />
	
	</session-factory>

</hibernate-configuration>    
    
   
    

 10、jdbc.properties配置文件

#JDBC连接驱动
jdbc.driver=com.mysql.jdbc.Driver
#服务器连接地址
jdbc.url=jdbc:mysql://127.0.0.1:3306/data?autoReconnect=true&useUnicode=true&characterEncoding=UTF-8
#用户名
jdbc.username=root
#密码
jdbc.password=123456

#连接池
#初始化连接
jdbc.initialPoolSize=10
# 最大连接
jdbc.maxPoolSize=20
#最小连接
jdbc.minPoolSize=5
#等待时间s
jdbc.maxIdleTime=30000

 11、spring-appliction.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"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
	http://www.springframework.org/schema/beans/spring-beans.xsd
	http://www.springframework.org/schema/context
	http://www.springframework.org/schema/context/spring-context-3.2.xsd">
	
	
	<!-- 配置数据源
	<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
	
		
		<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
		
		<property name="url" value="jdbc:mysql://localhost/data"/>
		
		<property name="username" value="root"/>
		
		<property name="password" value="123456"/>
	</bean>
	 -->
	<!-- hibernet 配置 -->
	<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		
		<!-- <property name="dataSource" ref="dataSource"/> --> 
		
		<property name="configLocation">
			<value>classpath:config/hibernet/hibernate.cfg.xml</value>
		</property>
		
	</bean>
	
	<!-- 配置事务 -->
	<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
		<property name="sessionFactory" ref="sessionFactory" />
	</bean>

	<!-- 使用代理配置事务管理 -->
	<bean id="transactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean" abstract="true">
		<property name="transactionManager" ref="transactionManager" />
		<property name="transactionAttributes">  
	        <props>  
	        <!--  	如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。 -->
	            <prop key="add*">PROPAGATION_REQUIRED,-Exception</prop>  
	            <prop key="modify*">PROPAGATION_REQUIRED,-myException</prop>  
	            <prop key="del*">PROPAGATION_REQUIRED</prop>  
	            <prop key="find*">PROPAGATION_REQUIRED,readOnly</prop>
	            <prop key="*">PROPAGATION_REQUIRED</prop>  
	        </props>  
	    </property>  
	</bean>
</beans>

 12、spring-mvc.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"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
	http://www.springframework.org/schema/beans/spring-beans.xsd
	http://www.springframework.org/schema/context
	http://www.springframework.org/schema/context/spring-context-3.2.xsd
	http://www.springframework.org/schema/mvc
	http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd">
	
	
<!-- 扫描包 -->
<context:component-scan base-package="com.ai.customer" />

 <!-- 启动注解 -->
 <mvc:annotation-driven />


<!-- 文件上传 -->
 <bean id="multipartResolver"  
   class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
   <!-- 设置上传文件的最大尺寸为10MB -->  
   <property name="maxUploadSize">  
       <value>10000000</value>  
   </property>  
  </bean>  


<!--  静态文件访问 -->
 <mvc:default-servlet-handler/> 
 <!-- 对模型视图名称的解析,即在模型视图名称添加前后缀 --> 
 <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" >
 
 	<property name="prefix" value="/"/>
 	<property name="suffix" value=".jsp"/>	
 </bean> 
 
</beans>

 13、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" 
		 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>springmvc_sh</display-name>
  <welcome-file-list>
    <welcome-file>login/login.jsp</welcome-file>
  </welcome-file-list>
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath*:config/spring/spring-appliction.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>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath*:config/spring/spring-*.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>spring</servlet-name>
    <url-pattern>*.do</url-pattern>
  </servlet-mapping>
  <listener>
    <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
  </listener>
  <filter>
    <filter-name>codeUTF-8</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
      <param-name>forceEncoding</param-name>
      <param-value>true</param-value>
    </init-param>
  </filter>
  <filter-mapping>
    <filter-name>codeUTF-8</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>


	<error-page>
		<error-code>404</error-code>
		<location>/login/loginIput.jsp</location>
	</error-page>
	<error-page>
		<error-code>500</error-code>
		<location>/login/login.jsp</location>
	</error-page>
</web-app>

 

  • 大小: 187.3 KB
0
0
分享到:
评论

相关推荐

    Spring+SpringMVC+Hibernate框架集成详解

    Spring+SpringMVC+Hibernate 框架集成详解 本文档旨在详细介绍 Spring、SpringMVC 和 Hibernate 框架的集成,旨在帮助开发人员快速了解这三个框架的集成过程。 Spring 框架 Spring 框架是一个 Java 语言的开源...

    新SSH(Spring+SpringMVC+Hibernate)框架结构的java web案例实践

    随着struts的安全问题的暴露,原由Struts2+spring+hibernate构成的SSH2已经被越来越多的开发者所弃用,反而,由Spring+SpringMVC+Hibernate构成的SSH框架越来越受欢迎!这里提供了一个案例代码,希望对大家搭建环境...

    基于注解的springMVC+hibernate+oracle包含数据库查询

    本文将详细解析基于注解的SpringMVC+Hibernate+Oracle数据库集成的实现过程及其核心知识点。 首先,SpringMVC是Spring框架的一部分,它是一个轻量级的MVC(Model-View-Controller)框架,用于处理HTTP请求和响应。...

    idea工具创建的Spring+SpringMVC+Hibernate+maven项目

    标题中的"idea工具创建的Spring+SpringMVC+Hibernate+maven项目"指的是使用IntelliJ IDEA这个集成开发环境(IDE)构建的一个Java Web项目,该项目整合了四个关键的技术框架:Spring、SpringMVC、Hibernate以及Maven...

    spring+springMVC+hibernate集成

    Spring、SpringMVC和Hibernate是Java开发中三大核心框架,它们的集成是企业级Web应用开发的常见模式,被广泛用于构建复杂、可扩展的后端系统。SSH(Spring、SpringMVC、Hibernate)集成提供了从数据持久化到业务逻辑...

    Spring+SpringMVC+hibernate集成jar包

    在集成Spring、SpringMVC和Hibernate时,通常需要以下jar包: 1. Spring的核心库,包括spring-context、spring-beans、spring-aop、spring-web和spring-webmvc等,这些库提供了Spring的基本功能。 2. Hibernate的...

    springmvc+hibernate完整项目

    学习和研究这个项目,可以深入理解SpringMVC和Hibernate的集成使用,提升Java Web开发技能。同时,对于项目中提到的不足之处,开发者可以尝试优化前端验证、增强错误处理、调整性能等方面,进一步完善项目。

    SpringMVC+Hibernate+Spring

    在SpringMVC和Hibernate的集成中,Spring可以配置和管理这两个组件的bean,例如,通过Bean定义加载Hibernate的SessionFactory,以及为Controller注入Service层的对象。 在实际的项目中,整合SpringMVC、Hibernate和...

    Maven整合Spring+SpringMVC+Hibernate+SpringDataJPA

    在现代Java Web开发中,"Maven整合Spring+SpringMVC+Hibernate+SpringDataJPA"是一个常见的架构组合,被广泛应用于构建企业级应用程序。这个组合通常被称为"SSM",其中"M"代表Maven,"S"代表Spring,包括Spring核心...

    SpringMVC+Hibernate+EXT

    总结起来,"SpringMVC+Hibernate+EXT"的项目源码提供了一个完整的解决方案,涵盖了Web开发的各个方面:从后端的业务逻辑处理到前端的用户体验设计。通过学习和理解这个项目的源码,开发者可以深入理解如何将这三个...

    spring3+springmvc+jpa+hibernate多数据源

    "spring3+springmvc+jpa+hibernate多数据源"是一个示例项目,它演示了如何在一个应用中集成Spring 3、Spring MVC、JPA 2.0以及Hibernate,以实现对多个数据源的支持。下面将详细介绍这些技术及其集成的关键点。 **...

    Spring+SpringMVC+Hibernate+JSP框架搭建

    3. **集成Hibernate**:配置Hibernate SessionFactory,通过Spring的JPA或HibernateTemplate实现对数据库的操作,如增删改查。 4. **创建JSP页面**:设计JSP页面作为用户界面,使用EL(Expression Language)和JSTL...

    maven+spring+springmvc+hibernate项目示例

    在IT行业中,构建高效、可维护的Web应用是至关重要的,而"Maven+Spring+SpringMVC+Hibernate"是一个常用的技术栈,它整合了多个强大的工具和框架来简化开发流程。下面将详细介绍这个项目示例中涉及的关键知识点。 1...

    spring+springmvc+hibernate+thymeleaf 练习demo项目源码

    本项目"spring+springmvc+hibernate+thymeleaf 练习demo"是一个整合了这四个框架的实践示例,旨在帮助学习者理解它们如何协同工作。下面我们将深入探讨这些技术及其在项目中的应用。 1. Spring框架: - **依赖注入...

    百度Ueditor整合springMVC+hibernate完整demo

    《整合百度UEditor与SpringMVC+Hibernate:创建一个完整的Web应用DEMO》 在Web开发中,富文本编辑器是不可或缺的一部分,它为用户提供了一种便捷的方式来输入和格式化文本。百度UEditor是一款功能强大的在线编辑器...

    spring+springmvc+hibernate网上书城

    它集成了Spring框架、Spring MVC和Hibernate三个核心组件,构建了一个完整的后端系统,提供了普通用户购书以及管理员进行图书与用户管理的功能。 【Spring框架】Spring是Java领域最流行的轻量级开源框架之一,它...

    springMVC+hibernate+mysql

    在SpringMVC和Hibernate的集成中,MySQL作为数据存储的后端,可以通过JDBC(Java Database Connectivity)接口与应用程序进行通信。Hibernate通过JDBC驱动与MySQL交互,执行SQL命令,从而实现对数据的CRUD(Create、...

    SpringMVC+Hibernate+Spring+JSP整合实例

    "SpringMVC+Hibernate+Spring+JSP整合实例"是一个经典的后端技术组合,它涵盖了Java领域中多个核心框架的集成应用,旨在实现数据持久化、业务逻辑处理以及用户界面展示的无缝连接。下面我们将深入探讨这些技术及其...

    springmvc+spring+hibernate集成jar包

    这个"springmvc+spring+hibernate集成jar包"包含了这三个框架集成所需的所有依赖,使得开发者能够快速搭建一个基于SSH(Spring、Spring MVC、Hibernate)的项目。 Spring 框架是Java企业级应用的核心,它提供了依赖...

    Spring+SpringMVC+Hibernate非注解版

    【标题】"Spring+SpringMVC+Hibernate非注解版" 涵盖了Java开发中的三大核心框架,它们是Spring、SpringMVC和Hibernate。这些框架协同工作,为Java Web应用程序提供了一种高效且模块化的开发方式。Spring作为整体...

Global site tag (gtag.js) - Google Analytics