1、第1步、导入页面 将页面资料复制到项目的“WebRoot”文件夹下。注:确保每个页面的字符符合JSP的编码方式(GBK或UTF-8) 第2步、导入数据库驱动 将“mysql-connector-java-5[1].1.12-bin.jar”复制到项目的“WebRoot\WEB-INF\lib”文件夹下,刷新项目后出现。 第3步、添加Struts框架 1、添加Struts:在项目名字上点右键选择如下图 2、在“Base package for new classes”里填上“web”,点击Finish。 3、在web.xml文件里: <1>删除下面
2、的配置
3、ame>
4、ram>
5、ter.java的文件,文件代码如下: package filter; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; public class
6、CharFilter implements Filter { private String charSet=null; public void destroy() {} public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { request.setCharacterEncoding(charSet); response.setCharacterEncoding(charS
7、et);
chain.doFilter(request, response);//向后传递控制权
}
public void init(FilterConfig config) throws ServletException {
charSet=config.getInitParameter("charSet");
}
}
5、建立entity包,并根据Hibernate框架来生成实体类(User)[详细请参考第五步、添加Hibernate的框架]
第四步、在Struts框架下完成一个登录操作
1、在页面上:
12、form-bean标签里的type的值固定成:
org.apache.struts.action.DynaActionForm
注2:form-property标签里的name的值为属性值,在页面上提交表单里的name应写为:属性值.实体的字段值。例如user.user_name。
13、
14、ion标签里的type的值与web包里所写的DispatchAction的名字保持一致。 注4:action标签里的parameter的值与form表单提交时.do?后面的单词保持一致。 注5:exception标签里的key的值与web包里的ApplicationResources.properties文件里面的一致。 注6:exception标签里的type的值与biz包下面的exception包里的LoginException.java文件名一致。 注7:excetion标签里的path的值是报错后转向的路径,必须有“/”这个符号。 注8:forward标签里的name的值是与
15、web包里的DispatchAction文件里所调用的方法doLogin里面的return mapping.findForward("success"); 里的success这个单词保持一致。 注9:forward标签里的path的值是正确执行后转向的路径,必须有“/”这个符号。 3、DispatchAction.java文件(这里文件名为:EpaiDispatchAction.java)里: package web; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServl
16、etResponse; import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; import org.apache.struts.action.DynaActionForm; import org.apache.struts.actions.DispatchAction; import biz.UserLoginBiz; import entity.User;
17、 public class EpaiDispatchAction extends DispatchAction { private Biz biz; // 用户登录控制器方案 public ActionForward doLogin(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { DynaActionForm df = (DynaActionForm) form; Us
18、er user = (User) df.get("user"); User userInfo = biz.doLogin(user); request.getSession().setAttribute("UserLoginInfo", userInfo); return mapping.findForward("success"); } } 注:df.get(“user”)里面的user和form-property标签里的name的值为属性值,要一致。 4、在biz包里建一个Biz.java,其内容如下: package biz; import jav
19、a.util.List; import biz.exception.LoginException; import dao.BaseDao; import entity.User; public class Biz { private BaseDao dao; public User doLogin(User user) throws Exception { List list=(List)dao.findByParams("from User u where u.user_name=? and u.user_password=?", user.getUser_name()
20、user.getUser_password()); if(list.isEmpty()) throw new LoginException(); return (User) list.get(0); } } 5、在biz.exception包里建一个LoginException.java,其内容如下: package biz.exception; public class LoginException extends Exception {} 6、在web包里的ApplicationResources.properties文件里写上: 第五步、添加
21、Hibernate框架
1、加入Hibernate
2、只选择Hibernate3.2 Core Libraries -
22、mplate为要用的数据库类型;Driver name为在MyEclipse里的名称;
23、alder为项目里的src的路径;Java package为实体对象的包名;点击Finish 15、提示是否进入JAVA视图,点击Yes 16、打开hibernate.cfg.xml,DB确Driver里选择新建的DB Driver: 17、点击Properties里的Add..按钮 18、Property选择:format_sql,Value值为:true 19、Property选择:show_sql,Value值为:true 注:Hibernate框架成功建立应该有以下三方面: a.构建路径上有hibernate的jar. b.在src下有hibe
24、rnate.cfg.xml文件. c.在entity下有实体类,并且在同一目录下有"实体类名.hbm.xml". 20、双击所建实体(User.java和User.hbm.xml)修改对应表的字段的属性,使其保持一致,也可以删除“Customers.hbm.xml”后自己新建xml文件,21到25点的步骤为新建和编写xml文件 21、指向点击右键 选择后,在File name里填写“实体类名.hbm.xml” 22、点击Next>后,选择Create XML file from a DTD file,点击Next> 23、选择Select XML Catal
25、og entry,并找到Hibarnate Mapping DTD 3.0/EN,后击Next> 24、点击Finish 25、在dao包里建立BaseDao文件来链接数据库,文件代码如下: package dao; import java.util.List; import org.hibernate.Query; import org.hibernate.Session; import org.hibernate.Transaction; public class BaseDao { //增加 public void save(Object o){
26、 Session s=HibernateSessionFactory.getSession(); Transaction tx=s.beginTransaction(); s.save(o); mit(); HibernateSessionFactory.closeSession(); } //删除 public void delete(Object o){ Session s=HibernateSessionFactory.getSession(); Transaction tx=s.beginTransaction(
27、); s.delete(o); mit(); HibernateSessionFactory.closeSession(); } //修改 public void update(Object o){ Session s=HibernateSessionFactory.getSession(); Transaction tx=s.beginTransaction(); s.update(o); mit(); HibernateSessionFactory.closeSession(); } //
28、通过ID查找 public Object findById(Class clazz,Long id){ Session s=HibernateSessionFactory.getSession(); Transaction tx=s.beginTransaction(); Object o=s.get(clazz, id); mit(); HibernateSessionFactory.closeSession(); return o; } //通用查找 public List findByParams(String h
29、ql,Object...params){ Session s=HibernateSessionFactory.getSession(); Transaction tx=s.beginTransaction(); Query q=s.createQuery(hql); if(params!=null){ int i=0; for(Object p:params){ q.setParameter(i, p); i++; } } List list=q.list(); mit();
30、HibernateSessionFactory.closeSession(); return list; } //通用查找一条记录 public Object findByParams2(String hql, Object... params){ List list=this.findByParams(hql, params); if(!list.isEmpty()){ return list.get(0); } return null; } //分页查找 public List findByParams
31、WithPage(int page,int pageSize,String hql,Object...params){ Session s=HibernateSessionFactory.getSession(); Transaction tx=s.beginTransaction(); Query q=s.createQuery(hql); if(params!=null){ int i=0; for(Object p:params){ q.setParameter(i, p); i++; } }
32、 List list=q.setFirstResult((page-1)*pageSize).setMaxResults(pageSize).list(); mit(); HibernateSessionFactory.closeSession(); return list; } } 注:操作数据的原则 1.hibernate有自己的管理对象的阶段(生命周期)。 2.对于new创建的数据只做save 3.先查询才能做改或删. 4.做查询时要先close再return。 5.不要对主键属性赋值. 面试:临时态和游离态对象有可能被垃圾回收,而持
33、久态永不会回收.
26、打开Bid.hbm.xml编写配置文件如下:
35、ame="bidPrice" type="java.lang.Float">
36、
a.类表映射
37、va.lang.String bigint java.lang.Long java.lang.Long int java.lang.Integer java.lang.Integer bit java.lang.Boolean java.lang.Boolean blob java.lang.byte[] binary date java.sql.Date java.sql.Date timestamp java.sql.Timestamp java.sql.Timestamp char(1) java.lang.Characte
38、r java.lang.Character 第六步 添加Spring容器 1、加入Spring 2、选择Spring1.2,勾上“AOP Libraries”“Core Libraries”“Persistence Core Libraries”和“web Libraries”,并选择“Copychecked Library contents to project folder”,点击Next: 3、点击Next: 4、点击Finish: 第七步 Struts与Spring整合 1、在web包里的EpaiDispatchAc
39、tion.java里将biz加上set方法:
private Biz biz;
public void setBiz(Biz biz) {
this.biz = biz;
}
2、在biz包里的Biz.java里将dao加上set方法:
private BaseDao dao;
public void setDao(BaseDao dao) {
this.dao = dao;
}
3、中修改struts的配置文件struts-config.xml,将:
40、
name="loginForm"
type="web.EpaiDispatchAction" parameter="operate"
scope="request">
41、ngs>
里面的type的值修改为:
org.springframework.web.struts.DelegatingActionProxy
4、在struts-config.xml文件的最后加入:
42、Context.xml里配置:
44、 45、op的应用(用来在不修改源码的情况下增加新功能,建立SSH时,可以跳过)
aop的相关名词()
advice:表示一个增强的功能.
pointCut:表示一次或多次方法调用.
advisor=advice+pointcut
interceptor=advice或advisor
1、创建一个Advice对象,覆写方法完成增加的功能。
package biz;
import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
publ 46、ic class JiaJiFenAdvice implements MethodInterceptor {
@Override//覆写方法完成增加的功能
public Object invoke(MethodInvocation invocation) throws Throwable {
Object res=null;
try {
//这里添加:在原有功能前加功能
res=invocation.proceed();
//这里添加:在原有功能后加功能
} catch (Exception e) {
}
return res;
47、 }
}
2、在“applicationContext.xml”文件里配置:
48、/bean>
49、aryBiz