cordova plugin x509store

本文关键字:x509store plugin cordova | 更新日期: 2023-09-27 18:07:42

我必须开发一个应用程序与cordova主要针对Windows平台。在这个应用程序中,我必须操作证书存储。长话短说,我必须做一个cordova插件(或者一个activeX技巧)。我在c#中创建了一个windows运行时组件,正如这里所解释的那样,使用X509Store(因为我需要windows)。我使用visual studio 2015制作了一个windows运行时组件项目(我尝试了通用窗口和8.1)。它工作,我可以调用c#方法在我的。js。

但是问题是:windows运行时组件项目没有命名空间System.Security.Cryptography.X509Certificates。所以我不能访问X509Store。

作为解决方法,我创建了一个Class库(。NetCore, .dll)调用X509Store并返回字符串,至少显示证书(json stringify)。一个经典的类库也可以访问x509store,但是当我在这个windows运行时组件项目中引用它时,它会产生目标错误。(可移植/通用的dll项目也没有X509Store)。我的.netcore dll工作,我在控制台应用程序(. netcore)项目中尝试了它,它显示了我的所有证书。但是当我从cordova应用程序(cordova app -> plugin -> runtime -> .netcore dll)调用它时,它是空的(没有找到证书,当前用户未定义)。我认为这是因为执行环境不一样(web应用vs主机应用)。我不认为这是一个好的解决方案(它甚至不起作用)。

那么,我如何访问windows运行时组件中的(windows用户的)证书存储?因为我认为javascript是不可能的。

感谢

p。S:如果需要的话,我可以提供一些源代码

编辑:
我忘记了在运行时项目中与。netcore dll存在汇编冲突,我通过引用plugin.xml文件(System.Runtime.dll等)中的正确dll来解决这个问题,因为我没有设法在visual studio

中解决它。
//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 Store",我使用Windows 10),然后添加.netcore dll,我得到了导致异常的冲突:

先。fileloadeexception:无法加载文件或程序集。运行时,版本=4.1.0.0,文化=中性,PublicKeyToken=b03f5f7f11d50a3a'或其依赖项之一。定位的程序集的清单定义与程序集引用不匹配。(Exception from HRESULT: 0x80131040)

(在cordova中,我通过引用System.Runtime.dll等来防止此异常…,来自NETStandard.Library.1.6.0的内核包。我一定错过了什么。netcore dll似乎不兼容,但windows运行时项目目标。netcore

EDIT 2: (solved)
Vcsjones的回答=无用的解决方法(从之前的编辑中没有问题)。但在任何情况下都存在安全问题,我必须在appxmanifest

cordova plugin x509store

中的功能中检查"共享用户证书"。

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

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