1. using System.Data;
  2. using System.Net;
  3. using System.IO;
  4. using System.Net.Http;
  5. using System.Web;
  6. using System.Collections.Specialized;
  7. using System.Web.Script.Serialization;
  8. using System.Collections;
  9. public string ToPackageJson(DataTable dt) //封装Json
  10. {
  11. Dictionary<string, string> dic1 = new Dictionary<string, string>();
  12. foreach (DataRow dr in dt.Rows)
  13. {
  14. foreach (DataColumn dc in dt.Columns)
  15. {
  16. dic1.Add(dc.ColumnName, dr[dc.ColumnName].ToString());
  17. }
  18. }
  19. Dictionary<string, object> dic2 = new Dictionary<string, object>();
  20. dic2.Add(dt.TableName, dic1);
  21. JavaScriptSerializer javaScriptSerializer = new JavaScriptSerializer();
  22. javaScriptSerializer.MaxJsonLength = Int32.MaxValue; //取得最大数值
  23. return javaScriptSerializer.Serialize(dic2); //返回一个json字符串  {"dt.TableName":{"列名1":"列值1","列名2":"列值2","列名n":"列值n"}}
  24. }
  25. public string ToPost(string postURL,string NTLM_UserName,string NTML_PassWord,DataTable dtToPost)
  26.   {
  27.     //封装Json
  28.  string strJson = ToPackageJson(dtToPost);
  29. //通过NTLM验证
  30.     //1、创建空白的网站证书缓存
  31. System.Net.CredentialCache MyCredentialCache = new System.Net.CredentialCache();
  32.     //指定以b2c用户通过NTLM身份验证
  33. MyCredentialCache.Add(new System.Uri(postURL), "NTLM", new System.Net.NetworkCredential(NTLM_UserName, NTML_PassWord));
  34. HttpWebRequest httpWebRequest = (HttpWebRequest)WebRequest.Create(postURL);
  35. httpWebRequest.Credentials = MyCredentialCache;
  36. httpWebRequest.Method = "POST";
  37. httpWebRequest.ContentType = "application/json;charset=UTF-8";
  38. //httpWebRequest.Headers.Add(HttpRequestHeader.Authorization, authStr); //auth权限验证   
  39. //将Json字符串转化为字节
  40. byte[] postDataByte = Encoding.UTF8.GetBytes(strJson);
  41. httpWebRequest.ContentLength = postDataByte.Length;
  42. httpWebRequest.AllowAutoRedirect = false;
  43. httpWebRequest.KeepAlive = true;
  44. httpWebRequest.ContentLength = postDataByte.Length;
  45. //获取用于写入请求数据的Stream对象
  46. Stream writer = httpWebRequest.GetRequestStream();
  47. //将请求参数写入流
  48. writer.Write(postDataByte, 0, postDataByte.Length);
  49. //关闭请求流
  50. writer.Close();
  51. //http响应所返回的字符流
  52. string responseResult = "";
  53. HttpWebResponse response = null;
  54. try
  55. {
  56. //获取http返回的响应流
  57. response = (HttpWebResponse)httpWebRequest.GetResponse();
  58. }
  59. catch (WebException ex)
  60. {
  61.       response = (HttpWebResponse)ex.Response;
  62. }
  63. //读取响应流内容
  64. StreamReader sr = new StreamReader(response.GetResponseStream());
  65. responseResult = sr.ReadToEnd();
  66. //关闭读取器
  67. sr.Close();
  68. return responseResult;
  69. }

Web后台模拟前端post(带NTLM验证)的更多相关文章

  1. [转]Web后台模拟前端post(带NTLM验证)

    本文转自:http://www.cnblogs.com/pzstudyhard/p/4805885.html using System.Data; using System.Net; using Sy ...

  2. 购物车Demo,前端使用AngularJS,后端使用ASP.NET Web API(3)--Idetity,OWIN前后端验证

    原文:购物车Demo,前端使用AngularJS,后端使用ASP.NET Web API(3)--Idetity,OWIN前后端验证 chsakell分享了前端使用AngularJS,后端使用ASP. ...

  3. web的前台、后台、前端、后端

    前台:呈现给用户的视觉和基本的操作.后台:用户浏览网页时,我们看不见的后台数据跑动.后台包括前端,后端.前端:对应我们写的html .javascript 等网页语言作用在前端网页.后端:对应jsp. ...

  4. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(33)-数据验证共享

    原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(33)-数据验证共享 注:本节阅读需要有MVC 自定义验证的基础,否则比较吃力 一直以来表单的验证都是不可 ...

  5. 腾讯Web工程师的前端书单

    2014年一月以来,自己接触web前端开发已经两年多了,记录一下自己前端学习路上看过的,以及道听途说的一些书,基本上按照由浅入深来介绍. JavaScript 入门 <JavaScript权威指 ...

  6. Web后台快速开发框架(.NET Core)

    Web后台快速开发框架(.NET Core) Coldairarrow 目录 目录 第1章    目录    1 第2章    简介    3 第3章    基础准备    4 3.1    开发环境 ...

  7. Web后台快速开发框架

    Web后台快速开发框架 Coldairarrow 目录 目录 第1章    目录    1 第2章    简介    3 第3章    基础准备    4 3.1    开发环境要求    4 3.2 ...

  8. 第二周作业-web后台应用开发与xml

    web后台: 网站前台和网站后台通常是相对于动态网站而言,即网站建设是基于数据库开发 的网站.基于带数据库开发的网站,一般分网站前台和网站后台.网站前台是面向网站访问用户的,通俗的说也就是给访问网站的 ...

  9. Web暴力破解--前端JS表单加密进行爆破

    0x01 前言 常见的js实现加密的方式有:md5.base64.shal,写了一个简单的demo作为测试. 0x02 代码 login.html <!DOCTYPE HTML> < ...

随机推荐

  1. 菜鸟的Xamarin.Forms前行之路——共享组件

    出自:博客园-半路独行 本文出自于http://www.cnblogs.com/banluduxing 转载请注明出处. Url Description Xamarin.Social The Xama ...

  2. 使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况

    使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况 前言 本文在Debian9下采用Docker的方式安装Telegraf + Influxdb + ...

  3. HTML5 开发APP 第一章

    当今天下,移动端基本上是安卓和苹果的天下,基本上没微软什么事,作为微软忠实的支持者,也要顺势而变. 但安卓和IOS  开发是两个完全不同的世界,有没有一种技术,开发完以后可以运行在任意终端呢,答案是有 ...

  4. img标签中onerror用法

    <img src="/statics/bazi/images/150x100.jpg" alt="#" onerror="this.style. ...

  5. [Winter Vacation] 守护,守望

    最近总是堕落......想好了,不如在百无聊赖之时写一些心底的话,让它们最终不归于尘土吧. 有了想要守护一个人的信念与想法,然而有没有资格却还没有人能够说清楚,下断言.这可真是可悲了,总不能笃定着对方 ...

  6. Review notes

  7. virsh 连接虚拟机 (vnc 或 控制台)

    第一种方式 1.如果虚拟机登录方式为VNC,在ubuntu机器上安装vncviewer 在虚拟机的配置xml中 <graphics type="vnc" autoport=& ...

  8. Scrapy 抓取股票行情

    安装scrapy会出现错误,我们选择anaconda3作为编译环境,搜索scrapy安装(有错误自查) 创建scrapy爬虫项目: 调出cmd,到相应目录:输入: scrapy startprojec ...

  9. springboot设置日志级别时报错

    配置springboot日志,输出级别为info,运行时报错: Caused by: org.springframework.boot.context.properties.bind.BindExce ...

  10. using声明和using指示

    using声明(using declaration) using namespacename::namespacemember; using声明一次只引入命名空间的一个成员.从效果上看就好像using ...