C#使用伪随机数实现加密用户密码的方法
作者:shichen2014 时间:2023-06-27 05:27:56
本文所述实例为使用伪随机数进行用户密码加密,这段代码为核心部分主要代码,需要配合其它的程序实现,感兴趣的读者可以自己进一步加以完善,不费话了,下面列出主要代码:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace PRanDataEncrypt
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
if (textBox3.Text != "")
{
if (DecryptPwd(textBox3.Text) == textBox2.Text)
MessageBox.Show("用户登录成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
else
MessageBox.Show("用户密码错误!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
private void button2_Click(object sender, EventArgs e)
{
textBox1.Text = textBox2.Text = textBox3.Text = string.Empty;
textBox2.Focus();
}
private void textBox2_TextChanged(object sender, EventArgs e)
{
textBox3.Text = EncryptPwd(textBox2.Text);
}
//定义加密用户密码所用的伪随机数
private string randStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz";
#region 使用伪随机数加密用户登录密码
/// <summary>
/// 使用伪随机数加密用户登录密码
/// </summary>
/// <param name="str">用户登录密码</param>
/// <returns>加密后的用户登录密码</returns>
private string EncryptPwd(string str)
{
byte[] btData = Encoding.Default.GetBytes(str);
int j, k, m;
int len = randStr.Length;
StringBuilder sb = new StringBuilder();
Random rand = new Random();
for (int i = 0; i < btData.Length; i++)
{
j = (byte)rand.Next(6);
btData[i] = (byte)((int)btData[i] ^ j);
k = (int)btData[i] % len;
m = (int)btData[i] / len;
m = m * 8 + j;
sb.Append(randStr.Substring(k, 1) + randStr.Substring(m, 1));
}
return sb.ToString();
}
#endregion
#region 解密用户登录密码
/// <summary>
/// 解密用户登录密码
/// </summary>
/// <param name="str">经过加密的用户登录密码</param>
/// <returns>解密后的用户登录密码</returns>
private string DecryptPwd(string str)
{
try
{
int j, k, m, n = 0;
int len = randStr.Length;
byte[] btData = new byte[str.Length / 2];
for (int i = 0; i < str.Length; i += 2)
{
k = randStr.IndexOf(str[i]);
m = randStr.IndexOf(str[i + 1]);
j = m / 8;
m = m - j * 8;
btData[n] = (byte)(j * len + k);
btData[n] = (byte)((int)btData[n] ^ m);
n++;
}
return Encoding.Default.GetString(btData);
}
catch { return ""; }
}
#endregion
}
}
标签:C#,伪随机数,加密,密码
0
投稿
猜你喜欢
C# 面向对象三大特性:封装、继承、多态
2022-09-15 17:00:53
C#难点逐个击破(3):params数组参数
2022-01-17 14:40:22
Android系统音量条实例代码
2022-05-26 15:20:48
详解android系统的定制
2022-03-14 11:20:19
MyBatis动态SQL标签的用法详解
2021-07-24 10:38:56
Android中如何优雅的处理重复点击实例代码
2023-09-28 12:14:35
c#实现断点续传功能示例分享
2022-05-03 04:39:49
Android UI设计系列之自定义Dialog实现各种风格的对话框效果(7)
2023-11-18 14:26:37
C# 实现PPT 每一页转成图片过程解析
2023-02-21 10:01:27
c#只读字段和常量的区别,以及静态构造函数的使用实例
2023-10-31 09:52:20
Java数组扩容实现方法解析
2021-08-25 13:08:26
springboot整合mybatis的超详细过程(配置模式+注解模式)
2023-10-03 09:54:03
SpringBoot AOP控制Redis自动缓存和更新的示例
2023-08-31 17:34:37
Java中Map接口使用以及有关集合的面试知识点汇总
2021-08-20 00:28:51
90分钟实现一门编程语言(极简解释器教程)
2022-01-15 05:11:56
Java设计模式之命令模式_动力节点Java学院整理
2023-12-11 13:32:03
RocketMQ事务消息保证消息的可靠性和一致性
2022-09-05 00:25:26
c# DevExpress gridcontrol日期行的显示格式设置
2022-07-11 05:28:52
springBoot基于webSocket实现扫码登录
2023-02-16 13:07:34
JavaBean和Map转换封装类的方法
2023-04-18 06:50:52