1.result节点
<result name="" type=""></result>
name:action方法的返回值对应
type:常用的四种
>dispatcher:默认值,转发,同servlet中的转发
>redirect:重定向,同servlet中的重定向
>redirectAction:重定向到一个Action,可以用重定向的方式代替
>chain:转发到一个Action,不能用转发的方式代替
2.ModelDriven拦截器
//解析modelDriven拦截器,在params拦截器之前执行 public String intercept(ActionInvocation invocation) throws Exception { //获取Action类 Object action = invocation.getAction(); //如果Action类实现了ModelDriven接口 if (action instanceof ModelDriven) { //强转 ModelDriven modelDriven = (ModelDriven) action; //获取值栈 ValueStack stack = invocation.getStack(); //执行getModel方法,并得到返回值 Object model = modelDriven.getModel(); //若返回值不为null if (model != null) { //就把getModel方法返回对象放入值栈中。若为null则还是Action类对象在值栈栈顶 stack.push(model); } if (refreshModelBeforeResult) { invocation.addPreResultListener(new RefreshModelBeforeResult(modelDriven, model)); } } return invocation.invoke(); }
3.解析params拦截器
把请求参数的值赋给栈顶对象对应的属性
若栈顶对象没有对应的属性,则查询值栈中下一个对象对应的属性
4.如何在Action类中访问值栈
//不管有没有继承ActionSupport,都可以通过这种方式获得值栈,peek是获取栈顶对象的方法 ActionContext.getContext().getValueStack().peek();
5.struts2的运行流程
1.给服务器发送一个http请求
2.因为在web.xml中配置了拦截器,所以会拦截该请求
3.由ActionMapper对请求进行去扩展名,若去后为null,则不是struts请求,那么chain.doFilter放行;若不为null,则为struts请求,再执行下一步
4.创建ActionProxy对象,调用prepare方法通过ConfigurationManager来加载配置文件,确定拦截器栈,并创建Action类,确定执行的方法
5.此后ActionProxy对象再调用ActionInvocation的方法
6.ActionInvocation再起一次调用拦截器
7.每个拦截器又回调ActionInvocation的invoke方法,直到拦截器调完
8.ActionInvocation回去调用Action类的action方法,并得到返回的字符串
9.ActionInvocation通过返回的字符串调用result,并进行页面的渲染生成
10.再倒序执行拦截器的inv.invoke();后面的代码.
11.最后返回响应HttpServletResponse
6.
如何在页面上写下拉框 <s:select name="department" label="Department" list="#request.departmentList" listKey="id" listValue="name" headerValue="选择部门" headerKey=""> </s:select> <!-- 这里通过一个list类型的对象来动态生成一个下拉列表。 list="#request.departmentList"表示对象栈里有一个list<Department>类型的departmentList属性。 listKey="id"表示当前option的value从departmentList里的当前department对象的id属性取值。是要传回去的值 listValue="name"表示当前option的text从departmentList里的当前department对象的name属性取值。下拉框中显示的值 --> <s:select name="department.id" label="Department" list="#request.departmentList" listKey="id" listValue="name"> </s:select>
7.
怎么使用类型转换器 01.首先写好转换器类,需要extends StrutsTypeConverter,填写两个方法 /** * 返回值是转换好的类型的对象 * String[] arg1:从页面过来的字符串数组 * Class arg2:表示要把字符串转换成的类型 * */ @Override public Object convertFromString(Map arg0, String[] arg1, Class arg2) {} /** * 返回值是要在页面上显示的字符串 * */ @Override public String convertToString(Map arg0, Object arg1) {} 02.两种配置方法 >基于类型:可以为一个数据类型配置转换器 (在web应用初始化时创建,注意此时servletContext为null,创建两次,了解:因为注册器有两个,不是单实例) 在src下创建xwork-conversion.properties 内容:数据类型全类名=转换器全类名 >基于字段:可以为某个 Model(该 Model 类也可能是 Action,道理和下面的类型转换错误消息覆盖的第一种相同) 的各个属性分别配置一个自定义的转换器. (在需要转换时时创建,单实例) 创建一个属性文件: ModelClassName-conversion.properties, 该文件需和相对应的 Model 类放在同一个目录下 内容:属性名=转换器全类名
8.
<s:date/>的使用
<s:date name="birth" format="yyyy年MM月dd日"/>
9.
table节点内的属性的意义 <table cellpadding="10" cellspacing="0" border="1"> cellpadding:表内字距离表边框的距离是10 cellspacing:每个小框之间的距离,=0表示没有空隙 border:表边框的线宽度
10.
struts2本身会自动调栈顶对象的toString()方法所以有时候会出空指针异常
11.
类型转换错误消息的覆盖 两种方式都可以 >若一个model类对象作为栈顶元素被赋值,那么在对应的 Action类或model类所在的包中 新建 ActionClassName.properties 文件或ModelClassName.properties 文件即可 >若该输入字段仅存在于Action类中,那么在对应的 Action 类所在的包中新建 ActionClassName.properties 文件 文件内容都是invalid.fieldvalue.字段名=要显示的错误消息
1.请求路径 url:在地址栏上的全部。http://localhost:8080/springMVC-helloworld/nihao uri:url去掉站点以后的。/springMVC-helloworld/nihao contextPath:/应用名。/springMVC-helloworld servletPath:uri去掉contextPath。/nihao 2.<load-on-startup>1</load-on-startup> load-on-startup标记容器是否在启动的时候实例化并调用其init()方法的优先级。 当值为0或者大于0时,表示容器在应用启动时就加载并初始化这个servlet; 如果值小于0或未指定时,则表示只有在第一次请求的容器才为该servlet调用初始化函数 正值越小,servlet的优先级越高,应用启动时就越先加载。 值相同时,容器就会自己选择顺序来加载。 3.<url-pattern>/</url-pattern> http://www.cnblogs.com/canger/p/6084846.html