修正密钥函数
This commit is contained in:
parent
68114e9aa5
commit
934298497c
@ -5,6 +5,7 @@ using Org.BouncyCastle.Security;
|
|||||||
using Org.BouncyCastle.Crypto;
|
using Org.BouncyCastle.Crypto;
|
||||||
using Org.BouncyCastle.Crypto.Parameters;
|
using Org.BouncyCastle.Crypto.Parameters;
|
||||||
using System.Security.Cryptography;
|
using System.Security.Cryptography;
|
||||||
|
using PSO2SERVER;
|
||||||
|
|
||||||
public static class KeyLoader
|
public static class KeyLoader
|
||||||
{
|
{
|
||||||
@ -51,4 +52,33 @@ public static class KeyLoader
|
|||||||
return rsa;
|
return rsa;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void SaveKeyToFile(string filePath, byte[] keyBlob)
|
||||||
|
{
|
||||||
|
using (FileStream outFile = File.Create(filePath))
|
||||||
|
{
|
||||||
|
outFile.Write(keyBlob, 0, keyBlob.Length);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ProcessKeyFiles(string pemFile, string blobFile, bool isPrivateKey, bool isGenerating)
|
||||||
|
{
|
||||||
|
if (File.Exists(pemFile) && !File.Exists(blobFile) && isGenerating)
|
||||||
|
{
|
||||||
|
Logger.Write("[KEY] 发现{0}文件, 正在生成新的{1}密钥 {2}...", pemFile, isPrivateKey ? "私有" : "公共", blobFile);
|
||||||
|
RSACryptoServiceProvider rsa = isPrivateKey ? LoadPrivateKeyFromPem(pemFile) : LoadPublicKeyFromPem(pemFile);
|
||||||
|
byte[] cspBlob = rsa.ExportCspBlob(isPrivateKey);
|
||||||
|
SaveKeyToFile(blobFile, cspBlob);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void GenerateAndSaveKeyIfNotExists(RSACryptoServiceProvider rsa, string keyBlobFile, bool isPrivateKey)
|
||||||
|
{
|
||||||
|
if (!File.Exists(keyBlobFile))
|
||||||
|
{
|
||||||
|
Logger.WriteWarning("[KEY] 未找到 {0} 文件, 正在生成新的{1}密钥...", keyBlobFile, isPrivateKey ? "私有" : "公共");
|
||||||
|
byte[] cspBlob = rsa.ExportCspBlob(isPrivateKey);
|
||||||
|
SaveKeyToFile(keyBlobFile, cspBlob);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -140,45 +140,9 @@ namespace PSO2SERVER
|
|||||||
Environment.Exit(0);
|
Environment.Exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SaveKeyToFile(string filePath, byte[] keyBlob)
|
Instance = new ServerApp();
|
||||||
{
|
|
||||||
using (FileStream outFile = File.Create(filePath))
|
|
||||||
{
|
|
||||||
outFile.Write(keyBlob, 0, keyBlob.Length);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (File.Exists(ServerPrivatePem) && !File.Exists(ServerPrivateKeyBlob))
|
Instance.GenerateKeys();
|
||||||
{
|
|
||||||
Logger.Write("[KEY] 发现私有密钥 {0} 文件, 正在生成新的私有密钥 {1}...", ServerPrivatePem, ServerPrivateKeyBlob);
|
|
||||||
RSACryptoServiceProvider rsaPrivate = KeyLoader.LoadPrivateKeyFromPem(ServerPrivatePem);
|
|
||||||
byte[] cspBlobPub2 = rsaPrivate.ExportCspBlob(false);
|
|
||||||
SaveKeyToFile(ServerPrivateKeyBlob, cspBlobPub2);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (File.Exists(ServerSEGAPem) && !File.Exists(ServerSEGAKeyBlob))
|
|
||||||
{
|
|
||||||
Logger.Write("[KEY] 发现SEGA公共密钥 {0} 文件, 正在生成新的公共密钥 {1}...", ServerSEGAPem, ServerSEGAKeyBlob);
|
|
||||||
RSACryptoServiceProvider rsaPublic = KeyLoader.LoadPublicKeyFromPem(ServerSEGAPem);
|
|
||||||
byte[] cspBlobPub2 = rsaPublic.ExportCspBlob(false);
|
|
||||||
SaveKeyToFile(ServerSEGAKeyBlob, cspBlobPub2);
|
|
||||||
}
|
|
||||||
|
|
||||||
RSACryptoServiceProvider rcsp = new RSACryptoServiceProvider();
|
|
||||||
|
|
||||||
if (!File.Exists(ServerPrivateKeyBlob))
|
|
||||||
{
|
|
||||||
Logger.WriteWarning("[KEY] 未找到 {0} 文件, 正在生成新的私有密钥...", ServerPrivateKeyBlob);
|
|
||||||
byte[] cspBlob = rcsp.ExportCspBlob(true);
|
|
||||||
SaveKeyToFile(ServerPrivateKeyBlob, cspBlob);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!File.Exists(ServerPublicKeyBlob))
|
|
||||||
{
|
|
||||||
Logger.WriteWarning("[KEY] 未找到 {0} 文件, 正在生成新的公共密钥...", ServerPublicKeyBlob);
|
|
||||||
byte[] cspBlobPub = rcsp.ExportCspBlob(false);
|
|
||||||
SaveKeyToFile(ServerPublicKeyBlob, cspBlobPub);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fix up startup message [KeyPhact]
|
// Fix up startup message [KeyPhact]
|
||||||
Logger.WriteHeader();
|
Logger.WriteHeader();
|
||||||
@ -188,9 +152,26 @@ namespace PSO2SERVER
|
|||||||
|
|
||||||
Thread.Sleep(1000);
|
Thread.Sleep(1000);
|
||||||
//System.Data.Entity.Database.SetInitializer(new System.Data.Entity.DropCreateDatabaseIfModelChanges<ServerEf>());
|
//System.Data.Entity.Database.SetInitializer(new System.Data.Entity.DropCreateDatabaseIfModelChanges<ServerEf>());
|
||||||
Instance = new ServerApp();
|
|
||||||
_ = Instance.StartAsync();
|
_ = Instance.StartAsync();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void GenerateKeys()
|
||||||
|
{
|
||||||
|
// Process private key files
|
||||||
|
KeyLoader.ProcessKeyFiles(ServerPrivatePem, ServerPrivateKeyBlob, true, File.Exists(ServerPrivatePem));
|
||||||
|
|
||||||
|
// Process SEGA public key files
|
||||||
|
KeyLoader.ProcessKeyFiles(ServerSEGAPem, ServerSEGAKeyBlob, false, File.Exists(ServerSEGAPem));
|
||||||
|
|
||||||
|
// Process general RSA keys
|
||||||
|
using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider())
|
||||||
|
{
|
||||||
|
// Process private and public RSA keys
|
||||||
|
KeyLoader.GenerateAndSaveKeyIfNotExists(rsa, ServerPrivateKeyBlob, true);
|
||||||
|
KeyLoader.GenerateAndSaveKeyIfNotExists(rsa, ServerPublicKeyBlob, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public async Task StartAsync()
|
public async Task StartAsync()
|
||||||
{
|
{
|
||||||
var startTime = DateTime.Now; // 记录启动开始时间
|
var startTime = DateTime.Now; // 记录启动开始时间
|
||||||
|
Loading…
Reference in New Issue
Block a user