C# 获取社会统一信用代码
时间:2019-03-14
本文章向大家介绍C# 获取社会统一信用代码,主要包括C# 获取社会统一信用代码使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
时间不多,废话少说:
网络请求代码如下:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Net.Security; using System.Security.Cryptography.X509Certificates; using System.DirectoryServices.Protocols; using System.ServiceModel.Security; using System.Net; using System.IO; using System.IO.Compression; using System.Text.RegularExpressions; using System.Threading; namespace Meeting.Common { /// <summary> /// 有关HTTP请求的辅助类 /// </summary> public class HttpWebResponseUtility { public static string GetUrl(string url) { if (url.StartsWith("https", StringComparison.OrdinalIgnoreCase)) { System.Console.WriteLine("https connections....."); ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(CheckValidationResult); // 这里设置了协议类型。 //ServicePointManager.SecurityProtocol =SecurityProtocolType.Tls12;// (SecurityProtocolType)3072;// SecurityProtocolType.Tls1.2; ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12; //(SecurityProtocolType)768 | (SecurityProtocolType)3072 ServicePointManager.CheckCertificateRevocationList = true; ServicePointManager.DefaultConnectionLimit = 1000; ServicePointManager.Expect100Continue = false; } HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest; //增加下面两个属性即可 request.KeepAlive = false; request.ProtocolVersion = HttpVersion.Version10; request.Method = "GET"; //使用get方式发送数据 request.ContentType = "application/x-www-form-urlencoded"; request.Referer = ""; request.AllowAutoRedirect = true; request.UserAgent = "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2; .NET CLR 1.1.4322; .NET CLR 2.0.50727)"; request.Accept = "*/*"; //获取网页响应结果 HttpWebResponse response = (HttpWebResponse)request.GetResponse(); // Thread.Sleep(2000); Stream stream = response.GetResponseStream(); //client.Headers.Add("Content-Type", "application/x-www-form-urlencoded"); string result = string.Empty; using (StreamReader sr = new StreamReader(stream)) { result = sr.ReadToEnd(); } if (request != null) { request.Abort(); } if (response != null) { response.Close(); } return result; } private static readonly string DefaultUserAgent = "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)"; /// <summary> /// 创建GET方式的HTTP请求 /// </summary> /// <param name="url">请求的URL</param> /// <param name="timeout">请求的超时时间</param> /// <param name="userAgent">请求的客户端浏览器信息,可以为空</param> /// <param name="cookies">随同HTTP请求发送的Cookie信息,如果不需要身份验证可以为空</param> /// <returns></returns> public static HttpWebResponse CreateGetHttpResponse(string url, int? timeout, string userAgent, CookieCollection cookies) { if (string.IsNullOrEmpty(url)) { throw new ArgumentNullException("url"); } HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest; request.Method = "GET"; request.UserAgent = DefaultUserAgent; if (!string.IsNullOrEmpty(userAgent)) { request.UserAgent = userAgent; } if (timeout.HasValue) { request.Timeout = timeout.Value; } if (cookies != null) { request.CookieContainer = new CookieContainer(); request.CookieContainer.Add(cookies); } return request.GetResponse() as HttpWebResponse; } /// <summary> /// 创建POST方式的HTTP请求 /// </summary> /// <param name="url">请求的URL</param> /// <param name="parameters">随同请求POST的参数名称及参数值字典</param> /// <param name="timeout">请求的超时时间</param> /// <param name="userAgent">请求的客户端浏览器信息,可以为空</param> /// <param name="requestEncoding">发送HTTP请求时所用的编码</param> /// <param name="cookies">随同HTTP请求发送的Cookie信息,如果不需要身份验证可以为空</param> /// <returns></returns> public static HttpWebResponse CreatePostHttpResponse(string url, IDictionary<string, string> parameters, int? timeout, string userAgent, Encoding requestEncoding, CookieCollection cookies) { if (string.IsNullOrEmpty(url)) { throw new ArgumentNullException("url"); } if (requestEncoding == null) { throw new ArgumentNullException("requestEncoding"); } HttpWebRequest request = null; //如果是发送HTTPS请求 if (url.StartsWith("https", StringComparison.OrdinalIgnoreCase)) { ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(CheckValidationResult); request = WebRequest.Create(url) as HttpWebRequest; request.ProtocolVersion = HttpVersion.Version10; } else { request = WebRequest.Create(url) as HttpWebRequest; } request.Method = "POST"; request.ContentType = "application/x-www-form-urlencoded"; if (!string.IsNullOrEmpty(userAgent)) { request.UserAgent = userAgent; } else { request.UserAgent = DefaultUserAgent; } if (timeout.HasValue) { request.Timeout = timeout.Value; } if (cookies != null) { request.CookieContainer = new CookieContainer(); request.CookieContainer.Add(cookies); } //如果需要POST数据 if (!(parameters == null || parameters.Count == 0)) { StringBuilder buffer = new StringBuilder(); int i = 0; foreach (string key in parameters.Keys) { if (i > 0) { buffer.AppendFormat("&{0}={1}", key, parameters[key]); } else { buffer.AppendFormat("{0}={1}", key, parameters[key]); } i++; } byte[] data = requestEncoding.GetBytes(buffer.ToString()); using (Stream stream = request.GetRequestStream()) { stream.Write(data, 0, data.Length); } } return request.GetResponse() as HttpWebResponse; } private static bool CheckValidationResult(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors errors) { return true; //总是接受 } } }
执行代码如下:
public static void GetLinceNo() { using (TPMSEntities context = new TPMSEntities()) { List<dc_cb_SupplierLinceNo> lst = new List<dc_cb_SupplierLinceNo>(); var data = context.dc_p_Provider_temp2019.ToList(); foreach(var item in data) { if (!string.IsNullOrEmpty(item.LicenceNo)) { continue; } string uri = string.Format("https://www.creditchina.gov.cn/api/public_search/getCreditCodeFacade?keyword={0}&_={1}", item.SupplierName, GetTimestamp(DateTime.Now)); var json = HttpWebResponseUtility.GetUrl(uri); if (!string.IsNullOrEmpty(json)) { try { var jsonResult = JsonConvert.DeserializeObject<res>(json); if (jsonResult != null && jsonResult.result != null && jsonResult.result.results != null) { var model = jsonResult.result.results.Where(A => A.entName == item.SupplierName).FirstOrDefault(); if (model == null) { continue; } string credCode = model.credCode; dc_cb_SupplierLinceNo d = new dc_cb_SupplierLinceNo(); d.SupplierName = item.SupplierName; d.LinceNo = credCode; context.dc_cb_SupplierLinceNo.Add(d); context.SaveChanges(); } else { continue; } } catch(Exception ex) { continue; } } else { continue; } } //using (var Transaction = context.Database.BeginTransaction()) //{ // try // { // Transaction.Commit(); // } // catch (Exception ex) // { // Transaction.Rollback(); // } //} } } public static string GetTimestamp(DateTime d) { TimeSpan ts = d - new DateTime(1970, 1, 1); return ts.TotalMilliseconds.ToString(); } #endregion public class res { public resultCls result { get; set; } public int totalPageCount { get; set; } } public class resultCls { public string start { get; set; } public string pageSize { get; set; } public string totalCount { get; set; } public List<resultsCls> results { get; set; } public string exportButtonValid { get; set; } public string currentPageNo { get; set; } public string page { get; set; } public string totalPageCount { get; set; } } public class resultsCls { public string id { get; set; } public string entName { get; set; } public string credCode { get; set; } public string regCode { get; set; } public string orgCode { get; set; } public string taxCode { get; set; } public string status { get; set; } public string modifyDate { get; set; } public string md5 { get; set; } public string rank { get; set; } public string solrStatus { get; set; } public string validTime { get; set; } }
虽说免费,但是这个方法服务端会限制请求的次数!
@陈卧龙的博客
- Jenkins 未授权远程代码执行漏洞(CVE-2017-1000353)
- ASP.NET MVC编程——路由
- ASP.NET MVC编程——模型
- ASP.NET MVC编程——验证、授权与安全
- 如何使用SAML配置CDSW的身份验证
- ASP.NET MVC编程——控制器
- ASP.NET MVC编程——视图
- 设计原则
- Entity Framework——配置文件设置
- 如何安装SAS并配置连接Hive/Impala
- Entity Framework——记录执行的命令信息
- 【BlackHat 2017 议题剖析】连接的力量:GitHub 企业版漏洞攻击链构造之旅
- CVE-2015-1641 Word 利用样本分析
- Cloudera Navigator介绍与安装
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 中流砥柱java的动态代理
- java的反射机制到底是做什么的?
- Java中是否直接可以使用enum进行传输
- PHP 恶意程序简单分析
- springboot之相关环境设置
- springboot之第一个springboot程序
- 「查缺补漏」巩固你的RocketMQ知识体系
- springboot之场景启动器
- ICLR2020 | 深度自适应Transformer
- springboot之自动配置
- golang--连接redis数据库并进行增删查改
- golang--redis连接池
- springboot配置之使用application.properties时编码问题
- mybatis动态sql之foreach补充(二)
- golang数据结构之稀疏数组