Orl*_*era 4 .net c# asp.net web-services
我有个问题。我有一个网络服务,并且有一个“.p12”文件,我需要在我的网络服务中读取该文件来处理一些指令。读取“.p12”文件是必要的(该文件[已认证]允许我在我的域[谷歌电子邮件服务]中创建用户)
好吧,在我的机器中,Web 服务运行良好,但是当我在服务器中发布 Web 服务时,它不起作用。我已将文件 (.p12) 复制到 Web 服务的主文件夹中、bin 文件夹中、服务器的“C”单元中,但它不起作用。
这是读取文件的行(我使用的是 C#):
var certificate = new X509Certificate2(@"C:\\nameOfMyFile.p12", "notasecret", X509KeyStorageFlags.Exportable);
Run Code Online (Sandbox Code Playgroud)
它向我显示一个错误:服务器无法处理请求。---> 内部错误。
之后,我尝试了这个:
string hpath = HttpContext.Current.Server.MapPath(".");
hpath = hpath + "\\nameOfMyFile.p12";
var certificate = new X509Certificate2(System.Web.HttpContext.Current.Server.MapPath(hpath, "notasecret", X509KeyStorageFlags.Exportable);
Run Code Online (Sandbox Code Playgroud)
它向我显示了同样的错误:服务器无法处理请求。---> 内部错误。
之后,我只写文件名:
var certificate = new X509Certificate2(@"nameOfMyFile.p12", "notasecret", X509KeyStorageFlags.Exportable);
Run Code Online (Sandbox Code Playgroud)
它向我显示此错误:服务器无法处理请求。---> 系统找不到指定的文件
那么,我是否需要为文件、文件夹、Web 服务分配一项特殊权限?读取这样的文件(.p12)的最佳方法是什么?
提前致谢。
老实说,我不知道这是否是最好的方法,但它适用于我的情况。
添加这些命名空间:
using System.Security.Cryptography;
using System.Security.Cryptography.X509Certificates;
Run Code Online (Sandbox Code Playgroud)
我使用这段代码:
X509Certificate2 certificate = new X509Certificate2(@"file.p12", "password", X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.Exportable);
Run Code Online (Sandbox Code Playgroud)
最后我将“.p12”文件复制到Windows的“inetsrv”文件夹中。
| 归档时间: |
|
| 查看次数: |
8413 次 |
| 最近记录: |