??xml version="1.0" encoding="utf-8" standalone="yes"?>
一、初始化工作:新徏一个项??ssh),在此目中导入对hibernate的支?新徏一个表sstest表,有字Did,username,password,idZ健和自动?
二、对新徏的数据表q行hibernateq行映射,打开myhibernate视图Q右Msstest?>选hibernate revers engineering选项Q然后把Sstest.hbm.xml文g映射到hibernateDao包中Q同旉中工具 hibernate mapping file..., java data object....., java data access object dao...选项Q先中这几个文g可以生下列几?java文g:BaseHibernateDAO. ,HibernateSessionFactory ,IBaseHibernateDAO, Sstest,SstestDAO,最后你对你的代码进行测试,试成功Q进行下一?br />
三、在目中导入对spring的支持,在导入项目后不但要自动生applicationContext.xml,而且在这个文仉会出C面的内容Q?br />
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation" value="classpath:hibernate.cfg.xml">
</property>
</bean>
q就是ؓ什么要先要导入hibernate的原?br />
四、若你对spring的ioc比较熟,你可以直接进入下一步,如果不是很了解,那么你可以写一个比较简单的例子试一下看是否成功Q必竟框架和在一P所以小心点好,不然在以后出了有问题不好?br />
五、进入myeclipse hibernate视图下,在新的包Q如springDaoQ中重新对sstest表进行映,q次映射要注意的是Q打开hibernate reverse engineering对话框中复选按钮java data access object(dao)(hibernate 3 only)下,dao type 不是选basic dao选项Q而是选spring dao选项Q当你映成功后Q就会出现Sstest.java, SstestDAO.java, Sstest.hbm.xml几个文gQ你可以写一个类q行试Q如Q?br />
springdaotest.java
package org.test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import springDao.Sstest;
import springDao.SstestDAO;
public class SpringDaoTest {
public static void main(String a[]){
ApplicationContext cont = new ClassPathXmlApplicationContext("applicationContext.xml");
SstestDAO s = (SstestDAO) cont.getBean("SstestDAO");
SstestDAO s = (SstestDAO) cont.getBean("SstestDAOProxy");
Sstest st = new Sstest();
st.setUsername("spring");
st.setPassword("spring");
s.save(st);
}
}
六、由于映了两次Q所以你要在hibernate.cfg.xml文g中,把原来映的文g注解掉:
<mapping resource="hibernateDao/Sstest.hbm.xml" />
因ؓ现在已有一行这L代码Q?br />
<mapping resource="springDao/Sstest.hbm.xml" />
七、实现hibernate spring 代理Q加上下面的代码卛_Q?br />
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref local="sessionFactory"/>
</property>
</bean>
<bean id="SstestDAOProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="proxyTargetClass">
<value>true</value>
</property>
<property name="transactionManager">
<ref bean="transactionManager"/>
</property>
<property name="target">
<ref local="SstestDAO"/>
</property>
<property name="transactionAttributes">
<props>
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>
在进行测试,试Ӟq是用原来的c,只需把SstestDAO s = (SstestDAO) cont.getBean("SstestDAO");变成
SstestDAO s = (SstestDAO) cont.getBean("SstestDAOProxy");q次的bean是用的代码类实现
下面是完整的代码Q?br />
在这个实例中hibernate包中的文件BaseHibernateDAO. ,HibernateSessionFactory ,IBaseHibernateDAO, Sstest,SstestDAO, Sstest.hbm.xml Q和?a class="singleposttitle" id="viewpost1_TitleUrl" href="http://www.aygfsteel.com/qin/archive/2008/10/19/235318.html">一个简单的strutsQhibernate例子以及struts,hibernate集成中的文g是一LQ代码一P下面是一些其它代码:
applicationContext.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="configLocation" value="classpath:hibernate.cfg.xml">
</property>
</bean>
<!-- spring dao -->
<bean id="SstestDAO" class="springDao.SstestDAO">
<property name="sessionFactory">
<ref bean="sessionFactory"/>
</property>
</bean>
<!-- hibernate 3 事务代理 -->
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory">
<ref local="sessionFactory"/>
</property>
</bean>
<bean id="SstestDAOProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="proxyTargetClass">
<value>true</value>
</property>
<property name="transactionManager">
<ref bean="transactionManager"/>
</property>
<property name="target">
<ref local="SstestDAO"/>
</property>
<property name="transactionAttributes">
<props>
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>
</beans>
试c:SpringDaoTest.java
package org.test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import springDao.Sstest;
import springDao.SstestDAO;
public class SpringDaoTest {
public static void main(String a[]){
ApplicationContext cont = new ClassPathXmlApplicationContext("applicationContext.xml");
//SstestDAO s = (SstestDAO) cont.getBean("SstestDAO");
//代理c?br />
SstestDAO s = (SstestDAO) cont.getBean("SstestDAOProxy");
Sstest st = new Sstest();
st.setUsername("spring");
st.setPassword("spring");
s.save(st);
}
}
Sstest.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="springDao.Sstest" table="sstest" schema="dbo" catalog="manager">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="increment" />
</id>
<property name="username" type="java.lang.String">
<column name="username" length="10" />
</property>
<property name="password" type="java.lang.String">
<column name="password" length="20" />
</property>
</class>
</hibernate-mapping>
SstestDAO.java
package springDao;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.LockMode;
import org.springframework.context.ApplicationContext;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
public class SstestDAO extends HibernateDaoSupport {
private static final Log log = LogFactory.getLog(SstestDAO.class);
// property constants
public static final String USERNAME = "username";
public static final String PASSWORD = "password";
protected void initDao() {
// do nothing
}
public void save(Sstest transientInstance) {
log.debug("saving Sstest instance");
System.out.println("Ok");
try {
getHibernateTemplate().save(transientInstance);
log.debug("save successful");
System.out.print("save Ok");
} catch (RuntimeException re) {
log.error("save failed", re);
throw re;
}
}
public void delete(Sstest persistentInstance) {
log.debug("deleting Sstest instance");
try {
getHibernateTemplate().delete(persistentInstance);
log.debug("delete successful");
} catch (RuntimeException re) {
log.error("delete failed", re);
throw re;
}
}
public Sstest findById(java.lang.Integer id) {
log.debug("getting Sstest instance with id: " + id);
try {
Sstest instance = (Sstest) getHibernateTemplate().get(
"springDao.Sstest", id);
return instance;
} catch (RuntimeException re) {
log.error("get failed", re);
throw re;
}
}
public List findByExample(Sstest instance) {
log.debug("finding Sstest instance by example");
try {
List results = getHibernateTemplate().findByExample(instance);
log.debug("find by example successful, result size: "
+ results.size());
return results;
} catch (RuntimeException re) {
log.error("find by example failed", re);
throw re;
}
}
public List findByProperty(String propertyName, Object value) {
log.debug("finding Sstest instance with property: " + propertyName
+ ", value: " + value);
try {
String queryString = "from Sstest as model where model."
+ propertyName + "= ?";
return getHibernateTemplate().find(queryString, value);
} catch (RuntimeException re) {
log.error("find by property name failed", re);
throw re;
}
}
public List findByUsername(Object username) {
return findByProperty(USERNAME, username);
}
public List findByPassword(Object password) {
return findByProperty(PASSWORD, password);
}
public List findAll() {
log.debug("finding all Sstest instances");
try {
String queryString = "from Sstest";
return getHibernateTemplate().find(queryString);
} catch (RuntimeException re) {
log.error("find all failed", re);
throw re;
}
}
public Sstest merge(Sstest detachedInstance) {
log.debug("merging Sstest instance");
try {
Sstest result = (Sstest) getHibernateTemplate().merge(
detachedInstance);
log.debug("merge successful");
return result;
} catch (RuntimeException re) {
log.error("merge failed", re);
throw re;
}
}
public void attachDirty(Sstest instance) {
log.debug("attaching dirty Sstest instance");
try {
getHibernateTemplate().saveOrUpdate(instance);
log.debug("attach successful");
} catch (RuntimeException re) {
log.error("attach failed", re);
throw re;
}
}
public void attachClean(Sstest instance) {
log.debug("attaching clean Sstest instance");
try {
getHibernateTemplate().lock(instance, LockMode.NONE);
log.debug("attach successful");
} catch (RuntimeException re) {
log.error("attach failed", re);
throw re;
}
}
public static SstestDAO getFromApplicationContext(ApplicationContext ctx) {
return (SstestDAO) ctx.getBean("SstestDAO");
}
}
Sstest.java
package springDao;
public class Sstest implements java.io.Serializable {
// Fields
private Integer id;
private String username;
private String password;
// Constructors
/** default constructor */
public Sstest() {
}
/** full constructor */
public Sstest(String username, String password) {
this.username = username;
this.password = password;
}
// Property accessors
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return this.username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return this.password;
}
public void setPassword(String password) {
this.password = password;
}
}
hibernate.cfg.xml
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<property name="connection.username">sa</property>
<property name="connection.url">
jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=manager
</property>
<property name="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<property name="myeclipse.connection.profile">
com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<property name="connection.password">wq</property>
<property name="connection.driver_class">
com.microsoft.jdbc.sqlserver.SQLServerDriver
</property>
<!-- <mapping resource="hibernateDao/Sstest.hbm.xml" /> -->
<!-- 使用springdao -->
<mapping resource="springDao/Sstest.hbm.xml" />
</session-factory>
</hibernate-configuration>
<%@ page language="java" pageEncoding="ISO-8859-1"%>
<%@ taglib uri="http://struts.apache.org/tags-bean" prefix="bean"%>
<%@ taglib uri="http://struts.apache.org/tags-html" prefix="html"%>
<html>
<head>
<title>JSP for Register1Form form</title>
</head>
<body>
<html:form action="/register1">
password : <html:password property="password"/><html:errors property="password"/><br/>
username : <html:text property="username"/><html:errors property="username"/><br/>
<html:submit/><html:cancel/>
</html:form>
</body>
</html>
Register1Action.java
package com.yourcompany.struts.action;
import hibernateDao.Sstest;
import hibernateDao.SstestDAO;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
import org.hibernate.Transaction;
import com.yourcompany.struts.form.Register1Form;
public class Register1Action extends Action {
//数据dao
SstestDAO sd;
public Register1Action() {
// TODO Auto-generated constructor stub
setSd(new SstestDAO());
}
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) {
Register1Form register1Form = (Register1Form) form;// TODO Auto-generated method stub
//输出客户端的用户?br />
response.setCharacterEncoding("GB2312");
System.out.println("register1Form.name\t"+register1Form.getUsername());
/*
* 数据库操?br />
* */
Sstest st = new Sstest();
st.setUsername(register1Form.getUsername());
st.setPassword(register1Form.getPassword());
//dao对象
SstestDAO sd = getSd();
Transaction tran = sd.getSession().beginTransaction(); //开始事?br />
sd.save(st);
tran.commit();
//h转发到success
return mapping.findForward("success");
}
//数据daoQgetQsetҎ
public void setSd(SstestDAO sd) {
this.sd = sd;
}
public SstestDAO getSd() {
return sd;
}
}
Register1Form.java
package com.yourcompany.struts.form;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts.action.ActionErrors;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionMapping;
public ActionErrors validate(ActionMapping mapping,
HttpServletRequest request) {
// TODO Auto-generated method stub
return null;
}
public void reset(ActionMapping mapping, HttpServletRequest request) {
// TODO Auto-generated method stub
this.username = "qin";
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
}
如果你觉得你的代码自动生成有问题的话Q你可以参考下列代?/p>
BaseHibernateDAO.java
package hibernateDao;
import org.hibernate.Session;
public class BaseHibernateDAO implements IBaseHibernateDAO {
public Session getSession() {
return HibernateSessionFactory.getSession();
}
}
HibernateSessionFactory.java
package hibernateDao;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.cfg.Configuration;
public class HibernateSessionFactory {
private static String CONFIG_FILE_LOCATION = "/hibernate.cfg.xml";
private static final ThreadLocal<Session> threadLocal = new ThreadLocal<Session>();
private static Configuration configuration = new Configuration();
private static org.hibernate.SessionFactory sessionFactory;
private static String configFile = CONFIG_FILE_LOCATION;
static {
try {
configuration.configure(configFile);
sessionFactory = configuration.buildSessionFactory();
} catch (Exception e) {
System.err
.println("%%%% Error Creating SessionFactory %%%%");
e.printStackTrace();
}
}
private HibernateSessionFactory() {
}
public static Session getSession() throws HibernateException {
Session session = (Session) threadLocal.get();
if (session == null || !session.isOpen()) {
if (sessionFactory == null) {
rebuildSessionFactory();
}
session = (sessionFactory != null) ? sessionFactory.openSession()
: null;
threadLocal.set(session);
}
return session;
}
public static void rebuildSessionFactory() {
try {
configuration.configure(configFile);
sessionFactory = configuration.buildSessionFactory();
} catch (Exception e) {
System.err
.println("%%%% Error Creating SessionFactory %%%%");
e.printStackTrace();
}
}
public static void closeSession() throws HibernateException {
Session session = (Session) threadLocal.get();
threadLocal.set(null);
if (session != null) {
session.close();
}
}
public static org.hibernate.SessionFactory getSessionFactory() {
return sessionFactory;
}
public static void setConfigFile(String configFile) {
HibernateSessionFactory.configFile = configFile;
sessionFactory = null;
}
public static Configuration getConfiguration() {
return configuration;
}
}
IBaseHibernateDAO.java
package hibernateDao;
import org.hibernate.Session;
/**
* Data access interface for domain model
* @author MyEclipse Persistence Tools
*/
public interface IBaseHibernateDAO {
public Session getSession();
}
Sstest.java
package hibernateDao;
ublic class Sstest implements java.io.Serializable {
// Fields
private Integer id;
private String username;
private String password;
// Constructors
/** default constructor */
public Sstest() {
}
/** full constructor */
public Sstest(String username, String password) {
this.username = username;
this.password = password;
}
// Property accessors
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUsername() {
return this.username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return this.password;
}
public void setPassword(String password) {
this.password = password;
}
}
SstestDAO.java
package hibernateDao;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hibernate.LockMode;
import org.hibernate.Query;
import org.hibernate.criterion.Example;
public class SstestDAO extends BaseHibernateDAO {
private static final Log log = LogFactory.getLog(SstestDAO.class);
// property constants
public static final String USERNAME = "username";
public static final String PASSWORD = "password";
public void save(Sstest transientInstance) {
log.debug("saving Sstest instance");
try {
getSession().save(transientInstance);
log.debug("save successful");
} catch (RuntimeException re) {
log.error("save failed", re);
throw re;
}
}
public void delete(Sstest persistentInstance) {
log.debug("deleting Sstest instance");
try {
getSession().delete(persistentInstance);
log.debug("delete successful");
} catch (RuntimeException re) {
log.error("delete failed", re);
throw re;
}
}
public Sstest findById(java.lang.Integer id) {
log.debug("getting Sstest instance with id: " + id);
try {
Sstest instance = (Sstest) getSession().get("hibernateDao.Sstest",
id);
return instance;
} catch (RuntimeException re) {
log.error("get failed", re);
throw re;
}
}
public List findByExample(Sstest instance) {
log.debug("finding Sstest instance by example");
try {
List results = getSession().createCriteria("hibernateDao.Sstest")
.add(Example.create(instance)).list();
log.debug("find by example successful, result size: "
+ results.size());
return results;
} catch (RuntimeException re) {
log.error("find by example failed", re);
throw re;
}
}
public List findByProperty(String propertyName, Object value) {
log.debug("finding Sstest instance with property: " + propertyName
+ ", value: " + value);
try {
String queryString = "from Sstest as model where model."
+ propertyName + "= ?";
Query queryObject = getSession().createQuery(queryString);
queryObject.setParameter(0, value);
return queryObject.list();
} catch (RuntimeException re) {
log.error("find by property name failed", re);
throw re;
}
}
public List findByUsername(Object username) {
return findByProperty(USERNAME, username);
}
public List findByPassword(Object password) {
return findByProperty(PASSWORD, password);
}
public List findAll() {
log.debug("finding all Sstest instances");
try {
String queryString = "from Sstest";
Query queryObject = getSession().createQuery(queryString);
return queryObject.list();
} catch (RuntimeException re) {
log.error("find all failed", re);
throw re;
}
}
public Sstest merge(Sstest detachedInstance) {
log.debug("merging Sstest instance");
try {
Sstest result = (Sstest) getSession().merge(detachedInstance);
log.debug("merge successful");
return result;
} catch (RuntimeException re) {
log.error("merge failed", re);
throw re;
}
}
public void attachDirty(Sstest instance) {
log.debug("attaching dirty Sstest instance");
try {
getSession().saveOrUpdate(instance);
log.debug("attach successful");
} catch (RuntimeException re) {
log.error("attach failed", re);
throw re;
}
}
public void attachClean(Sstest instance) {
log.debug("attaching clean Sstest instance");
try {
getSession().lock(instance, LockMode.NONE);
log.debug("attach successful");
} catch (RuntimeException re) {
log.error("attach failed", re);
throw re;
}
}
}
Sstest.hbm.xml
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
<class name="hibernateDao.Sstest" table="sstest" schema="dbo" catalog="manager">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="increment" />
</id>
<property name="username" type="java.lang.String">
<column name="username" length="10" />
</property>
<property name="password" type="java.lang.String">
<column name="password" length="20" />
</property>
</class>
</hibernate-mapping>
struts-config.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.2//EN" "http://struts.apache.org/dtds/struts-config_1_2.dtd">
<struts-config>
<data-sources />
<form-beans >
<form-bean name="register1Form" type="com.yourcompany.struts.form.Register1Form" />
</form-beans>
<global-exceptions />
<global-forwards />
<action-mappings >
<action
attribute="register1Form"
input="/form/register1.jsp"
name="register1Form"
path="/register1"
scope="request"
type="com.yourcompany.struts.action.Register1Action">
<forward name="failed" path="/error.jsp" />
<forward name="success" path="/success.jsp" />
</action>
</action-mappings>
<message-resources parameter="com.yourcompany.struts.ApplicationResources" />
</struts-config>
type Status report
message /testSpringStruts2/
description The requested resource (/testSpringStruts2/) is not available.
package org.test.service.impl;
import org.test.service.LoginService;
public class LoginServiceImpl implements LoginService {
public boolean isLogin(String username, String password) {
//判断用户所以输入的数据是否为gao,qinQ如果是则登陆成?否则p|
// TODO Auto-generated method stub
if(username.equals("gao") && password.equals("qin")){
return true;
}
return false;
}
}
LoginAction.java
package org.test.struts2Action;
import org.test.service.LoginService;
import com.opensymphony.xwork2.ActionSupport;
@SuppressWarnings("serial")
public class LoginAction extends ActionSupport {
private String username;
private String password;
@SuppressWarnings("unused")
private LoginService loginService;
@Override
public String execute() throws Exception {
if(loginService.isLogin(username, password)){
return SUCCESS;
}
return INPUT;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public void setLoginService(LoginService loginService) {
this.loginService = loginService;
}
}
applicationContext.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">
<bean id="loginService" class="org.test.service.impl.LoginServiceImpl"></bean>
<bean id="loginAction" class="org.test.struts2Action.LoginAction" scope="prototype">
<property name="loginService">
<ref local="loginService"/>
</property>
</bean>
</beans>
struts.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<constant name="struts.objectFactory" value="spring"/>
<package name="qin" namespace="/" extends="struts-default">
<action name="login" class="loginAction">
<result name="success">/result.jsp</result>
<result name="input">/index.jsp</result>
</action>
</package>
</struts>
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<filter>
<filter-name>struts</filter-name>
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
</filter>
<filter-mapping>
<filter-name>struts</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<listener>
<listener-class>org.springframework.web.context.ContextLoader</listener-class>
</listener>
</web-app>
index.jsp
<%@ page language="java" pageEncoding="GB2312"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<html>
<head>
<title>My JSP 'index.jsp' starting page</title>
</head>
<body>
<h2>用户登陆</h2>
<s:form action="login.action" method="post">
<s:textfield name="username" label="用户?></s:textfield>
<s:password name="password" label="密码"></s:password>
<s:submit value="登陆" name="sure"></s:submit>
</s:form>
</body>
</html>
result.jsp
<%@ page language="java" pageEncoding="GB2312"%>
<%@ taglib uri="/struts-tags" prefix="s"%>
<html>
<head>
<title>My JSP 'index.jsp' starting page</title>
</head>
<body>
<h2>用户信息</h2>
用户名:<s:property value="username" escape="request"/>
密码Q?{requestScope.password }
</body>
</html>
该把修改web.xmlQ把原来?br />
<filter-mapping>
<filter-name>struts</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
改ؓ
<filter-mapping>
<filter-name>struts</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
而上传页面调用时直接用文件名调用Q如upload.jspQ。struts2只处?*.action 的请求?br />
或?br />
<filter>
<filter-name>struts2</filter-name>
<filter-class>
org.apache.struts2.dispatcher.FilterDispatcher
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
L也行
若是java.lang.NoClassDefFoundError: org/apache/commons/fileupload/FileUploadException错误
那就有可能是导包的问题,若用的是叛_目Q选择属性,然后导入相应的包Q就有可能出显此cȝ错误Q解x法是Q把commons-fileupload-1.2.1.jar,commons-io-1.4.jar复制到到WEB-INF下的lib目录中,虽然效果是一P但不会出错了
?
upload.jsp
<%@ page language="java" import="java.util.*" pageEncoding="GB2312"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP 'upload.jsp' starting page</title>
</head>
<body>
<form action="upload" method="post" enctype="multipart/form-data">
用户名:<input type="text" name="username"><br>
密码Q?lt;input type="password" name="password"><br>
文g1:<input type="file" name="file1"><br>
文g2:<input type="file" name="file2"><br>
<input type="submit" value="提交"><br>
</form>
</body>
</html>
UploadServlet.java
package com.test.servlet1;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;
public class UploadServlet extends HttpServlet {
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
DiskFileItemFactory factory = new DiskFileItemFactory();
String path = request.getRealPath("/upload");
// 讄传轮输文件的大小Q当于1024Ӟ把文件存在兹盘上
factory.setRepository(new File(path));
factory.setSizeThreshold(1024 * 1024);
ServletFileUpload upload = new ServletFileUpload(factory);
try {
List<FileItem> list = upload.parseRequest(request);
for(FileItem item : list){
if(item.isFormField()){
String name = item.getFieldName();
String value = item.getString("GB2312");
request.setAttribute(name, value);
}else{
String name = item.getFieldName();
String value = item.getName();
int start = value.lastIndexOf("\\");
String fileName = value.substring(start+1);
request.setAttribute(name, fileName);
//item.write(new File(path,fileName));
OutputStream os = new FileOutputStream(new File(path,fileName));
InputStream is = item.getInputStream();
// 文件is写到os?br />
byte[] buffer = new byte[400];
int lenght = 0 ;
while((lenght = is.read(buffer ))>0){
os.write(buffer,0,lenght);
}
os.close();
is.close();
}
}
} catch (FileUploadException e) {
// TODO Auto-generated catch block
System.out.println("文g上传出错"+e.getMessage());
e.printStackTrace();
}
request.getRequestDispatcher("upload/result.jsp").forward(request, response);
}
}
result.jsp
<%@ page language="java" import="java.util.*" pageEncoding="GB2312"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>My JSP 'result.jsp' starting page</title>
</head>
<body>
用户?${requestScope.username }
密码:${requestScope.password }
文g1:${requestScope.file1 }
文g2:${requestScope.file2 }
</body>
</html>
OSGi(ZJava的动态模型规?
注:OSGi(Open Service Gateway Initiative)指OSGi Alliancel织制定的一个基于Java语言的服?业务)规范——OSGi服务q_(Service Platform)?该规范和核心部分是一个框?Q其中定义了应用E序的生命周期模式和服务注册。这个框架实C一个优雅、完整和动态的lg模型。应用程?UCؓbundle)无需重新引导可以被远E安装、启动、升U和卸蝲(其中Java?cȝ理被详l定?。API中还定义了运行远E下载管理政{的生命周期理。服务注册允许bundlesL新服务和取消的服务Q然后相应配合?/p>
Java内容仓库Q最早于2002q?月由JCP发布
注:JCP(Java Community Process) 是一个开攄国际l织Q主要由Java开发者以及被授权者组成,职能是发展和更新Java技术规范、参考实?RI)、技术兼容包(TCK)。JCPl护的规范包括J2ME、J2SE、J2EEQXMLQOSSQJAIN{。组l成员可以提交JCR(Java SpECification RequESts)Q通过特定E序以后Q进入到下一版本的规范里面?/p>
Google Web Toolkit(最早发布于2006q??
注:GWT(Google Web Toolkit) ?Google 推出的一个开?Ajax 应用的框Ӟ它支持用 Java 开发和调试 Ajax 应用?/p>
Groovy(最早发布于2004q??
注:Groovy是一U面向对象的E序设计语言Q作为JavaE序设计语言的一U可选替代品Qƈ增加了PythonQRuby和Smalltalk中的一些特性?/p>
云雾计算(用于虚拟服务器的设计理念Q或无需EJB的分布式计算)
注:“云雾计算”的英文即Cloud Computing。自h发展h之后Q极大规模的服务器集中在一Pl一理QŞ成了“云雾计算”(“Cloud Computing”)的物质基?#8220;云雾计算”是社会计能力的大集中,也是所?#8220;SaaS”的客观基?/p>
有趣的是Q其中有几种技术已l成熟,或者说?#8220;?#8221;了,q且正在其被推荐应用的项目中有成熟的应用。当Ӟq五U技术都很有价倹{OSGi是Eclipse的徏模系l,Goovry因其正式的规范说明和频繁的改q版发布赢得支持。GWT也算是成熟稳定,云雾计算正在受到更ؓq泛市场的接受?/p>
JRC和云雾计是最q才被广泛接受的技术,但是厂商正在利用竞争和商业关pȝ取支持来发布相关的?比如GridGainQGigaspacesQ和Terracotta)Q而有的厂商还正在Ҏq行{划(TSS计划在TSSJS2008发布JCR相关的声??/p>
q是一份很有趣的列表。你认ؓ应该?008学习哪几UJava技术呢?哪些技术现在正在展露头角ƈ成ؓ你以后学习的方向?(http://developer.e800.com.cn/articles/2008/87/1218074549696_1.html)