界面显示:

加密:

解密:


代码实现:

public string EncryptString(string str)

        {

            #region 加密程序

            char[] Base64Code = new char[] { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q',
'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '+', '/', '=' };

            byte empty = (byte)0;

            System.Collections.ArrayList byteMessage = new System.Collections.ArrayList(System.Text.Encoding.Default.GetBytes(str));

            System.Text.StringBuilder outmessage;

            int messageLen = byteMessage.Count;

            int page = messageLen / 3;

            int use = 0;

            if ((use = messageLen % 3) > 0)

            {

                for (int i = 0; i < 3 - use; i++)

                    byteMessage.Add(empty);

                page++;

            }

            outmessage = new System.Text.StringBuilder(page * 4);

            for (int i = 0; i < page; i++)

            {

                byte[] instr = new byte[3];

                instr[0] = (byte)byteMessage[i * 3];

                instr[1] = (byte)byteMessage[i * 3 + 1];

                instr[2] = (byte)byteMessage[i * 3 + 2];

                int[] outstr = new int[4];

                outstr[0] = instr[0] >> 2;



                outstr[1] = ((instr[0] & 0x03) << 4) ^ (instr[1] >> 4);

                if (!instr[1].Equals(empty))

                    outstr[2] = ((instr[1] & 0x0f) << 2) ^ (instr[2] >> 6);

                else

                    outstr[2] = 64;

                if (!instr[2].Equals(empty))

                    outstr[3] = (instr[2] & 0x3f);

                else

                    outstr[3] = 64;

                outmessage.Append(Base64Code[outstr[0]]);

                outmessage.Append(Base64Code[outstr[1]]);

                outmessage.Append(Base64Code[outstr[2]]);

                outmessage.Append(Base64Code[outstr[3]]);

            }

            return outmessage.ToString();

            #endregion

        }

        private void btnEncrypt_Click(object sender, EventArgs e)

        {

            #region 加密按钮

            try

            {

                txtMiWen.Text = EncryptString(txtMingWen.Text);

            }

            catch

            {

                MessageBox.Show("明文(密文)有误!", System.Windows.Forms.Application.ProductName);

                txtMiWen.Text = "";

                return;

            }

            #endregion

        }

        public string DecryptString(string str)

        {

            #region 解密程序

            if ((str.Length % 4) != 0)

            {

                throw new ArgumentException("不是正确的BASE64编码,请检查。", "str");

            }

            if (!System.Text.RegularExpressions.Regex.IsMatch(str, "^[A-Z0-9/+=]*$", System.Text.RegularExpressions.RegexOptions.IgnoreCase))

            {

                throw new ArgumentException("包含不正确的BASE64编码,请检查。", "str");

            }

            string Base64Code = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=";

            int page = str.Length / 4;

            System.Collections.ArrayList outMessage = new System.Collections.ArrayList(page * 3);

            char[] message = str.ToCharArray();

            for (int i = 0; i < page; i++)

            {

                byte[] instr = new byte[4];

                instr[0] = (byte)Base64Code.IndexOf(message[i * 4]);

                instr[1] = (byte)Base64Code.IndexOf(message[i * 4 + 1]);

                instr[2] = (byte)Base64Code.IndexOf(message[i * 4 + 2]);

                instr[3] = (byte)Base64Code.IndexOf(message[i * 4 + 3]);

                byte[] outstr = new byte[3];

                outstr[0] = (byte)((instr[0] << 2) ^ ((instr[1] & 0x30) >> 4));

                if (instr[2] != 64)

                {

                    outstr[1] = (byte)((instr[1] << 4) ^ ((instr[2] & 0x3c) >> 2));

                }

                else

                {

                    outstr[2] = 0;

                }

                if (instr[3] != 64)

                {

                    outstr[2] = (byte)((instr[2] << 6) ^ instr[3]);

                }

                else

                {

                    outstr[2] = 0;

                }

                outMessage.Add(outstr[0]);

                if (outstr[1] != 0)

                    outMessage.Add(outstr[1]);

                if (outstr[2] != 0)

                    outMessage.Add(outstr[2]);

            }

            byte[] outbyte = (byte[])outMessage.ToArray(Type.GetType("System.Byte"));

            return System.Text.Encoding.Default.GetString(outbyte);

            #endregion

        }

        private void btnDecrypt_Click(object sender, EventArgs e)

        {

            #region 解密按钮

            try

            {

                txtMiWen.Text = DecryptString(txtMingWen.Text);

            }

            catch

            {

                MessageBox.Show("明文(密文)有误", System.Windows.Forms.Application.ProductName);

                txtMiWen.Text = "";

                return;

            }

            #endregion

        }

版权声明:本文为博主原创文章,未经博主允许不得转载。

winform 加密 解密 分类: WinForm 2014-05-16 15:05 400人阅读 评论(0) 收藏的更多相关文章

  1. PIE(二分) 分类: 二分查找 2015-06-07 15:46 9人阅读 评论(0) 收藏

    Pie Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissio ...

  2. Find The Multiple 分类: 搜索 POJ 2015-08-09 15:19 3人阅读 评论(0) 收藏

    Find The Multiple Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 21851 Accepted: 8984 Sp ...

  3. 周赛-DZY Loves Chessboard 分类: 比赛 搜索 2015-08-08 15:48 4人阅读 评论(0) 收藏

    DZY Loves Chessboard time limit per test 1 second memory limit per test 256 megabytes input standard ...

  4. Ultra-QuickSort 分类: POJ 排序 2015-08-03 15:39 2人阅读 评论(0) 收藏

    Ultra-QuickSort Time Limit: 7000MS   Memory Limit: 65536K Total Submissions: 48111   Accepted: 17549 ...

  5. Drainage Ditches 分类: POJ 图论 2015-07-29 15:01 7人阅读 评论(0) 收藏

    Drainage Ditches Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 62016 Accepted: 23808 De ...

  6. max_flow(Dinic) 分类: ACM TYPE 2014-09-02 15:42 94人阅读 评论(0) 收藏

    #include <cstdio> #include <iostream> #include <cstring> #include<queue> #in ...

  7. SQL 分组 加列 加自编号 自编号限定 分类: SQL Server 2014-11-25 15:41 283人阅读 评论(0) 收藏

    说明: (1)日期以年月形式显示:convert(varchar(7),字段名,120) , (2)加一列 (3)自编号: row_number() over(order by 字段名 desc) a ...

  8. SQL 按月统计(两种方式) 分类: SQL Server 2014-08-04 15:36 154人阅读 评论(0) 收藏

    (1)Convert 函数 select Convert ( VARCHAR(7),ComeDate,120) as Date ,Count(In_code) as 单数,Sum(SumTrueNum ...

  9. SQL 存储过程 分页 分类: SQL Server 2014-05-16 15:11 449人阅读 评论(0) 收藏

    set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go -- ============================================= -- Au ...

  10. Sort List 分类: leetcode 算法 2015-07-10 15:35 1人阅读 评论(0) 收藏

    对链表进行排序,要求时间复杂度为O(n log n) ,不使用额外的空间. 我一开始的想法是借助quicksort的思想,代码如下: # time O(nlog(n)) # Definition fo ...

随机推荐

  1. 分享一个自己写的基于TP的关系模型(2)

    1.增加多对多关系的处理 /** * 定义关系 * @return array */ public function test4(){ //参数说明 //关联的模型 //主表关联字段 //关联中间表 ...

  2. tornado学习精要

    最简单的应用在程序的最顶部,我们导入了一些Tornado模块.虽然Tornado还有另外一些有用的模块,但在这个例子中我们必须至少包含这四个模块. 12341234包括了一个有用的模块(tornado ...

  3. Xcode-程序开发设计-02九宫格

    行号是除 决定Y值 列号是余 决定X值 // // ViewController.m // 06-应用管理 // // Created by daier on 15/12/31. // Copyrig ...

  4. C语言学习总结(四) 剩余内容

    第六章.剩余内容 (预处理指令,宏定义,条件编译,文件操作) 预处理指令 简单的来说就是在程序编译之前需要做的事情 1.宏定义 概念: 是一个替换代码的预处理指令,可以在编译之前进行代码替换(宏展开, ...

  5. 【微机】验证负数以补码存储程序 C语言

    微机中验证负数以补码存储程序 一.相关基础知识 负数的补码等于它的反码加1,即在其反码的最低位加1就为该数的补码,且在计算机中负数以补码形式进行存储. .int型占4字节(32位二进制)char型占1 ...

  6. JSON字符串序列化与反序列化浅试

    一.添加引用(using Newtonsoft.Json.Linq;) 二. 1.生成json字符串源码 List<string> list = new List<string> ...

  7. 学习总结之Log4NET

    通过在网上查找了一些资料,用了些时间学习了log4NET,做了一个小小的总结,说一下它的特点吧 首先呢log4NET是.Net下一个非常优秀的开源日志记录组件.它可以将日志分成不同等级,也可以按照我们 ...

  8. 【Tools】Chrome 控制台不完全指南

    Chrome的开发者工具已经强大到没朋友的地步了,特别是其功能丰富界面友好的console,使用得当可以有如下功效: 更高「逼格」更快「开发调试」更强「进阶级的Frontender」 Bug无处遁形「 ...

  9. 如何对 Android 库进行依赖管理?

    Android 开发人员为项目选择库的时候,考虑的因素不仅仅是功能.可用性.性能.文档丰富度和技术支持情况.他们还关心库的大小,以及要添加的方法数量.因为项目越大,依赖也越多,要把应用的方法数量控制在 ...

  10. Solr总结

    http://www.cnblogs.com/guozk/p/3498831.html Solr调研总结 开发类型 全文检索相关开发 Solr版本 4.2 文件内容 本文介绍solr的功能使用及相关注 ...