开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 3301|回复: 28
打印 上一主题 下一主题
收起左侧

[易语言纯源码] 造轮子喽:Curve25519 算法,c#封的dll com库

[复制链接]
结帖率:36% (5/14)
跳转到指定楼层
楼主
发表于 2024-1-31 13:56:50 | 只看该作者 |只看大图 回帖奖励 |正序浏览 |阅读模式   四川省德阳市
分享源码
界面截图:
是否带模块: 纯源码
备注说明: -
昨天要用,没找到现成的轮子,于是自己用c#封装了一个
CurveCrypto.zip (883.21 KB, 下载次数: 49)

易语言代码:
  
窗口程序集名保 留  保 留备 注
C25519Lib, , 公开   
变量名类 型数组备 注
C25519对象  

子程序名返回值类型公开备 注
_初始化 当基于本类的对象被创建后,此方法会被自动调用
C25519.创建 (“CurveCryptoNew.Curve25519New”, )
子程序名返回值类型公开备 注
_销毁 当基于本类的对象被销毁前,此方法会被自动调用
C25519.清除 ()
子程序名返回值类型公开备 注
GenerateCurve25519KeyPair逻辑型 生成密钥对
变量名类 型静态数组备 注
flag逻辑型 
flag = C25519.逻辑方法 (“GenerateCurve25519KeyPair”, )
返回 (flag)
子程序名返回值类型公开备 注
GetPublicKey文本型 获取生成的密钥对中的公钥
变量名类 型静态数组备 注
publicKey文本型 
publicKey = C25519.文本方法 (“GetPublicKey”, )
返回 (到大写 (publicKey))
子程序名返回值类型公开备 注
GetPrivateKey文本型 获取生成的密钥对中的私钥
变量名类 型静态数组备 注
PrivateKey文本型 
PrivateKey = C25519.文本方法 (“GetPrivateKey”, )
返回 (到大写 (PrivateKey))
子程序名返回值类型公开备 注
CalculateCurve25519SharedSecret文本型 交换密钥
参数名类 型参考可空数组备 注
publicKey文本型
privateKey文本型
变量名类 型静态数组备 注
result文本型 
result = C25519.文本方法 (“CalculateCurve25519SharedSecret”, publicKey, privateKey)  ' ("CalculateCurve25519SharedSecret",publicKey,privateKey)
返回 (到大写 (result))

  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
变量名类 型数组备 注
C25519C25519Lib  

子程序名返回值类型公开备 注
__启动窗口_创建完毕  
变量名类 型静态数组备 注
publicKey文本型 
privateKey文本型 
result文本型 
如果真 (取反 (C25519.GenerateCurve25519KeyPair ()))
调试输出 (“生成密钥对失败”)
返回 ()
publicKey = C25519.GetPublicKey ()
privateKey = C25519.GetPrivateKey ()
调试输出 (publicKey)
调试输出 (privateKey)
result = C25519.CalculateCurve25519SharedSecret (publicKey, privateKey)
调试输出 (“共享密钥:”#换行符 + result)


i支持库列表   支持库注释   
spec特殊功能支持库


c#代码:
using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Crypto.Agreement;
using Org.BouncyCastle.Crypto.Generators;
using Org.BouncyCastle.Crypto.Parameters;
using Org.BouncyCastle.Security;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading.Tasks;

namespace CurveCryptoNew
{


    public interface IMyClass
    {


        string GetPublicKey();
        string GetPrivateKey();
        string CalculateCurve25519SharedSecret(string publicKey, string privateKey);
        bool GenerateCurve25519KeyPair();
    }
    [ClassInterface(ClassInterfaceType.None)]
    public class Curve25519New : IMyClass
    {
        /// <summary>
        /// 密钥交换算法
        /// </summary>
        /// <param name="publicKey"></param>
        /// <param name="privateKey"></param>
        /// <returns></returns>

        public string CalculateCurve25519SharedSecret(string publicKey, string privateKey)
        {
            X25519PrivateKeyParameters privateKeyParams = new X25519PrivateKeyParameters(HexToBytes(privateKey), 0);
            X25519PublicKeyParameters publicKeyParams = new X25519PublicKeyParameters(HexToBytes(publicKey), 0);

            X25519Agreement agreement = new X25519Agreement();
            agreement.Init(privateKeyParams);
            byte[] sharedSecret = new byte[32];
            agreement.CalculateAgreement(publicKeyParams, sharedSecret, 0);

            return BytesToHex(sharedSecret);
        }


        string privateKey;

        string publicKey;

        public string GetPublicKey()
        {
            return publicKey;
        }


        public string GetPrivateKey()
        {
            return privateKey;
        }
        /// <summary>
        /// 生成GenerateCurve25519算法密钥对
        /// </summary>
        /// <param name="privateKey"></param>
        /// <param name="publicKey"></param>
        /// <returns></returns>
        ///


        public bool GenerateCurve25519KeyPair()
        {
            X25519KeyPairGenerator generator = new X25519KeyPairGenerator();
            generator.Init(new X25519KeyGenerationParameters(new SecureRandom()));
            AsymmetricCipherKeyPair keyPair = generator.GenerateKeyPair();

            X25519PrivateKeyParameters privateKeyParams = (X25519PrivateKeyParameters)keyPair.Private;
            X25519PublicKeyParameters publicKeyParams = (X25519PublicKeyParameters)keyPair.Public;

            privateKey = BytesToHex(privateKeyParams.GetEncoded());
            publicKey = BytesToHex(publicKeyParams.GetEncoded());

            return privateKey.Length > 0 && publicKey.Length > 0;
        }


        public static byte[] HexToBytes(string hex)
        {
            int length = hex.Length;
            byte[] bytes = new byte[length / 2];
            for (int i = 0; i < length; i += 2)
            {
                bytes[i / 2] = Convert.ToByte(hex.Substring(i, 2), 16);
            }
            return bytes;
        }

        public static string BytesToHex(byte[] bytes)
        {
            StringBuilder hexBuilder = new StringBuilder(bytes.Length * 2);
            foreach (byte b in bytes)
            {
                hexBuilder.AppendFormat("{0:x2}", b);
            }
            return hexBuilder.ToString();
        }
    }
}


评分

参与人数 7好评 +4 精币 +10 收起 理由
wa690602724 + 1 感谢分享,很给力!~
qck易语言 + 1 + 2 支持开源~!感谢分享
財財 + 1 感谢分享,很给力!~
国王软件 + 1 + 3 支持开源~!感谢分享
wuqingg + 1 支持开源~!感谢分享
光影魔术 + 2 支持开源~!感谢分享
汉族 + 1 + 1 奉上小小红包希望笑纳

查看全部评分


本帖被以下淘专辑推荐:

  • · 鱼木|主题: 1601, 订阅: 155
结帖率:89% (66/74)

签到天数: 3 天

29
发表于 2024-9-8 14:15:20 | 只看该作者   黑龙江省绥化市
有没有C#的源码 学习学习
回复 支持 反对

使用道具 举报

结帖率:92% (11/12)

签到天数: 1 天

28
发表于 2024-9-3 00:51:04 | 只看该作者   山西省大同市
生成密钥对失败,管理员运行了Reg.bat也是生成密钥对失败~

怎么寻找错误原因呢
回复 支持 反对

使用道具 举报

结帖率:25% (1/4)

签到天数: 10 天

27
发表于 2024-3-10 12:38:39 | 只看该作者   四川省泸州市
Curve25519 算法
回复 支持 反对

使用道具 举报

结帖率:50% (1/2)

签到天数: 11 天

26
发表于 2024-2-5 12:29:16 | 只看该作者   广东省汕头市
感谢大神分享~!
回复 支持 反对

使用道具 举报

签到天数: 1 天

25
发表于 2024-2-3 21:47:34 | 只看该作者   江苏省连云港市
        支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)

签到天数: 15 天

24
发表于 2024-2-3 02:33:26 | 只看该作者   广东省深圳市
学习一下
回复 支持 反对

使用道具 举报

结帖率:50% (7/14)

签到天数: 11 天

23
发表于 2024-2-2 16:11:44 | 只看该作者   安徽省安庆市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:96% (53/55)

签到天数: 13 天

22
发表于 2024-2-2 07:38:08 | 只看该作者   山东省青岛市
全都是大佬~
回复 支持 反对

使用道具 举报

结帖率:98% (111/113)

签到天数: 16 天

21
发表于 2024-2-2 07:33:35 | 只看该作者   山东省青岛市
感谢您对论坛的支持!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:[email protected]
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表