第一种方式:className
用注解配置action 是:@Action(value="/action"),但将注解和spring联系起来,我们看文档知道,只需要@Action(value="/action" className="spring中的ID"),这样,当放问这个action时,struts2就向spring要action,spring则会通过这个className来匹配id,然后返回匹配的action类的实例。
- import org.apache.struts2.convention.annotation.Action;
- import org.xuliang.services.MyUserService;
- import org.xuliang.vos.LoginVo;
- public class MyLoginAction {
- private LoginVo lv = new LoginVo();
- private MyUserService mus;
- @Action(value="/mylogin")
- public String login(){
- System.out.println(this.hashCode());//这里输出这个类的实例的hashCode码
- System.out.println(lv.getUpwd()+"====="+lv.getUname());
- mus.findUserByUnameUpwd(lv.getUname(), lv.getUpwd());
- return null;
- }
- public MyUserService getMus() {
- return mus;
- }
- public void setMus(MyUserService mus) {
- this.mus = mus;
- }
- public LoginVo getLv() {
- return lv;
- }
- public void setLv(LoginVo lv) {
- this.lv = lv;
- }
- }
注:当上面的this.hashCode()可以看出这个类的实例是由Spring生产的还是Struts2生产的,当你配置的ClassName在Beans.xml中找不到指定的id时或不配置className(其中也除了在beans.xml中有bean的Id配置这个类的全名),就由Struts2产生,否则是Spring产生
Spring对应的ID的Bean产生的
当Spring中的Beans.xml中配置Scopt="Single" 如果输出的hashCode是一样的则是Spring产生的,反之是Struts2产生的
另外一种方式:不用配className,直降在spring里面配置这个类的全名org.hzy.actions.MyLoginAction则可以,
注解中,是不需要为action指定class这个属性的,其实并不代表这个属性不存在,这个属性的值就是@Action所在的类名,当访问没有设置className属性的action时,struts2找spring要Action,spring就通过这个action类的全名来匹配id的bean,所以,所以我们将这个bean的id设置为action的类名时,spring就能匹配到,这样的配置方式使得spring和struts2解藕度就很好.