我已经使用拦截器对我的应用进行身份验证。我已将其添加到defaultStackHibernate
其工作正常&我得到了预期的结果,唯一的问题是现在我想在每个页面的标题上显示用户名。
我已经尝试过这个<s:property value="name"></s:property>
但是只能用于欢迎页面。所以有一种方法我可以从拦截器向我调用的每个动作或直接向jsp发送一些像username这样的变量吗?
如果我访问其他人操作,我会得到会话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>
答案 0 :(得分:3)
您可以在页眉页面中显示您包含的用户名,该页面包含在每页
中<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>
答案 1 :(得分:2)
用户进入会话后,您可以通过以下方式访问该名称:
#session.USER.name
仅使用name
时,只有当堆栈上的某些内容暴露name
属性时才有效。您希望(a)检查用户是否在会话中,或者(b)为未登录的用户使用不同的模板。