Web后台模拟前端post(带NTLM验证)
- using System.Data;
- using System.Net;
- using System.IO;
- using System.Net.Http;
- using System.Web;
- using System.Collections.Specialized;
- using System.Web.Script.Serialization;
- using System.Collections;
- public string ToPackageJson(DataTable dt) //封装Json
- {
- Dictionary<string, string> dic1 = new Dictionary<string, string>();
- foreach (DataRow dr in dt.Rows)
- {
- foreach (DataColumn dc in dt.Columns)
- {
- dic1.Add(dc.ColumnName, dr[dc.ColumnName].ToString());
- }
- }
- Dictionary<string, object> dic2 = new Dictionary<string, object>();
- dic2.Add(dt.TableName, dic1);
- JavaScriptSerializer javaScriptSerializer = new JavaScriptSerializer();
- javaScriptSerializer.MaxJsonLength = Int32.MaxValue; //取得最大数值
- return javaScriptSerializer.Serialize(dic2); //返回一个json字符串 {"dt.TableName":{"列名1":"列值1","列名2":"列值2","列名n":"列值n"}}
- }
- public string ToPost(string postURL,string NTLM_UserName,string NTML_PassWord,DataTable dtToPost)
- {
- //封装Json
- string strJson = ToPackageJson(dtToPost);
- //通过NTLM验证
- //1、创建空白的网站证书缓存
- System.Net.CredentialCache MyCredentialCache = new System.Net.CredentialCache();
- //指定以b2c用户通过NTLM身份验证
- MyCredentialCache.Add(new System.Uri(postURL), "NTLM", new System.Net.NetworkCredential(NTLM_UserName, NTML_PassWord));
- HttpWebRequest httpWebRequest = (HttpWebRequest)WebRequest.Create(postURL);
- httpWebRequest.Credentials = MyCredentialCache;
- httpWebRequest.Method = "POST";
- httpWebRequest.ContentType = "application/json;charset=UTF-8";
- //httpWebRequest.Headers.Add(HttpRequestHeader.Authorization, authStr); //auth权限验证
- //将Json字符串转化为字节
- byte[] postDataByte = Encoding.UTF8.GetBytes(strJson);
- httpWebRequest.ContentLength = postDataByte.Length;
- httpWebRequest.AllowAutoRedirect = false;
- httpWebRequest.KeepAlive = true;
- httpWebRequest.ContentLength = postDataByte.Length;
- //获取用于写入请求数据的Stream对象
- Stream writer = httpWebRequest.GetRequestStream();
- //将请求参数写入流
- writer.Write(postDataByte, 0, postDataByte.Length);
- //关闭请求流
- writer.Close();
- //http响应所返回的字符流
- string responseResult = "";
- HttpWebResponse response = null;
- try
- {
- //获取http返回的响应流
- response = (HttpWebResponse)httpWebRequest.GetResponse();
- }
- catch (WebException ex)
- {
- response = (HttpWebResponse)ex.Response;
- }
- //读取响应流内容
- StreamReader sr = new StreamReader(response.GetResponseStream());
- responseResult = sr.ReadToEnd();
- //关闭读取器
- sr.Close();
- return responseResult;
- }
Web后台模拟前端post(带NTLM验证)的更多相关文章
- [转]Web后台模拟前端post(带NTLM验证)
本文转自:http://www.cnblogs.com/pzstudyhard/p/4805885.html using System.Data; using System.Net; using Sy ...
- 购物车Demo,前端使用AngularJS,后端使用ASP.NET Web API(3)--Idetity,OWIN前后端验证
原文:购物车Demo,前端使用AngularJS,后端使用ASP.NET Web API(3)--Idetity,OWIN前后端验证 chsakell分享了前端使用AngularJS,后端使用ASP. ...
- web的前台、后台、前端、后端
前台:呈现给用户的视觉和基本的操作.后台:用户浏览网页时,我们看不见的后台数据跑动.后台包括前端,后端.前端:对应我们写的html .javascript 等网页语言作用在前端网页.后端:对应jsp. ...
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(33)-数据验证共享
原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(33)-数据验证共享 注:本节阅读需要有MVC 自定义验证的基础,否则比较吃力 一直以来表单的验证都是不可 ...
- 腾讯Web工程师的前端书单
2014年一月以来,自己接触web前端开发已经两年多了,记录一下自己前端学习路上看过的,以及道听途说的一些书,基本上按照由浅入深来介绍. JavaScript 入门 <JavaScript权威指 ...
- Web后台快速开发框架(.NET Core)
Web后台快速开发框架(.NET Core) Coldairarrow 目录 目录 第1章 目录 1 第2章 简介 3 第3章 基础准备 4 3.1 开发环境 ...
- Web后台快速开发框架
Web后台快速开发框架 Coldairarrow 目录 目录 第1章 目录 1 第2章 简介 3 第3章 基础准备 4 3.1 开发环境要求 4 3.2 ...
- 第二周作业-web后台应用开发与xml
web后台: 网站前台和网站后台通常是相对于动态网站而言,即网站建设是基于数据库开发 的网站.基于带数据库开发的网站,一般分网站前台和网站后台.网站前台是面向网站访问用户的,通俗的说也就是给访问网站的 ...
- Web暴力破解--前端JS表单加密进行爆破
0x01 前言 常见的js实现加密的方式有:md5.base64.shal,写了一个简单的demo作为测试. 0x02 代码 login.html <!DOCTYPE HTML> < ...
随机推荐
- 菜鸟的Xamarin.Forms前行之路——共享组件
出自:博客园-半路独行 本文出自于http://www.cnblogs.com/banluduxing 转载请注明出处. Url Description Xamarin.Social The Xama ...
- 使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况
使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况 前言 本文在Debian9下采用Docker的方式安装Telegraf + Influxdb + ...
- HTML5 开发APP 第一章
当今天下,移动端基本上是安卓和苹果的天下,基本上没微软什么事,作为微软忠实的支持者,也要顺势而变. 但安卓和IOS 开发是两个完全不同的世界,有没有一种技术,开发完以后可以运行在任意终端呢,答案是有 ...
- img标签中onerror用法
<img src="/statics/bazi/images/150x100.jpg" alt="#" onerror="this.style. ...
- [Winter Vacation] 守护,守望
最近总是堕落......想好了,不如在百无聊赖之时写一些心底的话,让它们最终不归于尘土吧. 有了想要守护一个人的信念与想法,然而有没有资格却还没有人能够说清楚,下断言.这可真是可悲了,总不能笃定着对方 ...
- Review notes
- virsh 连接虚拟机 (vnc 或 控制台)
第一种方式 1.如果虚拟机登录方式为VNC,在ubuntu机器上安装vncviewer 在虚拟机的配置xml中 <graphics type="vnc" autoport=& ...
- Scrapy 抓取股票行情
安装scrapy会出现错误,我们选择anaconda3作为编译环境,搜索scrapy安装(有错误自查) 创建scrapy爬虫项目: 调出cmd,到相应目录:输入: scrapy startprojec ...
- springboot设置日志级别时报错
配置springboot日志,输出级别为info,运行时报错: Caused by: org.springframework.boot.context.properties.bind.BindExce ...
- using声明和using指示
using声明(using declaration) using namespacename::namespacemember; using声明一次只引入命名空间的一个成员.从效果上看就好像using ...