我在我的应用程序中使用了拦截器进行身份验证。我已将其添加到
defaultStackHibernate
中。它工作正常,我得到了想要的结果,唯一的问题是现在,我想在每个页面的标题上显示用户名。
我已经尝试过这个
<s:property value="name"></s:property>
,但仅适用于欢迎页面。那么,有没有一种方法可以将一些像 username
这样的变量从拦截器发送到我正在调用的每个操作或直接发送到 JSP?
如果我访问其他操作,我会获得会话
null
。
以下是我在标题页JSP中的部分代码:
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">
<b><s:property value="name"></s:property></b> <b class="caret"></b></a>
<ul class="dropdown-menu">
<li><a href="user_profile.html">My Profile</a></li>
<li class="divider"></li>
<li><a href="logOut">Log Out</a></li>
</ul>
</li>
以下是我的
LoginAction
班级:
public class LoginAction extends ActionSupport implements SessionAware, ModelDriven<User>{
private static final long serialVersionUID = -3369875299120377549L;
private User user = new User();
private SessionMap<String, Object> sessionAttributes = null;
private List<User> userList = new ArrayList<User>();
private UserDAO userDAO = new UserDAOImpl();
@Override
public String execute(){
System.out.println("inside execute");
if(user.getName().equals(user.getName()) && user.getName().equals(user.getPassword())){
System.out.println("Name"+user.getName() +" password"+user.getPassword());
sessionAttributes.put("USER", user);
return SUCCESS;
}
return INPUT;
}
@Override
public void setSession(Map<String, Object> sessionAttributes) {
this.sessionAttributes = (SessionMap<String, Object>)sessionAttributes;
}
@Override
public User getModel() {
return user;
}
public String logout(){
if(sessionAttributes!=null){
sessionAttributes.clear();
sessionAttributes.invalidate();
}
return "success";
}
}
AuthenticationInterceptor
班级:
public class AuthenticationInterceptor implements Interceptor {
private static final long serialVersionUID = -5011962009065225959L;
@Override
public void destroy() {
//release resources here
}
@Override
public void init() {
// create resources here
}
@Override
public String intercept(ActionInvocation actionInvocation)
throws Exception {
System.out.println("inside auth interceptor");
Map<String, Object> sessionAttributes = actionInvocation.getInvocationContext().getSession();
User user = (User) sessionAttributes.get("USER");
if(user == null){
return Action.LOGIN;
}else{
Action action = (Action) actionInvocation.getAction();
if(action instanceof UserAware){
((UserAware) action).setUser(user);
}
return actionInvocation.invoke();
}
}
struts.xml
:
<struts>
<constant name="struts.enable.DynamicMethodInvocation" value="false" />
<constant name="struts.devMode" value="false" />
<package name="default" extends="hibernate-default">
<interceptors>
<interceptor name="authentication"
class="com.inwi.interceptors.AuthenticationInterceptor"></interceptor>
<interceptor-stack name="authStack">
<interceptor-ref name="authentication"></interceptor-ref>
<interceptor-ref name="defaultStackHibernate"></interceptor-ref>
</interceptor-stack>
</interceptors>
<default-interceptor-ref name="authStack"></default-interceptor-ref>
<global-results>
<result name="loginAction" type="redirect">/home.action</result>
</global-results>
<action name="home">
<interceptor-ref name="defaultStack"></interceptor-ref>
<result>/login.jsp</result>
</action>
<action name="loginAction" class="com.inwi.action.LoginAction">
<interceptor-ref name="defaultStack"></interceptor-ref>
<result name="success">/dashboard.jsp</result>
<result name="input">/loginError.jsp</result>
</action>
<action name="welcome" class="com.inwi.action.WelcomeAction">
<result name="success">/dashboard.jsp</result>
</action>
<action name="saveOrUpdateTypeSites" method="saveOrUpdate" class="com.inwi.action.TypeSitesAction">
<result name="success" type="redirect">listTypeSites</result>
</action>
<action name="listTypeSites" method="list" class="com.inwi.action.TypeSitesAction">
<result name="success">/typeSiteMain.jsp</result>
</action>
您可以显示包含在标题页中的用户名,该标题页包含在每个页面上
<s:if test="#session.USER != null">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">
<b><s:property value="#session.USER.name"/></b><b class="caret"></b></a>
</s:if>
用户进入会话后,您可以通过以下方式访问该名称:
#session.USER.name
仅使用
name
仅当堆栈上有某些内容暴露 name
属性时才有效。您需要 (a) 检查用户是否处于会话中,或者 (b) 对未登录的用户使用不同的模板。