我的动作类是在没有Struts.xml mappins或java注释的情况下映射的

时间:2016-04-25 18:02:00

标签: java jsp configuration struts2 struts2-convention-plugin

我有一个JSP登录页面,可以调用登录操作类。我使用Struts注释而不是映射的struts.xml,一切正常。我随机尝试了一些新内容,因此我从动作类中删除了所有注释,而我的struts.xml没有映射,但我的login.jsp能够调用我的动作类。如果没有使用Struts.xml配置或使用struts注释,我的动作类是如何被调用的?

的login.jsp

    <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<%@ taglib prefix="s" uri="/struts-tags"%>    
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Welcome to Popular Movies</title>

<style type="text/css">
.errors {
    background-color:#FFCCCC;
    border:1px solid #CC0000;
    width:400px;
    margin-bottom:8px;
}
.errors li{ 
    list-style: none; 
}
</style>

</head>
<body>

<h2>Please Log in</h2>
<div  id="errorMessage" >   
        <s:if test="hasActionErrors()">
           <div class="errors" >
               <s:actionerror/>
           </div>
        </s:if>
</div>      
   <s:form action="login" method="post" name="myForm" onSubmit="return preValidate(errorMessage, userName, userPassword)" >
      <s:textfield name="userName" label="Name" size="20" id="userName" />
      <s:password name="password" label="Password" size="20" id="userPassword" />
      <s:hidden name="registration" value="false" />
      <s:submit value="Submit" align="center" />
   </s:form>

   <hr>

   <a href="/PopularMovies/registration.jsp">Sign up free</a> 
</body>

<script type="text/javascript" src="validation.js">

</script>
</html>

Login.java

    package com.esi.actions;

import com.opensymphony.xwork2.ActionSupport;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

import com.sans.model.Movie;
import com.sans.model.Movies;
import com.sans.model.user_account;
import org.hibernate.HibernateException;
import org.hibernate.Query;

@SuppressWarnings("serial")
public class Login extends ActionSupport {
    private String password;
    private String userName;
    private String email;
    private String firstName;
    private String lastName;
    private String registration;
    private static SessionFactory sessionFactory; 

    @SuppressWarnings("deprecation")
    public String execute() {
        boolean isRegistration = Boolean.parseBoolean(registration);

        System.out.println("Action called from struts.xml");
        try {
            //Setting up Hibernate configuration
            System.out.println("Attempting Database connection...");
            sessionFactory = new Configuration().configure().buildSessionFactory();
        }
        catch(Exception ex){
            System.out.println("Failed to create sessionFactory object. " + ex.toString());     
            return INPUT;
        }

        // If Registration flag is set to true then it means user is trying to register
        // else authenticate user
        if(isRegistration) {
            if(this.addUser()) {
                return SUCCESS;
            }
            else {
                return INPUT;
            }
        }
        else {
            if(this.authenticateUser(this.getUserName())) {
                return SUCCESS;
            }
            else {
                return INPUT;
            } 
        }
    }

    public boolean addUser() {
        boolean result = false;
        user_account user = new user_account();
        user.setUser_Name(this.getUserName());
        user.setFirstName(this.getFirstName());
        user.setLastName(this.getLastName());
        user.setEmail(this.getEmail());
        user.setUser_Password(this.getPassword());

        Session session = sessionFactory.openSession();
        try{
            session.beginTransaction();
            session.save(user);     
            session.getTransaction().commit();
            result = true;
            addActionMessage("Welcome " + user.getUser_Name());
        }
        catch(HibernateException e){
            if(session.getTransaction() != null)
                session.getTransaction().rollback();        
            System.out.println("Error trying to insert user to database.. " + e.getMessage() + "\nStack Trace: ");
            e.printStackTrace();
        }

        finally {
            session.close();
        }
        return result;
    }

    public boolean authenticateUser(String userName) {
        boolean result = false;

        Session session = sessionFactory.openSession();
        try{
            session.beginTransaction();
            String hql = "FROM user_account U WHERE U.User_Name = :userName";
            Query query = session.createQuery(hql);
            query.setParameter("userName", userName);
            List results = query.list();

            //If the query result size is 0, then it means user does not exist in database
            if(results.size() != 0) {
                user_account user = (user_account)results.get(0);

                if(this.getUserName().equals(user.getUser_Name()) && this.getPassword().equals(user.getUser_Password())) {
                    addActionMessage("Welcome " + user.getUser_Name());
                    result = true;
                }
                else {
                    addActionError("Invalid User");
                    result = false;
                }
            }
            else {
                addActionError("Invalid User");
                result = false;
            }
            session.getTransaction().commit();  
        }
        catch(HibernateException e){
            if(session.getTransaction() != null)
                session.getTransaction().rollback();        
            System.out.println("Error trying to insert user to database.. " + e.toString());
        }
        catch(IndexOutOfBoundsException e) {

        }
        catch(Exception ex) {
            System.out.println("Something went wrong: " + ex.toString());
        }

        finally {
            session.close();
        }
        return result;
    }


    public String getPassword() {
        return password;
    }

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

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getFirstName() {
        return firstName;
    }

    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }

    public String getLastName() {
        return lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }
    public String getRegistration() {
        return registration;
    }

    public void setRegistration(String registration) {
        this.registration = registration;
    }



}

struts.xml中

    <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>

    <action name="login" class="com.esi.actions.Login">
        <result name="success">/success.jsp</result>
    </action> 

</struts>

Web.xml中

    <?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>PopularMovies</display-name>
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>


    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>

    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

</web-app>

根据我对struts框架的了解,只有在struts.xml中或使用注释映射动作类时才能调用它。

2 个答案:

答案 0 :(得分:2)

在Struts2中,注释由Convention Plugin提供。

名称说明了一切: 约会 over Configuration

这意味着可以配置它的每个方面,但如果您遵循某些约定,它也将默认工作;这样,您只需花时间配置那些与标准行为不同的情况。

Specifically

  

默认情况下,Convention插件会找到所有操作类   实现com.opensymphony.xwork2.Action 或其名称以。结尾   单词特定包中的动作。

     

这些包由Convention插件使用搜索定位   方法。首先,Convention插件找到名为struts的包,   struts2,动作或动作。任何与这些名称匹配的包都是   考虑了Convention插件的根包。接下来,   插件查看这些包中的所有类以及   子包并确定类是否实现   com.opensymphony.xwork2.Action或如果他们的名字以Action结尾(即   FooAction)。这是“公约”中几个类别的一个例子   插件会找到:

Classes 

com.example.actions.MainAction
com.example.actions.products.Display (implements com.opensymphony.xwork2.Action)
com.example.struts.company.details.ShowCompanyDetailsAction

您扩展了ActionSupport,它实现了Action接口......因此,即使未配置,也会找到login操作。

修改

我忘了提到有一个插件可以帮助你调试动作/拦截器/结果配置:Struts2 Config Browser Plugin。只需在WAR / EAR中包含JAR,然后调用

即可
  

http://YOUR_DOMAIN/YOUR_WEBAPP/config-browser/index.action

您将清楚地看到您的webapp中配置的每个操作(通过约定隐式或通过配置显式)。

请记住在部署生产之前删除此插件,否则攻击者将有更多机会击中您。

答案 1 :(得分:0)

我很长时间没有使用Struts,我想知道它是否使用类名来进行映射,请尝试使用其中一个选项来查看是否正确:

1-将action =“login”更改为action =“login2”
要么
2-将班级名称更改为Login2

看看它是否有效!!