关联的代码在独立的控制台应用程序中可以很好地工作,而在尝试使之运行时却在NSB体系结构中出错。我试过在worker中进行相同的测试,也尝试在测试控制台应用程序中进行独立测试。无论哪种情况,它都会出错-X509Certificate2证书=新的X509Certificate2(filePath,“ *** key *** UeUHFxS”); 异常消息是- System.Security.Cryptography.CryptographicException:'系统找不到指定的文件。 该代码包括一个,如图所示,还包括一个与Activate设备相关的帮助文件。但是,从pfx文件路径和密钥初始化X509Certificate2的部分例外。
class Program
{
static void Main(string[] args)
{
try
{
string filePath = Path.GetDirectoryName(System.AppDomain.CurrentDomain.BaseDirectory);
filePath = Directory.GetParent(Directory.GetParent(filePath).FullName).FullName;
filePath = Path.Combine(filePath, @"Cert\TestCompany-qa.partner.client.siriusxm.com.pfx");
X509Certificate2 certificate = new X509Certificate2(filePath, "****key****");
SoapMessageHelper soapHelper = new SoapMessageHelper(certificate, @"https://api-ext-test.siriusxm.com/SAT/UpdateDeviceSatRefresh/v_1");
var test = soapHelper.ActivateDevice(new ActivateDeviceRequest()
{
SourceName = "12493",
ESN = "W26890HW",
TimeStamp = DateTime.UtcNow,
TrasanctionId = System.Guid.NewGuid().ToString()
});
XmlDocument doc = new XmlDocument();
doc.LoadXml(test);
foreach (XmlNode node in doc.DocumentElement.ChildNodes)
{
foreach (XmlNode locNode in node)
{
if (locNode.Name == "ns0:responseRefreshDevice")
{
string resultCode = locNode["ns0:resultCode"].InnerText;
string errorCode = locNode["ns0:errorCode"].InnerText;
string errorMessage = locNode["ns0:errorMessage"].InnerText;
Console.WriteLine(resultCode + errorCode + errorMessage);
}
}
}
}
catch (Exception ex)
{
Console.WriteLine(
String.Format("Exception occurred{0}Message:{1}{2}Inner Exception: {3}", Environment.NewLine, ex.Message, Environment.NewLine, ex.InnerException));
}
}
}
答案 0 :(得分:1)
让我们尝试将您的构造函数修改为:
X509Certificate2 certificate = new X509Certificate2(filePath, key,
X509KeyStorageFlags.MachineKeySet
| X509KeyStorageFlags.PersistKeySet
| X509KeyStorageFlags.Exportable);
使用MachineKeySet作为msdn表示:
“私钥存储在本地计算机存储区中,而不是 当前的用户商店。 “
答案 1 :(得分:1)
提供绝对路径而不是相对路径确实有所帮助。提供相对路径的目的是将证书包括在构件中,并且当应用程序部署到服务器时,证书将被写入输出路径,并从该位置读取。 但是,尽管当前将证书属性设置为始终复制,但是在尝试测试当前代码时,我发现只有绝对路径在起作用。工作代码现在看起来像-
filePath = @"C:\Users\rakesh\Documents\TestCompany-qa.partner.client.siriusxm.com.pfx";
X509Certificate2 certificate = new X509Certificate2(filePath, "****key****");
因此,作为变通办法,需要知道在其中部署应用程序的服务器中的路径以及证书的位置,以继续进行。