帶"簽名"的請求接口實現

廢話少說,直接上代碼(⊙﹏⊙)html

 class Program
    {
        //簽名證書
        public static X509Certificate2 cerSigneCert;
        private static char[] hexChars;
        public Program()
        {
            cerSigneCert = new X509Certificate2(AppDomain.CurrentDomain.BaseDirectory + @"resources\20016100001118204.p12", "");
        }
        static void Main(string[] args)
        {
            string xml = "xml字符串 <SIGNED_MSG />";
            string newXML = SHA1withRSA(xml);
            string url = "訪問地址";
            string requestUrl = RequestUrl(url, newXML);

        }

        /// <summary>
        /// 簽名
        /// PS:(SIGNED_MSG是屬性的名稱)
        /// </summary>
        /// <param name="xml"></param>
        /// <returns></returns>
        private static string SHA1withRSA(string xml)
        {
            string oldXML = xml.Replace("<SIGNED_MSG />", "");
            SHA1CryptoServiceProvider sha1 = new SHA1CryptoServiceProvider();
            byte[] msg = sha1.ComputeHash(Encoding.GetEncoding("GBK").GetBytes(oldXML));

            RSAPKCS1SignatureFormatter signe = new RSAPKCS1SignatureFormatter();

            signe.SetKey(cerSigneCert.PrivateKey);//設置用於簽名的私鑰
            signe.SetHashAlgorithm("SHA1");
            var signeText = ToHex(signe.CreateSignature(msg));//建立簽名

            string newXML = xml.Replace("<SIGNED_MSG />", "<SIGNED_MSG>" + signeText + "</SIGNED_MSG>");
            return newXML;
        }

        private static string ToHex(byte[] ba)
        {
            if (ba == null) return "";
            char[]
                buf = new char[ba.Length * 2];

            int p = 0;
            foreach (byte b in ba)
            {
                buf[p++] = hexChars[b >> 4];
                buf[p++] = hexChars[b & 0x0f];
            }
            return new string(buf);
        }


        /// <summary>
        /// 發送請求,獲取響應
        /// </summary>
        /// <param name="url"></param>
        /// <param name="data"></param>
        /// <returns></returns>
        public static string RequestUrl(string url, string data)//發送方法
        {
            var request = WebRequest.Create(url) as HttpWebRequest;

            request.ProtocolVersion = HttpVersion.Version11;
            // 這裏設置了協議類型。
            request.KeepAlive = false;

            ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(RemoteCertificateValidate);
            ServicePointManager.CheckCertificateRevocationList = true;
            ServicePointManager.DefaultConnectionLimit = 100;
            ServicePointManager.Expect100Continue = false;

            request.Method = "post";
            request.ContentType = "text/xml";
            request.Headers.Add("charset:gbk");
            var encoding = Encoding.GetEncoding("GBK");

            if (data != null)
            {
                byte[] buffer = encoding.GetBytes(data);
                request.ContentLength = buffer.Length;
                request.GetRequestStream().Write(buffer, 0, buffer.Length);
            }
            else
            {

            }

            using (HttpWebResponse wr = request.GetResponse() as HttpWebResponse)
            {
                using (StreamReader reader = new StreamReader(wr.GetResponseStream(), encoding))
                {
                    string strResult = reader.ReadToEnd();
                    return strResult;
                }
            }
        }

        private static bool RemoteCertificateValidate(object sender, X509Certificate cert, X509Chain chain, SslPolicyErrors error)
        {
            System.Console.WriteLine("Warning, trust any certificate");
            //爲了經過證書驗證,老是返回true
            return true;
        }

    }

 有關XML轉換,你們請參考上一篇文章: http://www.javashuo.com/article/p-yarossea-be.htmlide

相關文章
相關標籤/搜索