把官方提共的地方输入到地址栏里,然后回车,然后会出现这个对话框,我们只要单击查看证书,就行了,在后面出现的界面 里单击安装就可以了
如果要导出则选择“复制到文件” ==下一步 “Base64编码x.509 (.cer)(s)”选择这一项下一步完成就OK了。
然后把你的证书文件复制到一个位置方便使用。文件名假设为tingting.cer(cer表示证书文件);
像这样的程序一般只提共Java版的代码,那我们c#的怎么办呢,哎,不过经过今天下午的努力总算是出了,现在给大家分享一下经验;
看Java的代码不太明白 ,不过也能知道一些,现在是Wsdl文件要怎么得到呢?我是这样写的
代码
//请求的地址
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(”
https://www.cnblogs.com/sufei
“);
//创建证书文件
X509Certificate objx509 = new X509Certificate(Application.StartupPath + “\\tingting.cer”);
//添加到请求里
request.ClientCertificates.Add(objx509);
//User-AgentHTTP标头的值
request.UserAgent = “Client Cert Sample”;
request.Method = “POST”;
//读返回的流
StreamReader reader = new StreamReader(request.GetResponse().GetResponseStream());
//把得到的WSDL文件放到一个richTextBox1
this.richTextBox1.Text = reader.ReadToEnd();
Application.StartupPath + “tingting.cer/” 这里就是我们刚才导出的证书文件的地址,当然我们在实际应用中要写成自己的才行;
request.UserAgent = “Client Cert Sample”; User-AgentHTTP标头的值这个可以参考这里
http://support.microsoft.com/kb/895971
我直接把全部的代码拿下来吧,方便以后查询
代码
当 Web 服务器需要一个使用 HttpWebRequest 和 HttpWebResponse 类时,您可以发送客户端证书。 若要获取用于通过使用 HttpWebRequest 类发送客户端证书的证书,使用下列方法之一:
方法 1
使用 x509 证书 类来读取从.cer 文件的证书,然后将 ClientCertificates 属性设置。
方法 2
使用 CryptoAPI 调用来从证书存储获得证书,然后将 x509 证书 类设置为接收从证书存储区的证书。 然后,您可以设置 ClientCertificates 属性。
回到顶端
发送客户端证书的要求
可与 ASP.NET 应用程序时确保完成以下要求:
LOCAL_MACHINE 注册表配置单元中并不在 CURRENT_USER 注册表配置单元中,必须安装客户端证书。 若要确认客户端证书的安装位置,请按照下列步骤操作:
单击 开始、 单击 运行,键入 mmc,然后单击 确定。
在 文件 菜单上单击 添加/删除管理单元。
在 添加/删除管理单元 对话框中单击 添加。
在 添加独立管理单元 对话框中单击 证书,然后单击 添加。
在 证书管理单元 对话框中单击 计算机帐户,然后单击 下一步
在 选择计算机 对话框中单击 完成。
在 添加独立管理单元 对话框中单击 关闭,然后单击 确定。
展开 证书 (本地计算机),展开 个人,然后单击 证书。
在右窗格中应列出客户端证书。
您必须授予 ASP.NET 用户客户端证书的私钥的帐户权限。 若要为 ASP.NET 用户授予客户端证书的私钥的帐户权限,使用 WinHttpCertCfg.exe 工具。有关详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
823193 (
http://support.microsoft.com/kb/823193/
) 如何获得 Windows HTTP 5.1 证书和跟踪工具
有关如何使用此工具,请访问下面的 Microsoft 开发人员网络 (MSDN) 的网站的详细信息:
WinHttpCertCfg.exe,证书配置工具
http://msdn2.microsoft.com/en-us/library/aa384088.aspx
(
http://msdn2.microsoft.com/en-us/library/aa384088.aspx
)
回到顶端
使用.cer 文件
方法 1 是易于使用,但方法要求您具有一个.cer 文件。 如果您没有安装的.cer 文件,使用 Microsoft Internet 资源管理器导出.cer 文件。
下列源代码介绍如何获取证书从一个.cer 文件您可以使用 HttpWebRequest class.
//Uncomment the following code if you need a proxy. The boolean true is used to bypass the local address.
//WebProxy proxyObject = new WebProxy(“Your Proxy value”,true);
//GlobalProxySelection.Select = proxyObject;
// Obtain the certificate.
try
{
//You must change the path to point to your .cer file location.
X509Certificate Cert = X509Certificate.CreateFromCertFile(“C:\\mycert.cer”);
// Handle any certificate errors on the certificate from the server.
ServicePointManager.CertificatePolicy = new CertPolicy();
// You must change the URL to point to your Web server.
HttpWebRequest Request = (HttpWebRequest)WebRequest.Create(”
https://YourServer/sample.asp
“);
Request.ClientCertificates.Add(Cert);
Request.UserAgent = “Client Cert Sample”;
Request.Method = “GET”;
HttpWebResponse Response = (HttpWebResponse)Request.GetResponse();
// Print the repsonse headers.
Console.WriteLine(“{0}”,Response.Headers);
Console.WriteLine();
// Get the certificate data.
StreamReader sr = new StreamReader(Response.GetResponseStream(), Encoding.Default);
int count;
char [] ReadBuf = new char[1024];
do
{
count = sr.Read(ReadBuf, 0, 1024);
if (0 != count)
{
Console.WriteLine(new string(ReadBuf));
}
}while(count > 0);
}
catch(Exception e)
{
Console.WriteLine(e.Message);
}
//Implement the ICertificatePolicy interface.
class CertPolicy: ICertificatePolicy
{
public bool CheckValidationResult(ServicePoint srvPoint,
X509Certificate certificate, WebRequest request, int certificateProblem)
{
// You can do your own certificate checking.
// You can obtain the error values from WinError.h.
// Return true so that any certificate will work with this sample.
return true;
}
}
使用 CryptoAPI 调用
如果您必须获取该证书从证书存储区,CryptoAPI 函数用于在获取该证书,然后将其存储在 x509 证书 类对象。 X509CertificateCollection 类枚举存储区中的所有证书,然后将其置于 X509CertificateCollection 类对象中。
如果想获得特定的证书,必须更改类代码,以使用 CertFindCertificateInStore 函数获取特定的证书。 Wincrypt.h 的文件中声明该函数。 鎴栬 € 咃,您可以枚举 X509CertificateCollection 函数,以查找所需的证书。
下面的代码示例使用从 CertEnumCertificatesInStore 函数返回集合中的第一个证书
using System;
using System.Net;
using System.IO;
using System.Text;
using System.Security.Cryptography;
using System.Security.Cryptography.X509Certificates;
using System.Runtime.InteropServices;
namespace SelectClientCert
{
/// Sample that describes how how to select client cetificate and send it to the server.
class MyCerts{
private static int CERT_STORE_PROV_SYSTEM = 10;
private static int CERT_SYSTEM_STORE_CURRENT_USER = (1 << 16);
///private static int CERT_SYSTEM_STORE_LOCAL_MACHINE = (2 << 16);
[DllImport(“CRYPT32″, EntryPoint=”CertOpenStore”, CharSet=CharSet.Unicode, SetLastError=true)]
public static extern IntPtr CertOpenStore(
int storeProvider, int encodingType,
int hcryptProv, int flags, string pvPara);
[DllImport(“CRYPT32″, EntryPoint=”CertEnumCertificatesInStore”, CharSet=CharSet.Unicode, SetLastError=true)]
public static extern IntPtr CertEnumCertificatesInStore(
IntPtr storeProvider,
IntPtr prevCertContext);
[DllImport(“CRYPT32″, EntryPoint=”CertCloseStore”, CharSet=CharSet.Unicode, SetLastError=true)]
public static extern bool CertCloseStore(
IntPtr storeProvider,
int flags);
X509CertificateCollection m_certs;
public MyCerts(){
m_certs = new X509CertificateCollection();
}
public int Init()
{
IntPtr storeHandle;
storeHandle = CertOpenStore(CERT_STORE_PROV_SYSTEM, 0, 0, CERT_SYSTEM_STORE_CURRENT_USER, “MY”);
IntPtr currentCertContext;
currentCertContext = CertEnumCertificatesInStore(storeHandle, (IntPtr)0);
int i = 0;
while (currentCertContext != (IntPtr)0)
{
m_certs.Insert(i++, new X509Certificate(currentCertContext));
currentCertContext = CertEnumCertificatesInStore(storeHandle, currentCertContext);
}
CertCloseStore(storeHandle, 0);
return m_certs.Count;
}
public X509Certificate this [int index]
{
get
{
// Check the index limits.
if (index < 0 || index > m_certs.Count)
return null;
else
return m_certs[index];
}
}
};
class MyHttpResource
{
String m_url;
public MyHttpResource(string url){
m_url = url;
}
public void GetFile(){
HttpWebResponse result = null;
try{
HttpWebRequest req = (HttpWebRequest)WebRequest.Create(m_url);
req.Credentials = CredentialCache.DefaultCredentials;
///Method1
//req.ClientCertificates.Add(X509Certificate.CreateFromCertFile(“D:\\Temp\\cert\\c1.cer”));
///Method2
///Uses interop services
MyCerts mycert = new MyCerts();
if(mycert.Init() > 0)
req.ClientCertificates.Add(mycert[0]);
result = (HttpWebResponse)req.GetResponse();
Stream ReceiveStream = result.GetResponseStream();
Encoding encode = System.Text.Encoding.GetEncoding(“utf-8”);
StreamReader sr = new StreamReader( ReceiveStream, encode );
Console.WriteLine(“\r\nResponse stream received”);
Char[] read = new Char[256];
int count = sr.Read( read, 0, 256 );
Console.WriteLine(“HTTP Response…\r\n”);
while (count > 0)
{
String str = new String(read, 0, count);
Console.Write(str);
count = sr.Read(read, 0, 256);
}
}
catch(WebException e)
{
Console.WriteLine(“\r\nError:”);
#if (DEBUG)
Console.WriteLine(e.ToString());
#else
Console.WriteLine(e.Message);
#endif
}
finally
{
if ( result != null ) {
result.Close();
}
}
}
}
class CertSample
{
static void Main(string[] args)
{
try
{
if (args.Length < 1)
{
Console.WriteLine(“No url is entered to download, returning.\n”);
Console.WriteLine(“Usage: CertSample <urltoget>\n”);
Console.WriteLine(” e.g: CertSample
https://servername
\n”);
return;
}
MyHttpResource hr = new MyHttpResource(args[0]);
hr.GetFile();
}
catch(Exception e)
{
Console.WriteLine(e.ToString());
}
return;
}
}
}
参考有关详细信息请访问下面的 Microsoft 开发网络 (MSDN) 网站: x509 证书类
http://msdn2.microsoft.com/en-us/
…有关详细信息请访问下面的 Microsoft 开发网络 (MSDN)
x509 证书类
http://msdn2.microsoft.com/en-us/library/system.security.cryptography.x509certificates.x509certificate(vs.71).aspx
(
http://msdn2.microsoft.com/en-us/library/system.security.cryptography.x509certificates.x509certificate(vs.71).aspx
)
我们接着说,WSDL文件是得如下
代码
<?xml version=”1.0″ encoding=”UTF-8″?>
……..
可是我们想一下这是一个Xml文件,我们应该怎么使用他呢,如果 是Webservce相信大家都 知道 怎么使用,直接添加引用就可以,但这里是一个Wsdl的XMl文件,我们得把他转化成一个类文件才行,
方法很简单,这是在我知道 了之后才这样讲的,呵呵
利用wsdl.exe生成webservice代理类:
根据提供的wsdl生成webservice代理类
1、开始->程序->Visual Studio 2008 命令提示
2、输入如下红色标记部分
D:\Program Files\Microsoft Visual Studio 8\VC>wsdl /language:c# /n:TestDemo /out:d:\text\TestService.cs D:\text\TestService.wsdl
在d:/text下就会产生一个TestService.cs 文件
注意:D:\text\TestService.wsdl 是wsdl路径,可以是url路径:
https://www.cnblogs.com/sufei/?wsdl
如果 你想知道WSDL文件是怎么使用的话,直接写WSDL回车就可以,会出显所有的说明,呵呵
还有一个方法更方便
首先打开Visual Studio 2008,选择菜单”工具”-“外部工具”打开外部工具对话框,如图
,单击“添加”按钮添加新工具,然后在“标题”行中输入”WSDL生成代理类”,”命令”行中输入”C:\Program Files\Microsoft Visual Studio 8\SDK\v2.0\Bin\wsdl.exe”(wsdl.exe文件的路径),”参数”行中输入”/l:cs /out:”, 单击”初始目录”行右边的三角按钮选择”项目录”,勾选”使用输出窗口”和”提示输入参数”,然后确定保存。
再打开菜单”工具”可以看到多了一个”WSDL生成代理类”菜单,这时先选定一个存放生成的代理类的文件夹(必须位于并且包含于当前解决方案中),然后单击”WSDL生成代理类”菜单,弹出如下对话框,然后你只需在”/l:cs /out:”后面空一格(必须空一格)再粘贴WebService文件的http地址如
https://www.cnblogs.com/sufei?wsdl
,单击”确定”看看发生了什么?是的,输出窗口会显示生成了一个类及其存放的位置,看看是不是你选定的文件夹,找到这个路径看看是不是有一个类,你会发现这个类跟上面使用命令行生成的类一模一样,个人觉得这样操作起来更简单一点。
这段是来自己
http://blog.sina.com.cn/s/blog_48964b120100fz14.html
在这里谢谢了
到这里我们应该好办多了,生成的类文件里会包括 方法使用和怎么样和服务器沟通,我们只要调用 方法就要可以了,
类文件如下
代码
//——————————————————————————
// <auto-generated>
// 此代码由工具生成。
// 运行库版本:2.0.50727.1873
//
// 对此文件的更改可能会导致不正确的行为,并且如果
// 重新生成代码,这些更改将会丢失。
// </auto-generated>
//——————————————————————————
//
// 此源代码由 wsdl 自动生成, Version=2.0.50727.1432。
//
namespace WSDLServices
{
using System.Diagnostics;
using System.Web.Services;
using System.ComponentModel;
using System.Web.Services.Protocols;
using System;
using System.Xml.Serialization;
/// <remarks/>
[System.CodeDom.Compiler.GeneratedCodeAttribute(“wsdl”, “2.0.50727.1432”)]
[System.Diagnostics.DebuggerStepThroughAttribute()]
[System.ComponentModel.DesignerCategoryAttribute(“code”)]
[System.Web.Services.WebServiceBindingAttribute(Name=”nciicGetConditionHttpBinding”, Namespace=”
https://http://www.cnblogs.com/sufei/nciicGetCondition
“)]
public partial class nciicGetCondition : System.Web.Services.Protocols.SoapHttpClientProtocol {
private System.Threading.SendOrPostCallback nciicDiscernOperationCompleted;
private System.Threading.SendOrPostCallback nciicCheckChinaOperationCompleted;
private System.Threading.SendOrPostCallback CallnciicGetConditionOperationCompleted;
private System.Threading.SendOrPostCallback nciicExactSearchOperationCompleted;
private System.Threading.SendOrPostCallback nciicCourtOperationCompleted;
private System.Threading.SendOrPostCallback nciicBirthplaceCompareOperationCompleted;
private System.Threading.SendOrPostCallback nciicAddrExactSearchOperationCompleted;
private System.Threading.SendOrPostCallback nciicCheckOperationCompleted;
private System.Threading.SendOrPostCallback nciicCompareOperationCompleted;
private System.Threading.SendOrPostCallback nciicCombineSearchOperationCompleted;
/// <remarks/>
public nciicGetCondition() {
this.Url = ”
http://http://www.cnblogs.com/sufei/nciic_ws/services/nciicGetCondition
“;
}
…..}
}
有了这个类,最后一步就是怎么样来实现调取数据了,
代码
try
{
//授权文件内容建议以后放在数据库或是文件里而且要加密
string inliance = @”文件内容”;
//生成的WSDL类()
nciicGetCondition objText = new nciicGetCondition();
//基础URL建议加密和写在文件中
objText.Url = ”
https://www.cnblogs.com/sufei
“;
//编码
objText.RequestEncoding = Encoding.UTF8;
//创建证书文件
X509Certificate objx509 = new X509Certificate(Application.StartupPath + “\\tingting.cer”);
//证书
objText.ClientCertificates.Add(objx509);
//方式可有可无
objText.UserAgent = “Client Cert Sample”;
//读XML文件
string inConditions = File.ReadAllText(Application.StartupPath + “\\XMLFile1.xml”);
//Text文件
this.richTextBox1.Text = objText.nciicCheck(inliance, inConditions);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
到这里我们已经和服务器沟通上了,把回的结果集的格式 跟文档中的一样,我们自己去解析就行了,这里为了保证公司的利益就不再多写了。
结果取出来如下:
代码
//转图片的方法
public Image Base64ToImage(string base64String)
{
byte[] imageBytes = Convert.FromBase64String(base64String);
MemoryStream ms = new MemoryStream(imageBytes, 0,
imageBytes.Length);
ms.Write(imageBytes, 0, imageBytes.Length);
System.Drawing.Image image = System.Drawing.Image.FromStream(ms, true);
return image;
}
//取返回的信息结果
private void button4_Click(object sender, EventArgs e)
{
XmlDocument objXml = new XmlDocument();
//文件在Bin目录下
objXml.Load(Application.StartupPath + “\\XML.xml”);
//身份证号
textBox1.Text = objXml.SelectSingleNode(“//gmsfhm”).InnerText;
//姓名
textBox2.Text = objXml.SelectSingleNode(“//xm”).InnerText;
//身份证号是否一样
textBox4.Text = objXml.SelectSingleNode(“//result_gmsfhm”).InnerText;
//姓名是否一样
textBox3.Text = objXml.SelectSingleNode(“//result_xm”).InnerText;
//取图片
string bas64 = objXml.SelectSingleNode(“//xp”).InnerText;
//显示图片
pictureBox1.Image = Base64ToImage(bas64);
}
原文来自:雨枫技术教程网
http://www.fengfly.com
原文网址:
http://www.fengfly.com/plus/view-171681-1.html
在使用的过程 中我又碰到了一个很棘手的问题这是我的代码
//官方查询结果xml
[WebMethod ]
public OrderNciis GetNciisResult(string onName, string onId)
{
//获取授权文件
string inLicense = LotteryMethods.GetContext(11);
//生成的WSDL类()
nciicGetCondition objText = new nciicGetCondition();
//获取基础URL
objText.Url = LotteryMethods.GetContext(12);
//编码
objText.RequestEncoding = Encoding.UTF8;
//创建证书文件
X509Certificate objx509 = new X509Certificate(System.Configuration.ConfigurationSettings.AppSettings[“cd”].ToString().Trim());
//证书
objText.ClientCertificates.Add(objx509);
//方式可有可无
objText.UserAgent = “Client Cert Sample”;
//读XML文件
string inConditions = OrderNciisXml(onName, onId);
//返回查询结果XML
OrderNciis model = new OrderNciis();
model.onLottery = objText.nciicCheck(inLicense, inConditions);
return model;
}
代码应该是没有问题,在本地的Vs里测试没有问题,如果在ISS里使用时报基础连接已经关闭: 未能为 SSL/TLS 安全通道建立信任关系”证书验证失败
城刚开始我还以为是文章路径的问题,结果不是,
接着找,后来认为是IIS里配置问题,还是不对,后来,看到 网上也有很多这的问题,但是没有真正解决的,一般都 是在说怎么生成代理类,还有带有证书的过程
我想了想,还是自己想办法解决吧,我把代理类分析了一下才知道 ,原来证书是在代理类里验证的,验证后会返回一个值 表示是否通过,这就好看了,
我们定义一个方法
private static bool RemoteCertificateValidate(object sender, X509Certificate cert, X509Chain chain, SslPolicyErrors error){
// trust any certificate!!!
System.Console.WriteLine(“Warning, trust any certificate”);
//为了通过证书验证,总是返回true
return true;
}
只要这个方法返回为True不就完了吗?呵呵
还需要几个命名空间
using System.Net;
using System.Net.Security;
using System.Security.Authentication;
using System.Security.Cryptography.X509Certificates;
这个应该在什么时候调用呢,当然 是在构造器里合适些
/// <remarks/>
public nciicGetCondition()
{
//验证服务器证书回调自动验证
ServicePointManager.ServerCertificateValidationCallback += RemoteCertificateValidate;
}
原文来自:雨枫技术教程网
http://www.fengfly.com
原文网址:
http://www.fengfly.com/plus/view-172302-1.html
转载于:https://www.cnblogs.com/zhaoyong/archive/2010/06/01/1749477.html