- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 struts 2 MVC 框架开发一个 Web 应用程序。我目前正在研究它的登录模块。我对这些技术很陌生。我在维持 session 方面遇到问题。我希望如果有人直接点击个人资料页面(成功登录后打开的页面)的 url,那么他或她会被重定向回登录页面。此外,如果有人使用错误的凭据登录,那么他会再次被重定向回登录页面。此外,如果他输入一些登录详细信息,则必须首先检查凭据,如果凭据正确,则必须设置 session 变量。在呈现个人资料页面之前,将检查 session 变量是否已设置。如果仅设置了 session 变量,则控制权将传递到配置文件页面。
下面是我的登录表单代码loginPage.jsp:此页面向用户显示登录页面:
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%@ taglib prefix="s" uri="/struts-tags" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>LOGIN PAGE</title>
</head>
<body>
<s:form action="login" method="post">
<s:textfield name="login.username" label="Username"/>
<s:password name="login.password" label="Password"/>
<s:submit value="SUBMIT" align="center"/>
<s:reset value="RESET" align="center"/>
</s:form>
</body>
</html>
现在是我的loginAction类:这是我的操作类,对应于在登录表单上单击登录按钮时生成的登录操作。
package com.view;
import java.util.Map;
import org.apache.struts2.interceptor.SessionAware;
import com.controller.LoginManager;
import com.model.Login;
import com.model.UserDetails;
public class LoginAction implements SessionAware{
private Login login;
private LoginManager loginManager;
private UserDetails userDetails;
Map<String,Object> map;
public LoginAction()
{
loginManager=new LoginManager();
}
public String loginLink()
{
return "loginClicked";
}
public String checkLogin()
{
try
{
//String loggedInUsername=null;
System.out.println("---------"+login.getUsername());
/*if(map.containsKey("username"))
{
loggedInUsername=(String)map.get("username");
}*/
userDetails=loginManager.check(login);
/*if(loggedInUsername!=null && loggedInUsername==userDetails.getUsername())
{
return "loginSuccess";
}*/
if(userDetails!=null && userDetails.getUsername()!=null)
{
map.put("login",true);
map.put("username",userDetails.getUsername());
map.put("name",userDetails.getName());
map.put("sex",userDetails.getSex());
map.put("email",userDetails.getEmail());
map.put("phoneno",userDetails.getPhone_no());
System.out.println("Inside session map creation that is Successful login");
return "loginSuccess";
}
else
{
System.out.println("Inside check login with invalid credentials");
return "loginClicked";
}
}catch(Exception ex)
{
System.out.println("Inside exception of checkLogin.");
return "loginClicked";
}
}
public void setLogin(Login login)
{
this.login=login;
}
public Login getLogin()
{
return login;
}
@Override
public void setSession(Map<String, Object> map) {
this.map=map;
}
}
loginManager类:该类处理数据库部分。在此类中检查登录凭据。
package com.controller;
import org.hibernate.Query;
import org.hibernate.classic.Session;
//import java.util.List;
import com.model.Login;
import com.model.UserDetails;
import com.util.HibernateUtil;
public class LoginManager extends HibernateUtil{
UserDetails userDetails;
public UserDetails check(Login login)
{
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
session.beginTransaction();
try
{
System.out.println("Inside try block to retrieve from db");
String hql="FROM UserDetails where username='"+login.getUsername()+"' and password='"+login.getPassword()+"' and role='U'";
Query query = session.createQuery(hql);
System.out.println("Query Created");
userDetails=(UserDetails)query.uniqueResult();
//System.out.println("Returned Username"+userDetails.getUsername());
//System.out.println("Returned Password"+userDetails.getPassword());
session.getTransaction().commit();
}catch(Exception ex){
System.out.println("Exception generated is "+ex.getMessage());
session.getTransaction().rollback();
userDetails=null;
ex.printStackTrace();
}
return userDetails;
}
}
下面是我的 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>
<constant name="struts.devMode" value="true" />
<package name="package2" extends="struts-default">
<interceptors>
<interceptor name="myinterceptor" class="interceptors.LoginInterceptor" />
<interceptor-stack name="myinterceptorSt">
<interceptor-ref name="myinterceptor" />
<interceptor-ref name="defaultStack" />
</interceptor-stack>
</interceptors>
<action name="registerLink" class="com.view.RegisterAction" method="registerLink">
<result name="registerLinkClicked">/registerPage1.jsp</result>
</action>
<action name="register" class="com.view.RegisterAction" method="addUser">
<result name="registered">/registrationSuccess.jsp</result>
</action>
<action name="login" class="com.view.LoginAction" method="checkLogin">
<interceptor-ref name="myinterceptorSt" />
<result name="loginSuccess" type="redirect">/profile.jsp</result>
<result name="loginFail">/loginFail.jsp</result>
<result name="loginClicked">/loginPage.jsp</result>
</action>
<action name="sessionCheck" class="com.view.SessionCheckAction">
<result name="sessionCheckSuccess"></result>
</action>
<action name="loginLink" class="com.view.LoginAction" method="loginLink">
<result name="loginClicked">/loginPage.jsp</result>
</action>
</package>
</struts>
任何人都可以帮助我编写拦截器代码,以实现我上面指定的功能。
最佳答案
我阅读了评论,正如 Dave Newton 提到的,这是拦截器代码:
public class LoginInterceptor extends AbstractInterceptor {
@Override
public String intercept(final ActionInvocation invocation) throws Exception {
Map<String, Object> session = ActionContext.getContext().getSession();
String username = (String) session.get("username");//getting username from session
// If the user is already logged-in, then let the request through.
if (username != null) {
return invocation.invoke();
}
Object action = invocation.getAction(); // get which action class is called
// for the first action LoginAction interceptor will allow request to be forwarded.
if (action instanceof LoginAction) {
return invocation.invoke();
}
else {
return "notAuthorized";
}
}
}
现在,在 struts.xml
中添加代码下面<interceptors></interceptors>
<global-results>
<result name="notAuthorized">/loginPage.jsp</result>
</global-results>
这个答案基于您的代码。我最好推荐这个post
这里有一些可能对您有帮助的链接
关于java - struts2 session 维护,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18635383/
我们已经在我的工作场所使用 SVN 几年了,自从我们安装它以来,除了更新和备份之外,我们真的没有对其进行任何类型的维护。我们还应该做些什么来维护 SVN,或者我们已经做了所有我们真正需要做的事情吗?
正则表达式模式如下: ".*/.*/.*/.*/.*/.*/(.*)-\d{2}\.\d{2}\.\d{2}.\d{4}.*" 确实很难维护。 我想知道,有没有这样的东西: ".*/.*/.*/.*/
我已经搜索了一些,但没有找到任何对我有帮助的问题/答案。问题是我的 jQuery 函数调用变得太大而无法维护。我想知道我是否应该进行更多重构,或者是否有更好的方法来完成所有这些调用。当我进行一次调用时
我在 mySql 中有一个记录表。我需要按照用户指定的方式为它们维护订单。所以我添加了一个“位置”列。 当我移动特定记录时更新所有记录的 SQL 语句是什么?我有类似的东西: UPDATE items
我正在使用 go channels 作为类似队列的机制,这非常适合我。我正在为每个用户打开这些类似队列的 channel 之一,并为这些 channel 中的每一个都有一个 for-range 循环。
使用 docker,您可以非常好地基于其他图像创建图像。例如,您可以制作一个镜像 Java-jdk7(基于最新的 Ubuntu LTS),并在此基础上创建镜像 elastic-search 和 tom
我正在用 Bash 编写脚本。 我的关联数组有问题,当我像这样在我的数组中放置一条记录时: declare -A arr_list_people_name 我将文本放入循环关联数组的方式(将文本排序)
我目前正在开发一个系统,该系统需要在没有可用互联网连接的情况下安装 python(或者至少我不能假设有可用的互联网连接), 我想知道维护 PIP 存储库的间接费用是多少,而且这样的存储库也可能会满足系
我正在考虑使用 Chrome 扩展的国际化支持,如 here 所述. 建议的翻译方法是先创建英文 messages.json 文件,然后将其复制并翻译成给定的语言。 我的问题是,这对于初始翻译来说工作
我想在(自托管)bitbucket 服务器中克隆 github 存储库,并不时从 github 存储库中提取最新更改。在我们的克隆中,我们将做一些永远不会离开我们的存储库的实验性内容。 为了显示;对于
我的应用程序基于银行域,需要 session 处理。当应用程序空闲时(应用程序打开后没有任何触摸事件)必须在后台计算时间。 当应用程序进入前台时,我处理 session 维护以及 AppDelegat
我可以保持 UISegmentViewControl 段的选定状态吗?即,即使用户选择了另一个段,也可以保持一个段显示为选中状态?我似乎在任何地方都找不到任何可以做到这一点的东西!! 最佳答案 这是不
我的要求:我想将登录详细信息(电子邮件、密码)发送到服务器,必须保持有效用户名的 session 。 如何使用 iphone SDK 的“NSURLConnection”创建和维护 session ?
就像Carl's question over here我想问你(因为我自己找不到 :( ) 删除既不是静态也不是动态(例如通过反射)使用的程序集引用是否有任何好处。 最佳答案 除了清理项目之外,删除未
我使用的是Bootstrap 3。我目前有2个页面,一个是查看页面,一个是编辑页面。两个页面都有许多导航选项卡,例如 id= tab1、tab2、tab3。 我想要实现的是,当我在查看页面的 tab2
我正在创建 Chrome 应用程序,我希望我的用户在首次进入应用程序时登录或创建用户。 目标: 在 Chrome 打包的应用程序上维护登录状态。 问题: Cookie - Chrome 打包的应用程序
我有arm模板来使用资源及其设置重新创建资源组。这工作得很好。 用例: 一些开发人员访问 Azure 门户并更新某些资源的某些设置。有没有办法获得可以应用于我的模板的精确更改以使这些更改生效? (更新
我有一个包含三个组合框的表单,一个代表该月(可能的)31 天,第二个代表代表月份的 12 个数字,第三个代表与 future 五年相对应的年份值。 我将它们连接在一起形成一个日期 TheDay = C
我有一个打开多个 JIF 的应用程序,但我只想创建 JIF 的单个实例,因此我使用这些函数来检查这一点,并在按下某个键后使用 dispose 关闭 JIF(JDesktopPane. getSelec
我想为一个项目制作一个帐户屏幕,但我对 GUI 还很陌生。这是我第一次使用 JComboBox,但遇到了一些麻烦。我基本上想将 JComboBox 放置在一个盒子内,这将成为我的背景图像的一部分。我尝
我是一名优秀的程序员,十分优秀!