强力重置ASP.NET membership加密后的密码![转]
公司网站的用户管理采用的是ASP.NET内置的membership管理,在web.config文件中的密码格式配置是加密了的,passwordFormat="Hashed",这样在用户注册的时候存到数据库中的密码都是加密了的,如果你忘记密码了要找回密码的时候必须要记得注册时写的密码问题答案,可是如果密码问题答案也忘记的话。。。因为密码是加了密的,所以也不知道他的密码的生成规律,直接改数据库也不懂怎么改。。。
这个问题在以前的时候碰到过,当时特意上网搜索了一下,竟然没有发现,不知道是不是我的关键字输入错误还是怎么的,今天上台湾的论坛逛成人版块的时候发现论坛中的编辑版块有篇文章是教你怎么样在不记得密码,利用了membership其中的一个存储过程,废话少说,亮code:
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Web.UI;
- using System.Web.UI.WebControls;
- using System.Web.Configuration;
- using System.Data.SqlClient;
- using System.Web.Security;
- using System.Data;
- public partial class ResetPassword : System.Web.UI.Page
- {
- protected void Page_Load(object sender, EventArgs e)
- {
- }
- // 重置
- protected void btnReset_Click(object sender, EventArgs e)
- {
- string connStr = WebConfigurationManager.ConnectionStrings["conn"].ToString();
- string username = txtUserName.Text.Trim();
- if (username.Length==0)
- {
- Response.Write("请输入用户名!");
- return;
- }
- //=== 产生加密用的密码密钥 ===
- string salt = GenerateSalt();
- //=== 将明码密码加密(此时密码为"P@ssw0rd" 当然也可随机数生成) ===
- string password = EncryptToHashString("123456", salt, "SHA1");
- SqlConnection conn = new SqlConnection(connStr);
- conn.Open();
- //=== 在此我们呼叫 Membership 提供者 数据库里的预存程序来重置密码 ===
- SqlCommand cmd = new SqlCommand("aspnet_Membership_SetPassword", conn);
- cmd.CommandType = CommandType.StoredProcedure;
- //=== 目前使用 Membership 提供者的 web 应用程序名称 ===
- cmd.Parameters.Add(new SqlParameter("@ApplicationName", Membership.ApplicationName));
- //=== 要重置密码的用户账号 ===
- cmd.Parameters.Add(new SqlParameter("@UserName", username));
- //=== 加密过的密码 ===
- cmd.Parameters.Add(new SqlParameter("@NewPassword", password));
- //=== 密码加密密钥(一定和使用加密密码的密钥一样,不要再重新产生) ===
- cmd.Parameters.Add(new SqlParameter("@PasswordSalt", salt));
- //=== 重置密码的时间 ===
- cmd.Parameters.Add(new SqlParameter("@CurrentTimeUtc", DateTime.Now));
- //=== 密码加密的格式(此时是Hash1,注意传入参数是int型态。) ===
- cmd.Parameters.Add(new SqlParameter("@PasswordFormat", Membership.Provider.PasswordFormat.GetHashCode()));
- //=== 宣告一个可以接收回传值得参数 ===
- SqlParameter returnValue = new SqlParameter();
- returnValue.ParameterName = "returnValue";
- returnValue.Direction = ParameterDirection.ReturnValue;
- cmd.Parameters.Add(returnValue);
- //=== 执行预存程序 ===
- cmd.ExecuteNonQuery();
- conn.Close();
- //=== 检查重置密码是否成功 ===
- if (returnValue.Value.ToString() == "0")
- Response.Write("重置密码成功!!");
- else
- Response.Write("重置密码失败!!");
- }
- /// <summary>
- /// 密码加密钥
- /// </summary>
- /// <returns></returns>
- public string GenerateSalt()
- {
- byte[] data = new byte[0x10];
- new System.Security.Cryptography.RNGCryptoServiceProvider().GetBytes(data);
- return Convert.ToBase64String(data);
- }
- /// <summary>
- /// 哈希密码加密(不可还原)
- /// </summary>
- /// <param name="s">原始字符串</param>
- /// <param name="saltKey">Salt加密字符串</param>
- /// <param name="hashName">加密格式(MD5, SHA1, SHA256, SHA384, SHA512.)</param>
- /// <returns>加密过的密码</returns>
- public string EncryptToHashString(string s, string saltKey, string hashName)
- {
- byte[] src = System.Text.Encoding.Unicode.GetBytes(s);
- byte[] saltbuf = Convert.FromBase64String(saltKey);
- byte[] dst = new byte[saltbuf.Length + src.Length];
- byte[] inArray = null;
- System.Buffer.BlockCopy(saltbuf, 0, dst, 0, saltbuf.Length);
- System.Buffer.BlockCopy(src, 0, dst, saltbuf.Length, src.Length);
- System.Security.Cryptography.HashAlgorithm algorithm = System.Security.Cryptography.HashAlgorithm.Create(hashName);
- inArray = algorithm.ComputeHash(dst);
- return Convert.ToBase64String(inArray);
- }
- }
这样就把密码重置为123456了
刚刚在做membership的测试的时修实然想到,数据表aspnet_Membership中的Password字段是存储密码的,FormatPassword字段是表示密码的存储格式的,0是明码,1是加密过的,假如我在数据库中把已经加密了的密码的FormatPassword改为0,然后Password改成123456, 测试,哈哈,竟然也能登陆了!!!
强力重置ASP.NET membership加密后的密码![转]的更多相关文章
- 电信级的RSA加密后的密码的破解方法
一直以来,电信通过HTTP劫持推送广告的方式已经存在了很多年了,这种手段至今并未停止.这种手段月光博客曾经有多次曝光,见<电信级的网络弹出广告>.<获取了电信恶意弹出广告的罪证> ...
- Excel文件加密后忘记密码破解方法
最好使用VBA 工程密码破解方法 新建一个excel文档,然后打开,同时按Alt和F11,进入VBA界面 点击菜单上的插入,模块 在新的窗口粘贴以下代码: Sub crack() Dim i As L ...
- Web安全--使用Salt + Hash将密码加密后再存储进数据库
转载原地址 http://www.bozhiyue.com/mianshiti/_net/2016/0728/314239.html (一) 为什么要用哈希函数来加密密码 如果你需要保存密码(比如网站 ...
- ASP.NET常用加密解密方法
ASP.NET常用加密解密方法 一.MD5加密解密 1.加密 C# 代码 public static string ToMd5(string clearString) ...
- ASP原码加密工具介绍
ASP原码加密工具介绍 总是会有非常多方法暴露ASP的原程序.造成数据库的password 路径都能够轻易被其它人搞到,所以对ASP程序实行加密处理是个不错的解决方法.以下来介绍一个工具假设大家感兴趣 ...
- md5加密后不能解密
MD5加密原理是散列算法,散列算法也称哈希算法.计算机专业学的数据结构就有哈希表这一知识点.比如10除以3余数为一,4除以3余数也为一,但余数为一的就不知道这个数是哪个了.所以md5不能解密.就算是设 ...
- 【转】asp.net(c#)加密解密算法之sha1、md5、des、aes实现源码详解
原文地址:http://docode.top/Article/Detail/10003 目录: 1..Net(C#)平台下Des加密解密源代码 2..Net(C#)平台下Aes加密解密源代码 3..N ...
- Java_I/O输入输出_使用输入输出流读取文件,将一段文字加密后存入文件,然后读取,将加密前与后的文件输出
import java.io.*; public class Example { public static void main(String[] args) { char a[] = "今 ...
- Code笔记之:对使用zend加密后的php文件进行解密
对使用zend加密后的php文件进行解密 使用zend加密后的php文件用notpad++打开会出现类似的乱码 下面使用解密工具进行解密 http://pan.baidu.com/s/1i3n4ysX ...
随机推荐
- C#学习笔记(补充)——扩展方法、事件
(搬运自我在SegmentFault的博客) 一.扩展方法 扩展方法使你能够向现有类型"添加"方法,而无需创建新的派生类型.重新编译或以其他方式修改原始类型. 注意事项: 扩展方法 ...
- .NET开源工作流RoadFlow-流程设计-保存与发布
如果流程未设计完时可以先保存,以后再打开接着设计.点击工具栏上的保存按钮即可保存当前流程设计: 如果下次要接着设计,则可以打开该流程继续设计: 如果流程设计完成,可以点击安装按钮来发布流程,流程安装成 ...
- [Environment Build] Win10下Appach配置
1. Apache下载,登录http://httpd.apache.org/download.cgi,选择Files for Microsoft Windows, 有以下几个选择, 我选择的是Apac ...
- golang的哪些坑爷事: package实践
在golang中package是个困惑的概念, 特别是package还可以与folder不同名, 委实让我恶心了一把. 关于golang的package的最佳实践: package is folder ...
- http压力测试
一.http_load程序非常小,解压后也不到100Khttp_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载.但是它不同于大多数压力测试工具,它可以以一个单一的进程运行,一般不会把 ...
- python 实现求和、计数、最大最小值、平均值、中位数、标准偏差、百分比。
import sys class Stats: def __init__(self, sequence): # sequence of numbers we will process # conver ...
- 一位iOS教育类应用开发者是如何赚到60多万美元?
注:伯乐在线12月19日在@程序员的那些事 微博推荐了此文的英文原文,非常感谢@dotSlash 的翻译. 转眼距我写<我如何在iOS教育类应用中赚到20万美元>这篇博文已经一年多了,它 ...
- 元音字母A的发音规则
摘抄自百度文库 A/a的发音比较复杂,归纳起来有10种情况: 一.在重读开音节中读[ei]. 例如: plane [plein] radio [ˈreidiəu] wake [weik] pape ...
- qt 焦点设置策略
focusPolicy 一个QWidget获得焦点的方式受 focusPolicy 控制 Qt::TabFocus 通过Tab键获得焦点 Qt::ClickFocus 通过被单击获得焦点 Qt::St ...
- [原]Java修炼 之 基础篇(一)Java语言特性
学习软件开发,首先要选择的就是选择需要采用的编程语言,考虑语言本身的优缺点和实际需求,综合评价之后选择相关的语言进行系统开发.本篇博客开始就从近年来比较流行的Java开始为大家讲起. 背景 1995年 ...