现在的位置: 首页 > 综合 > 正文

linux下访问https协议做法

2012年02月18日 ⁄ 综合 ⁄ 共 2190字 ⁄ 字号 评论关闭

一、http://www.mono-project.com/FAQ:_Security

1、inux本身在发行的时候是不带任何证书的,这和windows平台似乎恰恰相反。不过有工具,允许我们自行安装证书。

 

                  mozroots --import /               ##导入证书

 

                    --ask-remove  /       ##仅删除时确认

 

                    --machine               ##保存在全局环境

 

              

mozroots --import  --sync

或者手动加入证书

certmgr -ssl https://t.open.com

2是直接在程序中加入代码默认此https协议是正确的

using System;
using System.Security.Cryptography.X509Certificates;


namespace SSLtest
{
    
    class MainClass
    {
        
        // callback used to validate the certificate in an SSL conversation
        private static bool ValidateRemoteCertificate(
            object sender,
            X509Certificate certificate,
            X509Chain chain,
            System.Net.Security.SslPolicyErrors policyErrors
        )
        {
            
            return true;
            /*
            if (Convert.ToBoolean(ConfigurationManager.AppSettings["IgnoreSslErrors"]))
            {
                // allow any old dodgy certificate...
                return true;
            }
            else
            {
                return policyErrors == SslPolicyErrors.None;
            }
            */
        } // End Function ValidateRemoteCertificate

        
        public static void Main (string[] args)
        {
            //System.Net.ServicePointManager.ServerCertificateValidationCallback += ValidateRemoteCertificate;
            System.Net.ServicePointManager.ServerCertificateValidationCallback += (s,ce,ca,p) => true;
            
            string strResponse = null;
            try 
            {
                System.Net.WebRequest request = System.Net.HttpWebRequest.Create("https://encrypted.google.com/");
                System.Net.HttpWebResponse response = (System.Net.HttpWebResponse) request.GetResponse();
                System.IO.Stream stream = response.GetResponseStream();
                System.IO.StreamReader sr = new System.IO.StreamReader(stream);
                strResponse = sr.ReadToEnd();
                sr.Close();
                sr.Dispose();
                stream.Dispose();
            }
            catch(System.IO.IOException ex) 
            { 
                Console.WriteLine("Failed to connect to URI"); 
                Console.WriteLine("Reason:"); 
                Console.WriteLine(ex.Message);
                Console.WriteLine(Environment.NewLine);
                Console.WriteLine("Stacktrace:"); 
                Console.WriteLine(ex.StackTrace); 
            }
            catch(System.UriFormatException ex) 
            { 
                Console.WriteLine("Bad URI format"); 
                
                Console.WriteLine("Reason:"); 
                Console.WriteLine(ex.Message); 
                Console.WriteLine(Environment.NewLine);
                Console.WriteLine("Stacktrace:"); 
                Console.WriteLine(ex.StackTrace); 
            }
        
            Console.WriteLine ("Read the following stream:");
            Console.WriteLine(strResponse);
            Console.WriteLine(Environment.NewLine);
            Console.WriteLine(" --- Press any key to continue --- ");
            Console.ReadKey();
        } // End Sub Main 
        
        
    } // End Class MainClass
    
    
} // End Namespace SSLtest

 

 

抱歉!评论已关闭.