我必须使用cordova开发一款主要针对Windows平台的应用。 在这个应用程序中,我必须操纵认证商店。长话短说,我必须做一个cordova插件(或者也许是一个activeX技巧)。 我在C#中创建了一个Windows运行时组件,如here所述,使用X509Store(因为我需要Windows)。 我使用visual studio 2015来制作一个Windows运行时组件项目(我尝试了通用窗口和8.1)。它有效,我可以在我的.js中调用C#方法。
但问题是:Windows运行时组件项目没有命名空间System.Security.Cryptography.X509Certificates。所以我无法访问X509Store。
作为一种解决方法,我创建了一个类库(.NetCore,.dll),它调用X509Store并返回字符串,至少显示证书(json stringify)。经典类库也可以访问x509store,但是当我在这个Windows运行时组件项目中引用它时会出现目标错误。 (便携/通用DLL项目既没有X509Store也没有)。我的.netcore dll有效,我在一个控制台应用程序(.NetCore)项目中尝试了它,它显示了我所有的证书。但是当我从cordova app(cordova app - >插件 - > runtime - > .netcore dll)调用它时它是空的(没有找到证书,并且当前用户未定义)。我认为这是因为执行上下文不一样(webapp vs console app)。而且我认为这不是一个好的解决方案(它甚至不起作用)。
那么,如何在Windows运行时组件中访问(windows用户的)认证存储?因为我不认为使用javascript可以。
由于
P.S:如果需要,我可以提供一些源代码
编辑:
我忘了运行时项目中有一个与.netcore dll的程序集冲突,我通过引用plugin.xml文件(System.Runtime.dll等等)中的正确dll解决了这个问题,因为我没有设法解决它在视觉工作室
//script inside cordova, called after device ready
signatureplugin.getAllCertNames(function(a) { }, function(a) { }, 0);
//signatureplugin.js
var exec = require('cordova/exec');
module.exports = {
getAllCertNames: function(successCallback, errorCallback, args) {
exec(successCallback, errorCallback, "SignaturePlugin", "getAllCertNames", [args]);
}
};
//signaturepluginProxy.js
module.exports = {
getAllCertNames: function(successCallback, errorCallback, args) {
var res = SignerVerifier.PluginRT.getAllCertNames();
for (var i = 0, len = res.length; i < len; i++) {
alert(res[i]);
}
}
};
require("cordova/exec/proxy").add("SignaturePlugin", module.exports);
//windows runtime component
using CertStore;
namespace SignerVerifier
{
public sealed class PluginRT
{
public static string[] getAllCertNames()
{
var certStore = new StoreManager();
var res = certStore.getAllCertificates();
return res;
}
}
}
//.NetCore dll
using System.Collections.Generic;
using System.Security.Cryptography.X509Certificates;
using Newtonsoft.Json;
using System;
namespace CertStore
{
public class StoreManager
{
private X509Store store;
public StoreManager()
{
store = new X509Store(StoreName.My, StoreLocation.CurrentUser);
}
public string[] getAllCertificates()
{
List<string> res = new List<string>();
store.Open(OpenFlags.ReadOnly);
var certificates = store.Certificates;
foreach (var cert in certificates)
{
res.Add(JsonConvert.SerializeObject(cert));
}
store.Dispose();
return res.ToArray();
}
}
}
如果我做一个javascript空白应用程序项目+ Windows运行时组件项目(项目来自&#34;通用&#34;,我没有&#34; Windows Store&#34;我使用的是Windows 10)然后添加.netcore dll我得到了导致异常的冲突:
System.IO.FileLoadException:无法加载文件或程序集System.Runtime,Version = 4.1.0.0,Culture = neutral,PublicKeyToken = b03f5f7f11d50a3a&#39;或其中一个依赖项。定位的程序集的清单定义与程序集引用不匹配。 (HRESULT异常:0x80131040)
(在cordova中我通过引用System.Runtime.dll等来防止此异常,来自.netcore中使用的nuget包NETStandard.Library.1.6.0) 我必须错过一些东西。 .NetCore dll似乎不兼容,但是Windows运行时项目目标.NetCore
编辑2 :(已解决)
vcsjones的回答=解决方法没用(并且上一次编辑没有问题)。
但是在任何情况下都存在安全问题,我必须检查&#34;共享用户证书&#34;在appxmanifest中的功能
答案 0 :(得分:0)
WinRT的证书管理与Desktop和Core框架不同。对于WinRT,您将使用Windows.Security
命名空间。
您可以使用Windows.Security.Cryptography.Certificates.CertificateStore
类打开并管理证书存储区。