- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发具有高度隐私的网络应用程序。我想将每个用户的用户名和加密密码存储在数据库表中,并且我想将 AnonymousUserName 存储在另一个表中以关联个人详细信息。 AnonymousUserName 应该通过对真实用户名进行哈希处理并用明文密码对哈希进行加盐来创建。所以管理员不可能找到 AnonymousUserName,因为密码只是加密存储在数据库中。
尽管如此,我必须知道哪个 AnonymousUserName 属于登录用户。因此,我想在每次用户登录时对用户名进行哈希处理,并用普通密码对哈希进行加盐,并将生成的 AnonymousUserName 保存为 SessionAtribute,当用户离开应用程序时,它会再次被删除。
目前我的 Authentication-Manager 配置看起来非常简单。
<?xml version="1.0" encoding="UTF-8"?>
<beans:beans xmlns="http://www.springframework.org/schema/security"
xmlns:beans="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:repository="http://www.springframework.org/schema/data/repository"
xsi:schemaLocation="http://www.springframework.org/schema/data/repository http://www.springframework.org/schema/data/repository/spring-repository-1.5.xsd
http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-3.1.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<http use-expressions="true" auto-config="true">
<intercept-url pattern="/login"
access="permitAll"/>
<access-denied-handler />
<form-login login-page="/login" default-target-url="/"/>
<logout />
</http>
<beans:bean id="encoder" class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder"/>
<authentication-manager>
<authentication-provider user-service-ref="jdbcUserService">
<password-encoder ref="encoder"/>
</authentication-provider>
</authentication-manager>
<beans:bean id="jdbcUserService"
class="de.tuberlin.livefeedback.dao.SpringSecurityDaoImpl">
<beans:property name="dataSource" ref="dataSource" />
<beans:property name="enableGroups" value="true" />
<beans:property name="enableAuthorities" value="false" />
<beans:property name="groupAuthoritiesByUsernameQuery">
<beans:value>SELECT R.idROLE, R.NAME, P.NAME
FROM ROLE R
JOIN USER_ROLE RM on R.idROLE = RM.user_role_role
JOIN USER U on U.idUSER = RM.user_role_user
JOIN ROLE_PERMISSION RP ON RP.role_permission_role = R.idROLE
JOIN PERMISSION P ON P.idPERMISSION = RP.role_permission_permission
WHERE U.login=?
</beans:value>
</beans:property>
<beans:property name="usersByUsernameQuery">
<beans:value>select login,password,enabled from USER where login = ?
</beans:value>
</beans:property>
<beans:property name="authoritiesByUsernameQuery">
<beans:value>SELECT U.login, P.name FROM USER U, PERMISSION P WHERE U.login = ? AND P.idPERMISSION IN
(SELECT role_permission_permission FROM ROLE_PERMISSION WHERE role_permission_role IN
(SELECT user_role_role FROM USER_ROLE WHERE user_role_user=
(SELECT idUSER FROM USER WHERE login = ? LIMIT 1)))
</beans:value>
</beans:property>
</beans:bean>
</beans:beans>
我的想法是在用户使用他的凭据登录时覆盖处理 httpRequest 的方法,如下面的伪代码应该说明:
@Override
void authenticate (String username, String password){
String anonymousUserName = hash(username, password);
httpSession.setAttribute("anonymousUserName", anonymousUserName);
super(username, password) //to do the authentication-stuff
}
因为我不知道是否有任何方法可以通过这种方式覆盖以及在哪里可以找到,所以我正在写这个问题。
那么,有没有可能以类似的方式做我想做的事情?
谢谢你的期待
最佳答案
你可以使用 AuthenticationSuccessHandler
并在其 onAuthenticationSuccess(request, response, authentication)
中实现您的逻辑方法,您可以在其中获取所有必要的信息/对象。
在实践中,这意味着子类化 SavedRequestAwareAuthenticationSuccessHandler
它由默认配置使用,并且您很可能希望保留其实现的行为。然后在配置中,您可以将该类与 <form-login authentication-success-handler-ref="...">
连接起来。属性。
关于java - 如何在加密之前使用 spring security 登录时获取普通用户凭据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17026931/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
DBMS 供应商使用 SQL 方言特性来区分他们的产品,同时声称支持 SQL 标准。 'Nuff 说。 您编写的任何 SQL 示例是否无法转换为 SQL:2008 标准 SQL? 具体来说,我说的是
多年来,我一直在考虑这个问题,但从未成功实现过。我说的是一个快速、高效的 C 函数,它在输入中接受一个整数值(例如 16 位),并在输出中给出完全不同的相同位大小的数字,但“考虑到”所有数字已经给出了
当标准 iPhone UI 控件变得过于平淡,并且您希望简单的记分应用程序通过颜色、动画、非标准 GUI 字体和背景壁纸等流行时。 ,为这样的事情集成游戏引擎有意义吗? 我对 Unity3D 和 To
这是我的第一个问题,所以如果我没有正确地标记标签,我很抱歉。我尝试过...这是我的问题:我希望有人能告诉我如何为普通的表格 View 创建 2 行节标题。我遇到的问题是:1)我找不到可以模仿默认 1
所以我一直在开发一个仅使用普通 JavaScript 的“非常简单”的计算器。但我不知道为什么它现在起作用了。 这是我的 JavaScript 和 HTML 代码: (function() { "
我正在尝试编写一个函数来满足以下要求: 给定一个对象和一个键,“getElementsThatEqual10AtProperty”返回一个数组,其中包含位于给定键处等于 10 的数组的所有元素。 注释
[最终编辑:我觉得有必要做出回应,因为我从这篇文章中学到了很多东西(主要是通过你们,我花了更多的时间来理解CSS..但最后,我真的不知道如何为了使这项工作有效..除了真正破坏html的基本结构..我不
我希望能够将一个函数附加到一个元素上,该函数只有在该元素上单击指定时间后才会运行。 有几个( 1 、 2 、 3 )与在 javascript 中处理鼠标保持相关的问题;但这些问题要么使用 jQuer
我想将泛型函数保存为变量: (defvar *gf* (make-instance 'standard-generic-function) 但是在添加方法时,我必须自己定义call-next-meth
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我有一个普通的 tableView——一个部分——当我滚动时,行出现在标题后面。像这样: 有没有简单的方法来防止这种情况?我认为它与 contentInset 有关,但这也会移动标题,这不是我想要的。
你好,我有一个ajax表单,它返回一个控制“发送”动画的脚本。然而,当淡入开始时,它会停止在 0.1 不透明度。我不确定脚本中有什么问题。任何帮助将不胜感激。 quote_form = documen
这是演示我的问题的代码笔:http://codepen.io/PiotrBerebecki/pen/yaWQwZ 目标是当用户点击时有滚动动画 顶部导航链接,以及 Back to Top 按钮在右下角
在我重新发明轮子之前,纯Java中有类似主题的并发队列吗?我有以下要求: 多个读者/消费者 多名作家/制片人 每条消息都必须由每个(活跃的)消费者消费 在每个消费者阅读一条消息后,它应该变成垃圾(即不
这个问题与 Do MySQL tables need an ID? 有一个无意义的auto_incremental ID作为一个表的PRIMARY KEY,那么我创建其他KEY时,我是否应该在KEY中
我有一个普通 UITableView 并且我想隐藏分隔符。为了隐藏它,我尝试使用以下属性: 我也在 viewDidLoad 中设置了它。 self.tableView.separatorStyle =
var vettore = document.getElementById(id_form).elements; for (var i = 0; i '+vettore_nomi_file[i]; 最
我已经构建了一个非常简单的轮播,但有一个问题。在我的轮播中,我有三张幻灯片,一个上一个按钮和一个下一个按钮。我想要的是当我单击下一个按钮并在最后一张幻灯片上转到第一张幻灯片时。此外,当我单击上一个按钮
我是 javascript 的新手,所以我需要一些帮助。 我正在尝试制作一个简单的插件(当然只是为了学习,以便更好地理解事物),但我遇到了一些麻烦,我将不胜感激。 我的插件是基本的,我正在尝试为 sc
我是一名优秀的程序员,十分优秀!