表示层我们选用的是struts1.1,为什么选用它,而不选用spring MVC或者是struts2,没什么特别的原因,主是因为
我们熟,因为struts1.1里面的代码我们都有研究过.
直接用表示层肯定不能满足业务需求,现在任何一个系统,都可能会用大量的Ajax,所以我们进行了改写,改写重要参
考就是springside2.
1):我们把ActionForward抽象出来,进行封装,以便可以支持不同类型的数据格式,比如:jsp,json,Excel,pdf,velocity等
定义一个struts Forward接口
public interface IStrutsForward {
public abstract ActionForward findForward(ActionContext context);
}
定义一个抽象类,实现这个接口,主要的目的是把一些公共的抽出来.
public abstract class AbstractStrutsForward implements IStrutsForward {
final public static String CONTENTTYPE_TEXT = "text/plain;charset=UTF-8";
final public static String CONTENTTYPE_XML = "text/xml;charset=UTF-8";
final public static String CONTENTTYPE_HTML = "text/html;charset=UTF-8";
final public static String CONTENTTYPE_JSON = "text/x-json;charset=UTF-8";
final public static String CONTENTTYPE_PDF = "application/pdf";
final public static String CONTENTTYPE_EXCEL = "application/vnd.ms-excel";
final public static String CONTENTTYPE_download = "application/x-download";
protected Object forward = null;
……
}
不同的类型继承抽象类,实现接口,比如:
public class JspForward extends AbstractStrutsForward{
public JspForward (Object forward){
super(forward);
}
/**
* 导向struts Forward
* @param context
* @return
* @see com.esk2.framework.web.action.IStrutsForward#findForward(com.esk2.framework.web.action.ActionContext)
*/
public ActionForward findForward(ActionContext context){
if(forward instanceof String){
return context.getMapping().findForward((String)forward);
}else{
SystemLogger.error("Forward类型应该为String,而不是:"+forward.toString());
return context.getMapping().findForward(SysFinal.STRUTS_SYSTEM_ERROR);
}
}
}
2):因为Action是直接将页面传过来的method参数,dispatch到Manager里面调用,所以表示层,我们借鉴了struts自带的DispatchAction的原理,再结合spring,就很好的实现了这一功能。
@Override
public IStrutsForward dispatch(ActionContext context) {
//从spring取到Manager
Object service = this.createService(context);
if (service instanceof IStrutsForward) {
IStrutsForward forward = (IStrutsForward) service;
return forward;
}
//获取Method方法
String methodStr = context.getForm().getMethod();
Object methodObj = this.createMethod(service, methodStr);
if (methodObj instanceof IStrutsForward) {
IStrutsForward forward = (IStrutsForward) methodObj;
return forward;
}
try {
Object args[] = { context };
Method method = (Method) methodObj;
long begin=System.currentTimeMillis();
//调用Manager里面的Method方法
IStrutsForward forward = (IStrutsForward) method
.invoke(service, args);
long end=System.currentTimeMillis();
StringBuffer msg=new StringBuffer();
msg.append("[");
msg.append(context.getRequest().getRemoteAddr());
msg.append("]");
msg.append(ClassUtils.getShortName(service.getClass()));
msg.append(".");
msg.append(methodStr);
msg.append("(context):");
msg.append(end-begin);
SystemLogger.debug(msg.toString());
return forward;
} catch (Exception e) {
SystemLogger.error("调用Serivce 方法出错", e);
IStrutsForward forward = new JspForward(
SysFinal.STRUTS_SYSTEM_ERROR);
return forward;
}
}
结束语,整个技术架构记录就告一段路了,不同的人由于经历不同,知识面不同,做出的架构也可能不同,只要你懂基础,懂原理,一定是大同小异。多去钻研一些牛人的源代码,你一定会受益匪浅.