您的位置:首页 > 编程语言 > Java开发

struts.xml属性配置,action属性,通配符,action接受参数(二)

2013-11-17 14:38 555 查看
尊重原创,文章出处:http://blog.csdn.net/chunlei_zhang/article/details/16369439

一、如果我们在Struts.xml中配置了studentadd和studentdelete等多个前面都是student后面是动作的action,并且各自调用动作名的方法,我们就可以使用通配符来配置action,如Struts.xml的配置如下:

<package name="default" extends="struts-default" namespace="/">
<action name="studentadd" class="com.thridProject.action.StudentAddAction" method ="add">
<result type="dispatcher" name="success">/studentadd.jsp</result>
</action>
<action name ="studentdelete" class="com.thridProject.action.StudentDeleteAction" method="delete">
<result name="success">/studentdelete.jsp</result>
</action>
</package>


等价于:

<package name="default" extends="struts-default" namespace="/">
<action name="student*" class="com.thridProject.action.StudentAction" method ="{1}">
<result type="dispatcher" name="success">/student{1}.jsp</result>
</action>
</package>
其中StudentAction类中含有add和delete方法。后面的{1}代表前面第几个*号,同样的action也可以使用
class="com.thridProject.action.Student{1}Action"


二、在action中接受参数有三种方式

1)第一种方式:如:url:http://localhost:8080/ThridProject/hello?username=zhang&password=123

或者使用form表单进行提交:

这个时候的Struts.xml的配置为:

<package name="default" extends="struts-default" namespace="/">
<action name="hello" class="com.thridProject.action.HelloAction" method="add">
<result type="dispatcher" name="success">/hello.jsp</result>
</action>
</package>


HelloAction的类的第一种实现代码如下:

package com.thridProject.action;

import com.opensymphony.xwork2.ActionSupport;

public class HelloAction extends ActionSupport {

/**
* author 张春蕾 2013-11-17
*/
private static final long serialVersionUID = 1L;

private String username;
private String password;

public String getUsername() {
return username;
}

public void setUsername(String username) {
this.username = username;
}

public String getPassword() {
return password;
}

public void setPassword(String password) {
this.password = password;
}

public String add(){
System.out.println("username = "+username);
System.out.println("password = "+password);
return "success";
}
}
输出结果为:

username = zhang
password = 123
2)第二种方式使用ThemainModel的形式,因为提交的参数肯定会封装成一个对象,然后对数据库进行访问。
url:http://localhost:8080/ThridProject/hello?user.username=zhang&user.password=123(注意变化的地方)

这种方法,model可以自己new出来,也可以通过传参来被struts自己实现,但是如果是通过传参,必须保证model有空的构造方法,否则会传参失败。(注意点)

这个时候struts.xml的配置不变,而java的后台实现需要加入model层,从action层方位model层的代码:

HelloAction的实现源码:

package com.thridProject.action;

import com.opensymphony.xwork2.ActionSupport;
import com.thridProject.model.User;

public class HelloAction extends ActionSupport {

/**
* author 张春蕾 2013-11-17
*/
private static final long serialVersionUID = 1L;

private User user;

public User getUser() {
return user;
}

public void setUser(User user) {
this.user = user;
}

public String add(){
System.out.println("username = "+user.getUsername());
System.out.println("password = "+user.getPassword());
return "success";
}
}
model层的实现源码:

package com.thridProject.model;
/**
* author 张春蕾 2013年11-17
*/
public class User {

private String username;
private String password;

public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}

}

3)第三种方式是使用modelDriven的形式。通过继承ModelDriven的接口实现ModelDriven的getModel方法。而且不用使用set和get方法,可以自己进行new出来。

一般最常用的是使用第二种,使用DTO的形式。

三、include来包含其他的xml配置,可以实现多个人开发,开发完成后将struts.xml的配置包含进来即可。

<include file="XX.xml"/>

四、default-action-ref的配置

<package name="default" extends="struts-default" namespace="/">
<default-action-ref name="hello"></default-action-ref>
<action name="hello" class="com.thridProject.action.HelloAction">
<result name="success">/hello.jsp</result>
</action>
</package>


这是默认action引用,如果别人访问这个namespace的时候,如果找不到action,则会使用默认的action。

但是default-action-ref存在bug,不会执行后面的class,这个时候我们可以使用web.xml的配置完成这个bug
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息