需求描述:
登录和注册方法在一个action中,action添加了validation,所以如果注册直接访问就会被拦截;
所以只能设置拦截器exclude该注册方法;又要用到使国际化起作用;
1. LoginAction类
package com.wenli.web;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;
public class LoginAction extends ActionSupport {
private String username;
private String password;
/**
* Log in Method
* @return
* @throws Exception
*/
public String login() throws Exception {
System.out.println("username: " + username);
if("wensummer".equals(username)
&& "pretty".equals(password))
{
ActionContext.getContext().getSession()
.put("user", username);
return SUCCESS;
}
return ERROR;
}
/**
* Register Method
* @return
*/
public String regist()
{
System.out.println("regist method");
return SUCCESS;
}
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 void validate()
{
if ((null == username) ||
"".equals(username))
{
addFieldError("username", getText("user.required"));
}
if ((null == password) ||
"".equals(password))
{
addFieldError("password", getText("pass.required"));
}
}
}
2.login.jsp
<%@page contentType="text/html;charset=UTF-8" language = "java" errorPage = ""%>
<%@taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title><s:text name="loginPage"/></title>
<meta name="website" content=">
</head>
<body>
<s:form name="loginForm" action="login" method="post" namespace="/login">
<table align="center">
<caption>
<h3>用户登录</h3>
</caption>
<tr>
<td><s:textfield name="username" key="user"/></td>
</tr>
<tr>
<td><s:textfield name="password" key="pass"/></td>
</tr>
<tr align="center">
<td colspan="2" ><s:submit key="login" name="method:login"></s:submit></td>
</tr>
</table>
</s:form>
<input type="button" οnclick="javascript:location.href='${pageContext.request.scheme}://${pageContext.request.serverName}:${pageContext.request.serverPort}${pageContext.request.contextPath}/login/regist.action'" value = '<s:property value='%{getText("regist")}'></s:property>'/>
//此处用了El表达式获得web项目请求路径,也用了s:peroperty标签实现国际化
</body>
</html>
注意:login.jsp的另一种写法。注册也用submit,修改action方法
<
%@page contentType="text/html;charset=UTF-8" language = "java" errorPage = ""%><%@taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title><s:text name="loginPage"/></title>
<meta name="website" content=">
<script type="text/javascript"">
var whoClick = "submit";
function defineOnSubmit()
{
if (whoClick == 'regist')
{
var form = document.getElementById('loginForm');
form.action = '${pageContext.request.contextPath}' + '\/login\/regist.action';
}
form.submit();
return false;
}
</script>
</head>
<body>
<s:form id="loginForm" action="login" method="post" namespace="/login" οnsubmit="return defineOnSubmit()">
<table align="center">
<caption>
<h3>用户登录</h3>
</caption>
<tr>
<td><s:textfield name="username" key="user"/></td>
</tr>
<tr>
<td><s:textfield name="password" key="pass"/></td>
</tr>
<tr align="center">
<td colspan="2" ><s:submit key="login" name="method:login" οnclick="javascript:whoClick = 'submit'"></s:submit></td>
<td colspan="2" ><s:submit key="regist" οnclick="javascript:whoClick = 'regist'"></s:submit></td>
</tr>
</table>
</s:form>
</body>
</html>
3.struts.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"
<struts>
<package name="filterInterceptor" extends="struts-default"
namespace="">
<interceptors>
<interceptor-stack name="disValidate">
<interceptor-ref name="validation">
<param name="excludeMethods">
regist //校验拦截器忽略regist方法
</param>
</interceptor-ref>
</interceptor-stack>
</interceptors>
</package>
<package name="strutdef" extends="filterInterceptor" namespace="/login">
<action name="login" class="com.wenli.web.LoginAction"
method="login">
<result name="input">/login.jsp</result>
<result name="error">/error.jsp</result>
<result name="success">/success.jsp</result>
</action>
<action name="regist" class="com.wenli.web.LoginAction"
method="regist">
<interceptor-ref name="disValidate"></interceptor-ref> //使用改良后的拦截器
<result name="input">/login.jsp</result>
<result name="success">/success.jsp</result>
</action>
<action name="getBook" class="com.wenli.web.GetBooksAction">
<result name="success">/showBook.jsp</result>
<result name="login">/login.jsp</result>
</action>
</package>
</struts>