一步步搭框架……主要还是myeclipse+Tomat+mysql
准备工作:准备jar包(我已经是一股脑的全部加进去了我也不知道哪些要不要了)已经配置好tomact,以及新建好myqsl数据库。新建web工程,webroot下记得要有web.xml,jar包放在lib里!
对于Hibernate我已经能用注解就用注解了
目录结构
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</display-name> <servlet> <servlet-name>springDispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springmvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springDispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- 配置过滤器 作用是把Post请求转换为delete和put --> <filter> <filter-name>HiddenHttpMethodFilter</filter-name> <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class> </filter> <filter-mapping> <filter-name>HiddenHttpMethodFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
spring.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:p="http://www.springframework.org/schema/p" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xmlns:jee="http://www.springframework.org/schema/jee" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:task="http://www.springframework.org/schema/task" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation=" http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> <!-- 自动扫描的包 --> <context:component-scan base-package="com.yiki"></context:component-scan> <!-- 可以使用注解是注入 --> <context:annotation-config /> <!-- 数据源 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/springmvc?useUnicode=true&characterEncoding=UTF-8" /> <property name="username" value="root" /> <property name="password" value="******" /> <!-- 连接池启动的初始值 --> <property name="initialSize" value="1"></property> <!-- 连接池的最大值 --> <property name="maxActive" value="500"></property> </bean> <!-- 它充当数据存储源的代理,并负责创建Session对象 --> <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="annotatedClasses"> <list> <value>com.yiki.POJO.Person</value> </list> </property> <property name="hibernateProperties"><!-- 配置hibernate的属性映射 --> <props> <!-- 方言 --> <prop key="hibernate.dialect"> org.hibernate.dialect.MySQLDialect </prop> <prop key="hibernate.show_sql">true</prop> <!-- 自动建表 --> <prop key="hibernate.hbm2ddl.auto">update</prop> <prop key="hibernate.current_session_context_class">org.springframework.orm.hibernate4.SpringSessionContext </prop> </props> </property> </bean> <!-- 事务管理器 --> <bean id="txManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory"></property> </bean> <!-- 需要tx命名空间 注解方式实现事务,此功能为注解解析 --> <tx:annotation-driven transaction-manager="txManager" /> <!-- 配置视图解析器:如何把handler方法解析为实际屋里视图 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver"> <!-- 前缀 --> <property name="prefix" value="/WEB-INF/view/" /> <!-- 后缀 --> <property name="suffix" value=".jsp" /> </bean> <!-- 配置直接转发的页面 --> <mvc:annotation-driven></mvc:annotation-driven> <mvc:view-controller path="/success" view-name="success"></mvc:view-controller> <!-- 配置视图解析器 ,使用视图的名字来解析视图,order可以定义视图优先级 --> <bean class="org.springframework.web.servlet.view.BeanNameViewResolver"> <property name="order" value="100"></property> </bean> <!-- 对Hibernate定义bean --> <bean id="personService" class="com.yiki.Model.PersonService"></bean> </beans>
根据配置文件写的前缀和后缀新建对应的文件夹和文件
比如view文件夹下的success.jsp
实体类
package com.yiki.POJO; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; @Entity(name="person") public class Person { @Id @GeneratedValue//mysql底层是自动增长 private int pid; private String name; public Person() { // TODO Auto-generated constructor stub } public Person(String name) { this.name=name; } public int getPid() { return pid; } public void setPid(int pid) { this.pid = pid; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "Person [pid=" + pid + ", name=" + name + "]"; } }
模型层(增删查改的hibernate和spring的事务)
package com.yiki.Model; import java.util.List; import javax.annotation.Resource; import org.hibernate.SessionFactory; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; import com.yiki.POJO.Person; //读取的操作都不需要开启事务! @Transactional public class PersonService {//是一个业务bean @Resource // 默认按名称注入,注意同名 private SessionFactory sessionFactory; public void save(Person person) { sessionFactory.getCurrentSession().persist(person);// 得到spring管理的session } public void update(Person person) { sessionFactory.getCurrentSession().merge(person); } //@Transactional(propagation=Propagation.REQUIRED,readOnly=true) public Person getPerson(int id) { return (Person) sessionFactory.getCurrentSession().get(Person.class, id); // return (Person) sessionFactory.openSession().get(Person.class, id);//open会不起作用 } //@Transactional(noRollbackFor={Exception.class})如果设置不回滚 public void delete(int id) { sessionFactory.getCurrentSession().delete(sessionFactory.getCurrentSession().load(Person.class, id)); //throw new RuntimeException("测试回滚"); } @Transactional(propagation=Propagation.REQUIRED,readOnly=true) //要疯了propagation死也不起作用?????? public List<Person> getPerson() {//from 类名不是表名 return sessionFactory.getCurrentSession().createQuery("from Person").list(); } }
控制层
package com.yiki.Handle; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import com.yiki.Model.PersonService; import com.yiki.POJO.Person; @RequestMapping("/restStyle") @Controller public class RestMapping { private PersonService service; public void start() { ApplicationContext cxt = new ClassPathXmlApplicationContext("springmvc.xml"); service = (PersonService) cxt.getBean("personService"); } private static final String SUCCESS = "success"; @RequestMapping(value = "/testRest/{id}", method = RequestMethod.GET) public String testRestGet(@PathVariable Integer id) { start(); Person person = service.getPerson(id); System.out.println("GET :" + id + person); return SUCCESS; } @RequestMapping(value = "/testRest", method = RequestMethod.POST) public String testRestPost() { System.out.println("POST"); return SUCCESS; } @RequestMapping(value = "/testRest/{id}", method = RequestMethod.DELETE) public String testResDeletet(@PathVariable Integer id) { System.out.println("Delete :" + id); return SUCCESS; } @RequestMapping(value = "/testRest/{id}", method = RequestMethod.PUT) public String testResPut(@PathVariable Integer id) { System.out.println("PUT :" + id); return SUCCESS; } }
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>My JSP 'index.jsp' starting page</title> </head> <body> <a href="restStyle/testRest/22">Get</a> <br> <form action="restStyle/testRest" method="Post"> <input type="submit" value="Post"> </form> <br> <form action="restStyle/testRest/1" method="Post"> <input type="hidden" name="_method" value="DELETE"> <input type="submit" value="Delete"> </form> <br> <form action="restStyle/testRest/2" method="Post"> <input type="hidden" name="_method" value="PUT"> <input type="submit" value="PUT"> </form> <a href="helloworld">helloworld</a><br> </body> </html>点击index的get能有查到数据库的东西并在控制台打印出来即为成功~其他的可以自己加