已经投票
报表集成 >> 管理报表应用 >> 权限配置 >> 权限FAQ >> 权限之密码加密 >> 权限之密码加密RSA加密算法

权限之密码加密RSA加密算法

顶( )
最后更新日期: 人发表评论 (点击查看)
密码加密RSA加密算法,解密
1. 问题描述
在使用数据集进行身份认证时,密码存在数据库中,认证时用户输入的密码与数据库中密码相同则认证通过,若数据库被破解了则对系统造成威胁,怎样保证系统安全呢?
2. 实现思路
就是在url中传用户名密码时,先把用户名进行翻转,然后再进行加密,如输入的密码为12, 实际后台进行加密的值为21, 再与数据库进行验证,这样就可以避免数据库被破解查看到的是21的加密码,登陆系统时以21是无法登陆成功的。
3. 实现步骤
3.1 加载bcprov-jdk14-146.jar驱动包
RSA加密使用的第三方包,放到工程web-inf/lib文件夹下即可,如果没有驱动可点击bcprov-jdk14-146.jar驱动包下载。
注:JBOSS服务器下,使用的第三方加密包,提示报错:Can not parse the BC Provider。需要将此包bcprov-jdk14-146.jar从报表工程下移入到JBOSS默认jar包路径下即可。
3.2 调用js文件
RSA文件夹为前端js加密时需要调用js文件,因此需要将Barrett.js、BigInt.js、RSA.js放到工程目录下如:WebReport/js,新建js文件夹放入js文件,如果没有此js文件可点击rsa/js下载。
3.3 定义RSA加密类
定义RSAUtil.java类文件,先运行类中generateKeyPair()方法,会在服务器D盘中生成一个随机的RSAKey.txt文件,保存公钥和密钥,每访问一次这个方法会刷新一次txt文件。
3.4 定义TestPasswordValidator.java密码验证类
定义一个类,命名为TestPasswordValidator.java,扩展于AbstractPasswordValidator,重写其中密码验证方法validatePassword,先把输入的密码进行翻转,然后再进行加密,返回密码进行验证,具体代码如下:
3.5 编译类文件
首先编译RSAUtil.java类文件在服务器的D盘生成RSAKey.txt文件,再编译TestPasswordValidator.java类,把编译后的class文件放到项目工程web-inf/classes/com/fr/privilege/providers/dao文件夹中。
3.6 登陆Login.jsp页面设置
客户端请求到登录页面,随机生成一字符串,此随机字符串作为密钥加密密码,如下代码:
3.7 管理平台设置
访问报表触发加密文件需要在管理平台>权限配置中设置,勾选自定义密码加密,在文本框中输入com.fr.privilege.providers.dao.TestPasswordValidator即可调用,详细设置可参考文档简单权限之密码加密
如上所有设置完之后,RSA加密算法基本上就设置完成。
 
 
 
 
   
文明发言,用心评论
 
应用此篇文章,您:
不费力
研究了一会
琢磨了好久
 
查看全部条>>
返回顶部
Copyright©2019 帆软软件有限公司
苏ICP备18065767号-3