ActionForward

一、只有登录才能显示的页面

这是一个很平常的问题,在访问某些网页的时候,只有登录才可以访问,以此保证安全。

实现原理也很简单,就是将一个属性设置在session中。在访问的时候进行判断即可。

例:request.getSession().setAttribute("user", username);

这样就可以根据session进行判断了

1.MustLoginAction.java

package com;

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;

public class MustLoginAction extends Action {

@Override
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {

if(request.getSession().getAttribute("user") == null) {

return mapping.findForward("login");
}
return mapping.findForward("success");
}

}

  

在转向时,如果没有做重定向,浏览器地址栏显示的地址会是“.do”的形式,如果要避免这种情况发生,则需要在struts-config.xml中的forward配置里做重定向。

例:<forward name="login" path="/login.jsp" redirect="true"/>

 

 

二、动态ActionForward

如果需要做很多转向,那么会在struts-config.xml里配置很多的forward,这样就会比较麻烦。为了防止这种情况的发生,需要使用动态的ActionForward。

1.DynaActionForwardTestAction.java

 

package com;

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;

public class DynaActionForwardTestAction extends Action {

@Override
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {

ActionForward af = new ActionForward();
af.setPath("/page"+request.getParameter("page")+".jsp");
return af;
} 

如上所示,这个action在做转向的时候就使用了动态ActionForward

	 <global-forwards>
		 <forward name="login" path="/login.jsp" redirect="true"/>
	 </global-forwards>

redirect属性是指是否进行重定向。默认是false,即默认是转向而不重定向。转发的特点是共享request,并且地址栏不会改变,因为转发时在web容器内部进行的。重定向是不共享Session的,它的原理就是向客户端发送一个命令,通知客户端访问某个URL,因此不能共享request范围内的对象,并且浏览器地址栏里的地址也要发生变化。 

global-forwards可以有效地解决一些基本的Forward共享问题。

ActionForwards的一个比较常用的用途就是根据不同的用户权限来进行不同的页面跳转,如:

 

if (request.getSession().getAttribute("user") == null) {
			
			ActionForward af = mapping.findForward("login");
			
			//struts-config.xml文件不能修改
			//af.setRedirect(false);
			return af;
			
			//重定向
			//response.sendRedirect(request.getContextPath() + "/login.jsp");
			//return null;
		}
return mapping.findForward("success");

  

这段代码很有代表性,首先这个if{}()结构可以实现根据用户不同的权限来跳转到相应的页面,这也是比较常用的一种方法。

 

不能动态修改struts-config.xml文件。

 

struts-config.xml会在程序运行时一次性加载到内存中,它不是动态地装载的,所以不能动态修改。之所以这样是出于安全的原因。

 

在重定向时并不是非用ActionForward不可

因为在execute方法中有response,因此可以用response进行转向或重定向。用response重定向时,返回null即可

 

动态ActionForward

可以通过ActionForward的setPath();方法来动态设置ActionForward的转向路径,示例代码如下:

public class DynaActionForwardTestAction extends Action {
	@Override
	public ActionForward execute(ActionMapping mapping, ActionForm form,
			HttpServletRequest request, HttpServletResponse response)
			throws Exception {
		
		String page = request.getParameter("page");
//		ActionForward af = null;
//		if ("1".equals(page)) {
//			af = mapping.findForward("page1");
//		}else if ("2".equals(page)) {
//			af = mapping.findForward("page2");
//		}
//		return af;
		ActionForward af = new ActionForward();
		af.setPath("/page" + page + ".jsp?name=Tom");
		return af;
	}
}

  

注释掉的语句和动态ActionForward实现的功能一致,从这儿可以明显的看出动态ActionForward的灵活性和高效率。

使用这种方法可以不必在<action>理配置Forward属性。

Forward中的classname属性

在forward标签中使用这个属性,就是将自己定义的一个ActionForward类完整路径写入到这个属性里。这样可以用用户自己定义的ActionForward类来代替系统自动生成的ActionForward。

 

struts控制器中使用new ActionForward和mapping.findForward的区别

request.setAttribute("list", new Integer(0));
return new ActionForward("/success.jsp");

request.setAttribute("list", new Integer(0));
return mapping.findForward("fail");

当使用 return new ActionForward("/success.jsp");的时候相当于还是同一个request请求,所以可以携带参数setAttribute过去。
无论 <forward
                    name="succ"
                    path="/success.jsp"
                    redirect="true" />//无论此处的redirect是true还是false。

当使用 return mapping.findForward("fail");的时候如果 redirect="true",相当于还是另外一个request请求,所以不能携带参数setAttribute过去。
要想还是使用同一个request,获取到参数,则把
        <forward
                    name="succ"
                    path="/success.jsp"
                    redirect="false" />//此处的redirect改为false。另外,此处不设置的话默认redirect="false"。

无论在任何情况下使用
request.getSession().setAttribute("a", "sssss");都可以传递参数。
在页面处获取 <%=request.getSession().getAttribute

 

 

request.getSession(true):若存在会话则返回该会话,否则新建一个会话。

request.getSession(false):若存在会话则返回该会话,否则返回NULL

posted @ 2015-03-12 14:42  凡尘里的一根葱  阅读(286)  评论(0)    收藏  举报