c# rsa注册实现加密文字
RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
private void btencoding_Click(object sender, EventArgs e)
{
if (mbox.Text == "")
{
MessageBox.Show("加密文字信息不能为空!");
return;
}
if (publickey.Text == "")
{
MessageBox.Show("请生成公钥!");
return;
}
try
{
string pubKey = publickey.Text;
byte[] mw = ASCIIEncoding.ASCII.GetBytes(mbox.Text);
RSACryptoServiceProvider crypt = new RSACryptoServiceProvider();
crypt.FromXmlString(pubKey);
mw = crypt.Encrypt(mw, false);
string encryttext = Convert.ToBase64String(mw);//加密后的结果怎样处理解决显示乱码问题
cbox.Text = encryttext;
}
catch
{
MessageBox.Show("请检查是否打开公匙或者公匙是否损坏!");
}
}
private void btdecoding_Click(object sender, EventArgs e)
{
if (cbox.Text == "")
{
MessageBox.Show("请生成密钥!");
return;
}
try
{
RSACryptoServiceProvider crypt = new RSACryptoServiceProvider();
byte[] bytes = Convert.FromBase64String(cbox.Text);//从密文框中取出的字符串正确处理才能解密
string prtKey = privatekey.Text;
crypt.FromXmlString(prtKey);
byte[] decryptbyte = crypt.Decrypt(bytes, false);
string decrypttext = Encoding.Default.GetString(decryptbyte);
mbox.Text = decrypttext;
}
catch (CryptographicException ex)
{
//MessageBox.Show("请检查是否打开私匙或者私匙是否损坏!");
MessageBox.Show(ex.ToString());
} if (cbox.Text == "")
{
MessageBox.Show("请生成密钥!");
return;
}
}
相关推荐
-
c# 实现MD5,SHA1,SHA256,SHA512等常用加密算法源代码
复制代码 代码如下: using System; using System.IO; using System.Data; using System.Text; using System.Diagnostics; using System.Security; using System.Security.Cryptography; /**//* * .Net框架由于拥有CLR提供的丰富库支持,只需很少的代码即可实现先前使用C等旧式语言很难实现的加密算法.本类实现一些常用机密算法,供参考.其中MD5算
-
基于私钥加密公钥解密的RSA算法C#实现方法
本文实例讲述了基于私钥加密公钥解密的RSA算法C#实现方法,是一种应用十分广泛的算法.分享给大家供大家参考之用.具体方法如下: 一.概述 RSA算法是第一个能同时用于加密和数字签名的算法,也易于理解和操作. RSA是被研究得最广泛的公钥算法,从提出到现在已近二十年,经历了各种攻击的考验,逐渐为人们接受,普遍认为是目前最优秀的公钥方案之一.RSA的安全性依赖于大数的因子分解,但并没有从理论上证明破译RSA的难度与大数分解难度等价. RSA的安全性依赖于大数分解.公钥和私钥都是两个大素数( 大于 1
-
C#加密算法汇总(推荐)
方法一: 复制代码 代码如下: //须添加对System.Web的引用 using System.Web.Security; ... /// <summary> /// SHA1加密字符串 /// </summary> /// <param name="source">源字符串</param> /// <returns>加密后的字符串</returns> public string SHA1(string sour
-
C#自定义RSA加密解密及RSA签名和验证类实例
本文实例讲述了C#自定义RSA加密解密及RSA签名和验证类.分享给大家供大家参考.具体分析如下: 这个C#类自定义RSA加密解密及RSA签名和验证,包含了RSA加密.解密及签名所需的相关函数,带有详细的注释说明. using System; using System.Text; using System.Security.Cryptography; namespace DotNet.Utilities { /// <summary> /// RSA加密解密及RSA签名和验证 /// </
-
C# DES加密算法中向量的作用详细解析
DES一共就有4个参数参与运作:明文.密文.密钥.向量.为了初学者容易理解,可以把4个参数的关系写成:密文=明文+密钥+向量:明文=密文-密钥-向量.为什么要向量这个参数呢?因为如果有一篇文章,有几个词重复,那么这个词加上密钥形成的密文,仍然会重复,这给破解者有机可乘,破解者可以根据重复的内容,猜出是什么词,然而一旦猜对这个词,那么,他就能算出密钥,整篇文章就被破解了!加上向量这个参数以后,每块文字段都会依次加上一段值,这样,即使相同的文字,加密出来的密文,也是不一样的,算法的安全性大大提高!
-
C#的3DES加密解密算法实例代码
C#类如下: 复制代码 代码如下: using System;using System.Collections.Generic;using System.Text;using System.Security.Cryptography;using System.IO; namespace ConsoleApplication1{ /// <summary> /// 加解密类 /// </summary> public class EncryptHelper
-
jQuery+C#实现参数RSA加密传输功能【附jsencrypt.js下载】
本文实例讲述了jQuery+C#实现参数RSA加密传输功能.分享给大家供大家参考,具体如下: 注意: 参数传递的+号处理,在传输时会把+变成空格,不处理后端就报错了. 1.前端代码 <!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width" /> <title>Login</title> <
-
同时兼容JS和C#的RSA加密解密算法详解(对web提交的数据加密传输)
前言 我们在Web应用中往往涉及到敏感的数据,由于HTTP协议以明文的形式与服务器进行交互,因此可以通过截获请求的数据包进行分析来盗取有用的信息.虽然https可以对传输的数据进行加密,但是必须要申请证书(一般都是收费的),成本较高.那么问题来了,如果对web提交的敏感数据进行加密呢?web应用中,前端的数据处理和交互基本上都是靠javascript来完成,后台的逻辑处理可以C#(java)等进行处理. 微软的C#中虽然有RSA算法,但是格式和OpenSSL生成的公钥/私钥文件格式并不兼容.这个
-
C#实现简单的RSA非对称加密算法示例
本文实例讲述了C#实现简单的RSA非对称加密算法.分享给大家供大家参考,具体如下: 界面控件 namespace RSA算法 { partial class Form1 { /// <summary> /// 必需的设计器变量. /// </summary> private System.ComponentModel.IContainer components = null; /// <summary> /// 清理所有正在使用的资源. /// </summary
-
c# rsa注册实现加密文字
复制代码 代码如下: RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); private void btencoding_Click(object sender, EventArgs e){ if (mbox.Text == "") { MessageBox.Show("加密文字信息不能为空!"); return; } if (publick
-
原生js的RSA和AES加密解密算法
本文实例为大家分享了js中RSA和AES加密解密详细代码,供大家参考,具体内容如下 <!doctype html> <html> <head> <meta charset='UTF-8'> </head> <body> <div class='test'></div> <script type="text/javascript"> function encrypt(data, k
-
JAVA 中解密RSA算法JS加密实例详解
JAVA 中解密RSA算法JS加密实例详解 有这样一个需求,前端登录的用户名密码,密码必需加密,但不可使用MD5,因为后台要检测密码的复杂度,那么在保证安全的前提下将密码传到后台呢,答案就是使用RSA非对称加密算法解决 . java代码 需要依赖 commons-codec 包 RSACoder.Java import org.apache.commons.codec.binary.Base64; import javax.crypto.Cipher; import java.security.
-
java使用RSA与AES加密解密的实例代码详解
首先了解下,什么是堆成加密,什么是非对称加密? 对称加密:加密与解密的密钥是相同的,加解密速度很快,比如AES 非对称加密:加密与解密的秘钥是不同的,速度较慢,比如RSA •先看代码(先会用在研究) 相关依赖: <dependency> <groupId>org.bouncycastle</groupId> <artifactId>bcprov-jdk15on</artifactId> <version>1.58</versio
-
springboot实现注册的加密与登录的解密功能(demo)
前情提要:本demo是基于springboot+mybatis-plus实现加密,加密为主,全局异常处理,日志处理为辅,而登录密码加密是每个项目中必须要的,密码不可能明文存入数据,这样没有安全性. 涉及的功能,全局异常处理,日志处理,mybatis-plus实现与数据库的交互,密码加密,restful风格 涉及的工具:IDEA,postman,sqlyog(navicat) 1. 首先我们直接看效果吧,如果你不满意,也就没必要看了 如果这正是你想要的效果呢,那你可以继续看下面的内容了 2. 首先
-
JAVA简单实现MD5注册登录加密实例代码
开发环境:jdk1.7,eclipse 框架:springmvc,mybatis 工具:maven 以下代码复制即可实现MD5加密 创建一个mave项目,加web.不懂得可以搜索一下就有了. 注册用户的JSP页面代码如下. <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PU
-
Java RSA加密解密实现方法分析【附BASE64 jar包下载】
本文实例讲述了Java RSA加密解密实现方法.分享给大家供大家参考,具体如下: 该工具类中用到了BASE64,需要借助第三方类库:javabase64-1.3.1.jar javabase64-1.3.1.jar 本站下载地址. 注意: RSA加密明文最大长度117字节,解密要求密文最大长度为128字节,所以在加密和解密的过程中需要分块进行. RSA加密对明文的长度是有限制的,如果加密数据过大会抛出如下异常: Exception in thread "main" javax.cryp
-
Java实现的RSA加密解密算法示例
本文实例讲述了Java实现的RSA加密解密算法.分享给大家供大家参考,具体如下: import java.awt.AlphaComposite; import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; import java.awt.Image; import java.awt.RenderingHints; import java.awt.image.BufferedImage; import java.
-
RSA实现JS前端加密与PHP后端解密功能示例
本文实例讲述了RSA实现JS前端加密与PHP后端解密功能.分享给大家供大家参考,具体如下: web前端,用户注册与登录,不能直接以明文形式提交用户密码,容易被截获,这时就引入RSA. 前端加密 需引入4个JS扩展文件,jsbn.js.prng4.js.rng.js和rsa.js. <html> <head> <title>RSA Login Test</title> <meta charset="utf-8"> <scr
-
Flask框架实现的前端RSA加密与后端Python解密功能详解
本文实例讲述了Flask框架实现的前端RSA加密与后端Python解密功能.分享给大家供大家参考,具体如下: 前言 在使用 Flask 开发用户登录API的时候,我之前都是明文传输 username 和 password.这种传输方式有一定的安全隐患,password 可能会在传输过程中被窃听而造成用户密码的泄漏. 那么我认为解决该问题的方法是这样的:在前端页面对数据进行加密,然后再发送到后端进行处理. 这一篇文章是前端用 RSA 的 publicKey 进行加密,然后后端用 Python 进行
随机推荐
- js 简单类代码
- Express实现前端后端通信上传图片之存储数据库(mysql)傻瓜式教程(一)
- flash用php连接数据库的代码
- PHP递归调用数组值并用其执行指定函数的方法
- 用ASP实现对ORACLE数据库的操作
- MySQL产生随机数并连接字符串的方法示例
- Android使用ListView实现滚轮的动画效果实例
- php中的一些数组排序方法分享
- Linux服务器硬件运行状态及故障邮件提醒的监控脚本分享
- 批处理应用 临时目录清理
- 用来检测输入的选项$1是否在PATH中的shell脚本
- java得到某年某周的第一天实现思路及代码
- 基于JS实现移动端向左滑动出现删除按钮功能
- php实现的css文件背景图片下载器代码
- WEB前端开发框架Bootstrap3 VS Foundation5
- SpringBoot入坑笔记之spring-boot-starter-web 配置文件的使用
- python字符串分割及字符串的一些常规方法
- window和linux通过tomcat9手工部署war包的方法
- 详解vue.js之props传递参数
- 详解Laravel5.6 Passport实现Api接口认证