首页 > 其他分享 >授权验证方式(个人使用)

授权验证方式(个人使用)

时间:2023-12-23 11:05:25浏览次数:24  
标签:return string 个人 验证 para static new 授权 csEncrypt

当自己做的小工具不想泛滥传播时,而自己又没有网络服务器,即可采用此种本地文件授权的方式,授权文件中包含授权时间和电脑的唯一识别编号

需要配合另一个机器码生成工具来使用

首先在Program-应用程序的主入口点中添加验证是否授权

static void Main()
        {
            Application.EnableVisualStyles();
            Application.SetCompatibleTextRenderingDefault(false);
            GlobalData globalData = new GlobalData();
            bool shouquan = globalData.ISAuthorizationot();
            if (shouquan == true)
            {
                Application.Run(new FormMain());
            }
            else
            {
                MessageBox.Show("当前未授权");
            }
        }

globalData.ISAuthorizationot();代码如下:

/// <summary>
        /// 是否已经授权
        /// </summary>
        /// <returns></returns>
        public bool ISAuthorizationot()
        {
            try
            {
                string uuid = GetUuid();
                string jiqima = GenerateMD5(uuid).ToUpper();
                string ConfigFilePath = Path.Combine(System.AppDomain.CurrentDomain.BaseDirectory, "CCGiao.DAT");
                //读取
                Hashtable para = new Hashtable();
                object obj = EncryptUtilSeal.DecryptObject(ConfigFilePath);
                para = obj as Hashtable;
                string jqm = para["jqm"].ToString();
                DateTime guoqidays =DateTime.Parse(para["days"].ToString());
                DateTime daysnow = DateTime.Now;
                if (jqm == jiqima && guoqidays>daysnow)
                {
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch
            {
                return false;
            }
            
        }

以下是上个方法中需要用到的方法,是获取设备唯一编号的方法和MD5加密的方法

/// <summary>
        /// 获取UUID
        /// </summary>
        /// <returns></returns>
        public static string GetUuid()
        {
            string uuid = null;
            try
            {
                SelectQuery query = new SelectQuery("select * from Win32_ComputerSystemProduct");
                using (ManagementObjectSearcher searcher = new ManagementObjectSearcher(query))
                {
                    foreach (var item in searcher.Get())
                    {
                        using (item) uuid = item["UUID"].ToString();
                    }
                }
                //有些厂商的配件不支持UUId会显示为一堆F
                if (uuid == null || uuid == "FFFFFFFF-FFFF-FFFF-FFFF-FFFFFFFFFFFF")
                {
                    uuid = GetMacAddress();
                }
                return uuid;
            }
            catch (Exception)
            {
                return "unknown";
            }
        }

        /// <summary>  
        /// 获取本机MAC地址  
        /// </summary>  
        /// <returns>本机MAC地址</returns>  
        public static string GetMacAddress()
        {
            try
            {
                string strMac = string.Empty;
                ManagementClass mc = new ManagementClass("Win32_NetworkAdapterConfiguration");
                ManagementObjectCollection moc = mc.GetInstances();
                foreach (ManagementObject mo in moc)
                {
                    if ((bool)mo["IPEnabled"] == true)
                    {
                        strMac = mo["MacAddress"].ToString();
                    }
                }
                moc = null;
                mc = null;
                return strMac;
            }
            catch
            {
                return "unknown";
            }
        }
        /// <summary>
        /// 对机器码进行MD5加密以此来保持长度一致
        /// </summary>
        /// <param name="txt"></param>
        /// <returns></returns>
        public static string GenerateMD5(string txt)
        {
            using (MD5 mi = MD5.Create())
            {
                byte[] buffer = Encoding.Default.GetBytes(txt);
                //开始加密
                byte[] newBuffer = mi.ComputeHash(buffer);
                StringBuilder sb = new StringBuilder();
                for (int i = 0; i < newBuffer.Length; i++)
                {
                    sb.Append(newBuffer[i].ToString("x2"));
                }
                return sb.ToString();
            }
        }

以下是C#读取和写入DAT文件的代码,需要授权的软件中只需要读取DAT文件,然后验证和当前机器码是否一致即可判断是否已经过授权

/// <summary>
        /// 加密、解密
        /// </summary>
        public class EncryptUtilSeal
        {
            private static byte[] key = new byte[] { 78, 56, 61, 94, 12, 88, 56, 63, 66, 111, 102, 77, 1, 186, 97, 45 };
            private static byte[] iv = new byte[] { 36, 34, 42, 122, 242, 87, 2, 90, 59, 117, 123, 63, 72, 171, 130, 61 };

            private static IFormatter S_Formatter = null;

            static EncryptUtilSeal()
            {
                S_Formatter = new BinaryFormatter();//创建一个序列化的对象
            }
            /// <summary>
            /// 采用Rijndael128位加密二进制可序列化对象至文件
            /// </summary>
            /// <param name="para">二进制对象</param>
            /// <param name="filePath">文件路径</param>
            /// <returns></returns>
            public static bool EncryptObject(object para, string filePath)
            {
                //创建.bat文件 如果之前错在.bat文件则覆盖,无则创建
                using (Stream fs = new FileStream(filePath, FileMode.Create, FileAccess.Write, FileShare.None))
                {
                    RijndaelManaged RMCrypto = new RijndaelManaged();
                    CryptoStream csEncrypt = new CryptoStream(fs, RMCrypto.CreateEncryptor(key, iv), CryptoStreamMode.Write);
                    S_Formatter.Serialize(csEncrypt, para);//将数据序列化后给csEncrypt
                    csEncrypt.Close();
                    fs.Close();
                    return true;
                }
            }

            /// <summary>
            /// 从采用Rijndael128位加密的文件读取二进制对象
            /// </summary>
            /// <param name="filePath">文件路径</param>
            /// <returns>二进制对象</returns>
            public static object DecryptObject(string filePath)
            {
                //打开.bat文件
                using (Stream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read))
                {
                    object para;
                    RijndaelManaged RMCrypto = new RijndaelManaged();
                    CryptoStream csEncrypt = new CryptoStream(fs, RMCrypto.CreateDecryptor(key, iv), CryptoStreamMode.Read);
                    para = S_Formatter.Deserialize(csEncrypt); //将csEncrypt反序列化回原来的数据格式;
                    csEncrypt.Close();
                    fs.Close();
                    return para;
                }
            }
        }

原创帖子,请勿传播

标签:return,string,个人,验证,para,static,new,授权,csEncrypt
From: https://blog.51cto.com/u_16371710/8944868

相关文章

  • [贴装专题] 基于halcon的拟合矩形边缘验证贴装精度
    作者:丶布布......
  • django验证码插件 --- django-simple-captcha
    使用django-simple-captcha实现登录验证码: 第一步:安装pillow依赖pipinstallpillow  -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ 第二步:安装django-simple-captchapipinstalldjango-simple-captcha -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ 第三步:注......
  • 专利文件去哪里查?怎么看有没有授权!
    乱七八糟四处乱找附上网址:https://tysf.cponline.cnipa.gov.cn/am/#/user/login第一次登录需要注册喔。如何看专利是否授权?国内的专利就在上述网址中搜出来,然后点到详情里看是只有公开还是公开和授权都有。国外的专利就到WIPO上去查询https://www.wipo.int/portal/en/in......
  • 2023第七届强网杯 个人题解
    27htppySpring评价:相对简单,放出来的晚,做的出来的人相对比较少大致流程是可以上传.pebble模板文件,然后通过访问上传的恶意模板文件进行rce。首先上传恶意模板文件,经过几次尝试,黑名单过滤了,org.springframework.context.support.ClassPathXmlApplicationContext和{{最终.pe......
  • K8S增加限制后的启动时间验证
    K8S增加限制后的启动时间验证背景前段时间看了下JVM载linux上面的启动时间,进行过一些验证.最近想着能够验证一下K8S上面的启动相关的信息所以就整理了一下.虽然没有特别好的结论,但是还是发现自己对JVM的启动和参数还是了解的不够深入.自己的几个启动参数1."-XX:......
  • 手把手教你isPalindrome 方法在密码验证中的应用
    在信息安全领域中,密码验证是一个极为重要的组成部分。一个强密码应具备足够的复杂性,以免遭到破解。而回文密码是一种具备特殊性质的密码,其正序和倒序相同,因此具有极高的安全性,并能发挥重要作用。在实际密码策略中,我们可以使用回文判断算法中的isPalindrome来验证用户输入的密码是......
  • js逆向-某天下房地产验证码
    声明本文仅供学习参考,如有侵权可私信本人删除,请勿用于其他途径,违者后果自负!如果觉得文章对你有所帮助,可以给博主点击关注和收藏哦!前言目标网站:aHR0cHM6Ly9wYXNzcG9ydC5mYW5nLmNvbS8=``接口:短信验证码登录接口在此特别感谢k哥的文章及本人的指导。【验证码逆向专栏】房某下登......
  • postgresql常用创建用户和授权
    需求(1)给用户a创建一个数据库,并且给a用户对这个库有所有权限(2)给read_a用户对这个数据库有只读权限步骤1.创建用户a2.创建数据库db_a,并设置owner为a3.回收默认的publicschemacreate权限4.设置db_a的publicschema默认的owner为a5.创建只读用户read_a6.用a用户给read_a......
  • Nacos未授权 CVE-2021-29441
    Nacos未授权CVE-2021-29441环境搭建环境dockerfile在文末环境启动docker-composeup-d查看下当前的容器dockerps漏洞复现访问Web页面127.0.0.1:8848抓包,访问http://127.0.0.1:8848/nacos/v1/auth/users?pageNo=1&pageSize=2将User-Agent的值修改为Nacos-Server......
  • 一些数据可以验证测试使用功能的
    INSERTINTOoffline_news(id,status,create_time)VALUES(15455114757359,0,"),2023-08-3111:24:43"),);INSERTINTOoffline_news(id,status,create_time)VALUES(24709425874357,0,"),2023-08-3111:24:43"),);INSERTINTOofflin......