繁体   English   中英

cordova插件x509store

[英]cordova plugin x509store

我必须使用主要面向Windows平台的cordova开发一个应用程序。 在这个应用程序中,我必须操纵认证商店。 长话短说,我必须做一个cordova插件(或一个activeX技巧)。 我做在C#中的Windows运行时组件,如解释在这里 ,使用的X509Store(因为我需要的Windows)。 我使用Visual Studio 2015制作了Windows运行时组件项目(我尝试使用通用Windows和8.1)。 它可以工作,我可以在.js中调用C#方法。

但是问题是:Windows运行时组件项目没有名称空间System.Security.Cryptography.X509Certificates。 因此,我无法访问X509Store。

作为一种解决方法,我制作了一个类库(.NetCore,.dll),该类库调用X509Store并返回字符串,至少显示证书(json字符串化)。 经典类库也可以访问x509store,但是当我在此Windows运行时组件项目中引用它时,它将产生目标错误。 (便携式/通用dll项目也没有X509Store)。 我的.netcore dll有效,我在控制台应用程序(.NetCore)项目中尝试了它,并显示了我所有的证书。 但是,当我从cordova应用程序(cordova应用程序->插件->运行时-> .netcore dll)调用它时,它是空的(未找到证书,并且当前用户未定义)。 我认为这是因为执行上下文不同(Web应用程序与控制台应用程序)。 而且我认为这不是一个很好的解决方案(甚至不起作用)。

因此,如何在Windows运行时组件中访问(Windows用户的)证书存储? 由于我认为使用javascript不可能。

谢谢

PS:如果需要,我可以提供一些源代码

编辑:
我忘记了在运行时项目中存在与.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运行时组件项目(“通用”项目,则没有“ Windows应用商店”,而我使用Windows 10),然后添加.netcore dll,我得到了导致异常的冲突:

System.IO.FileLoadException:无法加载文件或程序集'System.Runtime,版本= 4.1.0.0,区域性=中性,PublicKeyToken = b03f5f7f11d50a3a'或其依赖项之一。 找到的程序集的清单定义与程序集引用不匹配。 (来自HRESULT的异常:0x80131040)

(在cordova中,我通过.netcore中使用的nuget包NETStandard.Library.1.6.0引用System.Runtime.dll等来防止此异常),我必须错过一些东西。 .NetCore dll似乎不兼容,但是Windows运行时项目的目标是.NetCore

编辑2 :(已解决)
vcsjones的答案=解决方法没有用(并且以前的编辑没有问题)。 但是在任何情况下都存在安全问题,我必须在appxmanifest的功能中检查“共享用户证书”

WinRT进行的证书管理与桌面和核心框架不同。 对于WinRT,您将使用Windows.Security命名空间。

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM