cordova插件x509store

时间:2016-09-19 09:53:57

标签: javascript c# windows cordova .net-core

我必须使用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中的功能

1 个答案:

答案 0 :(得分:0)

WinRT的证书管理与Desktop和Core框架不同。对于WinRT,您将使用Windows.Security命名空间。

您可以使用Windows.Security.Cryptography.Certificates.CertificateStore类打开并管理证书存储区。