关于在struts2中使用getJSON方式进行异步调用后,拦截器返回的问题:
项目中采用Struts2+Extjs(混杂的有Jquery)的架构进行开发,前后台之间的数据传递全部是采用JSON格式,如果前台的某一次action调用出现了session为空或者权限不够的情况时,这是需要进行页面跳转,如果是采用ajax的话,前台只是获取到跳转页面的html的代码,并不能实现真正的跳转,这时需要在前端页面中进行JS控制,才能进行页面跳转:
首先在struts.xml文件中定义好全局的视图和拦截器,如:
<interceptors>
<interceptor name ="privilege" class ="cn.util.AuthorizationInterceptor" />
<interceptor-stack name="myinterceptor">
<interceptor-ref name="privilege"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<global-results>
<result name="login">/login.html</result>
<result name="error">/common/error.html</result>
<result name="nopermit">/common/nopermit.html</result>
</global-results>
然后在拦截器中判断用户访问的类型:
/**
* 判断是否是ajax访问
* @param request
* @return
*/
private boolean isAjaxRequest(HttpServletRequest request) {
String header = request.getHeader("X-Requested-With");
if (header != null && "XMLHttpRequest".equals(header))
return true;
else
return false;
}
package cn.util;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts2.ServletActionContext;
public class AuthorizationInterceptor extends AbstractInterceptor {
private static final long serialVersionUID = 1L;
/**
* 如果是传统访问,直接返回视图给前端页面进行跳转
* 如果是ajax访问,系统将返回对应的错误状态码交由前端ajax的全局设置函数进行跳转
* 错误码403表示操作未授权,500表示后台java服务端出现内部错误,408表示请求超时,session清空,自动跳转到登陆页面。
* @WYQ
*/
@SuppressWarnings("unchecked")
@Override
public String intercept(ActionInvocation ai) throws Exception {
boolean flag = false,ajaxflag = false;
ActionContext ctx = ai.getInvocationContext();
String actionName = ctx.getName();
HttpServletRequest request = ServletActionContext.getRequest();
HttpServletResponse response = ServletActionContext.getResponse();
//判断是否是ajax访问
ajaxflag = this.isAjaxRequest(request);
Map map= ctx.getApplication();
Map mp = ctx.getSession();
//拦截session为空的操作
if(mp == null){
if(!ajaxflag){
return "login";
}else{
response.sendError(408);
return "login";
}
}
Integer type = (Integer) mp.get( "type" );
HashMap<String,String> m = (HashMap<String,String>) map.get("actionprivilege");
if(null!=m){
String exclude_rolestr = m.get(actionName);
if(null!=exclude_rolestr){
//拦截没有权限的操作
if(exclude_rolestr.indexOf(type+"")!=-1){
flag = true;
System.out.println("拦截器验证:"+actionName+".do,用户无功能的操作权限,已被系统拦截。。");
if(!ajaxflag){
return "nopermit";
}else{
response.sendError(403);
return "nopermit";
}
}
}
}
return ai.invoke();
}
前端页面的处理结果(这里是关键)、需要导入jquery的Js库文件:
$.ajaxSetup({"error":myfunc});
function myfunc(XMLHttpRequest, textStatus, errorThrown)
{
if(XMLHttpRequest.status==403){
window.location = "common/nopermit.html";
}else if(XMLHttpRequest.status==500){
window.location = "common/error.html";
}else ifif(XMLHttpRequest.status==408){
window.location = "login.html";
}
}
在这里设置ajax全局错误设置,jquery获取到后台传递的error信息后,自动会进行页面的跳转。这样就可以实现ajax下的页面跳转了。
分享到:
相关推荐
- **Action类与Result类型**:在Struts2中,Action类是业务逻辑的载体,Result类型负责决定请求处理后的跳转页面或资源。 - **Interceptor拦截器**:用于在Action调用前后执行特定逻辑,如登录验证、日志记录等。 ...
3. **JQuery/Ajax库**:使用JQuery库发送Ajax请求,例如`$.ajax()`或`$.getJSON()`方法,与Struts2的Action进行通信。 一个简单的Struts2 Ajax实例包括以下几个步骤: 1. **创建Action类**:编写一个处理Ajax请求...
在传统的Web应用中,当一个异常发生时,通常会跳转到错误页面或者返回错误信息。但在现代Web应用中,尤其是涉及到Ajax异步请求时,我们希望以JSON格式将异常信息发送回客户端,以便前端可以做出相应的处理。Struts2...
5. JSON格式:因为XML在现代Web开发中使用较少,所以你需要掌握JSON(JavaScript Object Notation),它是Ajax通信中常见的数据交换格式。 6. JavaScript库的使用:了解jQuery或其他库中的Ajax函数,简化Ajax请求的...
**AjaxExample.zip** 是一个基于 **Struts2** 框架实现的 **Ajax** 实例,主要用于展示如何在Web应用程序中使用Ajax技术与后台进行异步数据交互。这个实例包含了一个简单的测试表,用于演示如何动态更新页面部分内容...
4. **AJAX**:前端使用JavaScript和jQuery库,通过`$.ajax`或`$.getJSON`方法向服务器发送异步请求。当用户点击分页链接时,AJAX请求携带当前页码发送到服务器,然后在回调函数中更新DOM,展示新的分页内容。为了...
- 在SSH(Struts + Spring + Hibernate)架构中,Action层实例化接口并调用方法,DAO层进行数据库操作。 2. **接口安全性** - 确保敏感信息加密传输。 - 验证用户权限。 ### 五、同步与异步 1. **同步** - ...
在文档中,使用了artDialog.js来创建一个模态对话框,显示操作成功的信息,并在一定时间后自动刷新父页面。这说明在实际应用中,开发者可以根据需要使用各种JavaScript库来增强用户交互体验。 用户列表页面(user....
- 跳转至前端页面或返回JSON数据。 - **应用场景**: - 负责处理用户的HTTP请求,并调用业务层的方法。 - **前端页面设计(09_用户注册页面.mp4)**: - **知识点概述**: - HTML表单元素的使用; - CSS样式...