标签:序列 class use cli 椭圆 成员 word 曲线 turn
将公开密钥算法作为软件注冊算法的优点是Cracker非常难通过跟踪验证算法得到注冊机。以下。将介绍使用SM2国密算法进行软件注冊的方法。
生成授权码
在国家商用password算法开放动态库OpenSM.dll的SM2类中已集成授权码的生成和验证方法。
相应的成员函数为:
/// <summary> /// 生成授权码 /// </summary> /// <param name="userId">用户注冊信息</param> /// <param name="PrivateKey">私钥</param> /// <returns>授权码</returns> /// <remarks>注意:对于同样的注冊信息。每次生成的授权码并不同样</remarks> public ECLicenseKey LicenseKeyMaker(byte[] userId, BigInteger PrivateKey); /// <summary> /// 生成授权码 /// </summary> /// <param name="userId">用户注冊信息</param> /// <param name="PrivateKey">私钥</param> /// <param name="r">随机数。其值在[1, N-1]。N为G点的阶</param> /// <returns>授权码</returns> /// <remarks>注意:对于同样的注冊信息和同样的r。每次生成的授权码一致</remarks> public ECLicenseKey LicenseKeyMaker(byte[] userId, BigInteger PrivateKey, BigInteger r); /// <summary> /// 校验授权码 /// </summary> /// <param name="userId">用户注冊信息</param> /// <param name="RegisterCode">注冊码</param> /// <param name="PublicKey">公钥</param> /// <returns> /// true:校验通过 /// fasle:校验失败 /// </returns> public bool LicenseKeyVerifier(byte[] userId, ECLicenseKey RegisterCode, ECPoint PublicKey);
/// <summary>
/// SM2password算法注冊机生成授权码格式
/// </summary>
public class ECLicenseKey
{
public readonly BigInteger mKey;
public readonly BigInteger mHash;
/// <summary>
/// 构造函数
/// </summary>
/// <param name="key">授权码</param>
/// <param name="hash">哈希值</param>
public ECLicenseKey(BigInteger key, BigInteger hash)
{
this.mKey = key;
this.mHash = hash;
}
}
国家商用password(五)基于SM2的软件授权码生成及校验
标签:序列 class use cli 椭圆 成员 word 曲线 turn
原文地址:http://www.cnblogs.com/zhchoutai/p/6805131.html