相关jar包分享:struts2+hibernate3+spring3 以及aop ,mysql,以及整合必须包。
链接:https://pan.baidu.com/s/1nCHmSsKU0hiV8DTj_V03sQ 密码:29nf
在学习spring和hibernate的基础后,试着将三大框架整合,下面以登陆为例,作为学习笔记供初学者参考。
总结一下思路:
第一步:从客户端获取用户输入数据,即用户名和密码,然后交给action处理。
第二步:action需要使用service接口提供的功能,如登陆,注册,修改信息等,并返回执行结果,然后给用户响应。
第三步:service层负责业务逻辑,通过dao接口来增删改查数据库中多个表的数据,从而完成一个功能,实际应用中不可能像登陆这么简单。
第四步:hibernate完成了实体类持久化,所有dao层负责对model层实体类的管理,即实现了对表数据的管理。
另外使用了事物管理器,使事物的管理更加规范,代码也更加简洁,这里不做介绍,可以参考其他文章。
web.xml配置代码:
注:其中这里applicationContext.xml放在src目录下,需用classpath指明。(系统默认的applicationContext.xml文件是在WEB-INF下)
<!-- 配置Spring的核心监听器 --> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </context-param> <!-- 配置structs2 --> <filter> <filter-name>Struts2</filter-name> <filter-class> org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter </filter-class> </filter> <filter-mapping> <filter-name>Struts2</filter-name> <url-pattern>*.do</url-pattern> </filter-mapping>
login.jsp代码:
<form method="post" onsubmit="return loginCheck()" id="loginForm"> <div> <input type="text" id="name"/> </div> <div> <input type="password" id="pass"/> </div> <button id="submit" type="submit">登 录</button> </form>
在这里并没有用action="login.do"的方式提交表单,而是使用ajax异步请求,读者若不理解可以使用传统的方式,下面做简单的介绍:
格式:$.ajax({type:'',data:'',async:''...})
参数:
cache: true缓存页面 false不缓存页面
type:get/post
data:发送到服务器的数据,必须为Object/String类型,对象必须为key/value格式
dataType:想要服务器返回数据的类型
success:(data,textStatus,jqXHR):请求成功后的回调函数。参数:由服务器返回,并根据dataType参数进行处理后的数据;描述状态的字符串。还有 jqXHR(在jQuery 1.4.x的中,XMLHttpRequest) 对象 。在jQuery 1.5, 成功设置可以接受一个函数数组。每个函数将被依次调用。
点击登陆按钮执行loginCheck()函数,代码如下:
//登陆按钮事件 function loginCheck(){ $.ajax({ url:"${pageContext.request.contextPath}/wp/login.do", data:{ username:function(){ return $("#name").val();//注:用id为name的值赋值给username(对应Action属性里的username) }, password:function(){ return $("#pass").val(); } }, dataType:"json", cache:false, type:"POST", success:function(data){ if(data =='ok'){ alert("登陆成功!"); } else{ alert("登陆失败!"); } }, }); return false; }
loginAction代码:
public class loginAction extends ActionSupport{ private String username; private String password; private UserService userService;//业务逻辑层的接口
private User user;
public String checkresult;//判断结果,以json的方式传给ajax
public UserService getUserService() { return userService; } public v