C# 中请求数据方式
#region 根据URL获取结果集
/// <summary>
/// 根据URL获取结果集 默认为GET,如果数据量大了可以传入POST
/// </summary>
/// <param name="url">URL地址</param>
/// <param name="type">默认为GET,删除时用DELETE</param>
/// <returns>String类型的,Json格式的结果集</returns>
public static string GetUrlResult(string url, string type = "GET")
{
string result = string.Empty;
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
request.Method = type;
request.ContentType = "application/x-www-form-urlencoded";
Stream resStream = null;
StreamReader sr = null;
try
{
WebResponse response = request.GetResponse();
resStream = response.GetResponseStream();
sr = new StreamReader(resStream, System.Text.Encoding.UTF8);
result = sr.ReadToEnd();
resStream.Close();
sr.Close();
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return result;
}
#endregion
#region 根据URL获取结果集
/// <summary>
/// 根据URL获取结果集 默认为GET,如果数据量大了可以传入POST
/// </summary>
/// <param name="url">URL地址</param>
/// <param name="proxy">代理IP</param>
/// <param name="type">默认为GET,删除时用DELETE</param>
/// <returns>String类型的,Json格式的结果集</returns>
public static string GetUrlResult(string url, WebProxy proxy, string type = "GET")
{
string result = string.Empty;
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
request.Proxy = proxy;
request.Method = type;
request.Timeout = 1000 * 10;
request.ContentType = "application/x-www-form-urlencoded";
Stream resStream = null;
StreamReader sr = null;
try
{
WebResponse response = request.GetResponse();
resStream = response.GetResponseStream();
sr = new StreamReader(resStream, System.Text.Encoding.UTF8);
result = sr.ReadToEnd();
resStream.Close();
sr.Close();
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return result;
}
#endregion
#region 通过POST方式去TRS创建豆腐块
/// <summary>
/// 通过POST方式去TRS创建豆腐块
/// </summary>
/// <param name="url">url</param>
/// <param name="param">参数</param>
/// <returns></returns>
public static string PostUrlResult(string url, string param)
{
string result = string.Empty;
byte[] byteArray = Encoding.UTF8.GetBytes(param);
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
request.Method = "POST";
request.ContentType = "application/x-www-form-urlencoded";
Stream newStream = null;
StreamReader sr = null;
try
{
newStream = request.GetRequestStream();
newStream.Write(byteArray, 0, byteArray.Length);
newStream.Close();
//获取响应
WebResponse response = request.GetResponse();
sr = new StreamReader(response.GetResponseStream(), Encoding.UTF8);
result = sr.ReadToEnd();
sr.Close();
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
return result;
}
#endregion
#region 根据IP和端口号检查代理IP是否有效
/// <summary>
/// 根据IP和端口号检查代理IP是否有效
/// </summary>
/// <param name="ip">代理IP</param>
/// <param name="port">端口号</param>
/// <returns></returns>
public static bool AgentIsAvailable(string ip, int port)
{
bool result = false;
HttpWebRequest webRequest;
HttpWebResponse webResponse;
StreamReader sr = null;
try
{
WebProxy proxy = new WebProxy(ip, port);
webRequest = WebRequest.Create(ConfigurationManager.AppSettings["SSWBValidIPUrl"]) as HttpWebRequest;
webRequest.Proxy = proxy;
webRequest.Timeout = 1000 * 5;
webResponse = webRequest.GetResponse() as HttpWebResponse;
sr = new StreamReader(webResponse.GetResponseStream(), Encoding.GetEncoding("UTF-8"));
string str = sr.ReadToEnd();
if (str.Contains(ConfigurationManager.AppSettings["SSWBContainsString"]))
result = true;
sr.Close();
sr.Dispose();
}
catch (Exception ex)
{
Logging.Error(string.Format("检验代理IP是否有效时异常,异常信息:{0}", ex.Message));
}
return result;
}
#endregion
C# 中请求数据方式的更多相关文章
- vue的请求数据方式
一,vue-resource请求数据 介绍:vue-resource请求数据方式是官方提供的一个插件 步骤: 1,npm安装 npm install vue-resource --save ...
- Flask中请求数据的优雅传递
当一个请求到来时,浏览器会携带很多信息发送发送服务端.在Django中,每一个处理函数都要传入一个request的参数,该参数携带所有请求的信息,也就是服务端程序封装的environ(不明白该参数可以 ...
- js中请求数据的$post和$ajax区别(同步和异步问题)
$.post和$.Ajax都为页面上向后台发送请求,请求数据 1.post 因为post默认为异步请求,可是有时候我们会发现,本来要求请求马上出现,可是异步会导致后面突然再执行,这样就出很多问题 2. ...
- axios中请求传值方式
日常开发中与后端联调,可能需要的数据不同,所传值也有所不同 1.如果是data方式,设置请求头为:并且直接返回data就可以 raw axios.defaults.headers['Content- ...
- Nuxt.js 如何在 asyncData中 请求数据 ,并将拿到的数据传给子组件
说明:同接口请求一样,也可以进行数据的处理:return 中 左侧的变量 可以直接拿到在页面上使用,也可以传递给子组件 下面再给出一段代码,方便觉得有用的.却又不想手敲的朋友们: async as ...
- struts中请求数据自动封装
实现原理 参数拦截器 第一:jsp表单数据填充到action中的属性 必须实现set方法,get方法可以不需要实现,jsp页面name名字保持一致 第二:jsp表单填充到action的对象的属性 js ...
- 爬取'Content-Type': 'text/plain;charset=UTF-8' ,发送请求数据方式
解决方式 直接以字符串的方式发送data就可以得到响应数据 import requests data = 'k1:v1,k2:v2' requests.post(url, data=data)
- Vue vue-resource三种请求数据方式pet,post,jsonp
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- vue.js中请求数据v-for循环使用数据
1.效果图 2.cart.json { "message":"", "status":"1", "result ...
随机推荐
- 总结一下block的几种常用方法
一.block的简单介绍 block相当于一个参数,有参数的名,有参数的值,有参数的使用,当使用block的时候,它又相当于一个函数,会回调函数体. 声明:void (^block)(void); 实 ...
- Objective-C 【Category-非正式协议-延展】
------------------------------------------- 类别(Category)的声明和实现 实质:类别又叫类目,它其实是对类的一个拓展!但是他不同于继承后的拓展! ...
- 20150528—html使用Jquery遍历text文本框的非空验证
<script src="jquery-1.7.2.min.js" type="text/javascript"></script> & ...
- UI1_ScrollViewHomeWork
// // AppDelegate.m // UI1_ScrollViewHomeWork // // Created by zhangxueming on 15/7/13. // Copyright ...
- 关于document.write
document.write的用处 document.write是JavaScript中对document.open所开启的文档流(document stream操作的API方法,它能够直接在文档流中 ...
- 不容错过的七个jQuery图片滑块插件
1.jQuery多图并列焦点图插件 今天我们要来分享一款比较特别的jQuery焦点图插件,它允许你自己定义当前画面的图片数量,在这个演示中,我们定义了3张图片一起显示.和其他jQuery焦点图一样,这 ...
- 判断Featureclass的类型
一个Featureclass可以是Shapefile Feature Class.Personal Geodatabase Feature Class.File Geodatabase Feature ...
- uniform 中checkbox通过jquery 选中
你是否曾经为不能修改多选框.单选框.文件选择框的样式而郁闷呢,是否想过控制它们的样式且兼容所有浏览器呢?我现在给你推荐的这个jQuery表单美化插件Uniform就可以解决这些问题. Uniform可 ...
- Android之“Unfortunately,xxx has stopped!”
初学Android遇到Unfortunately,xxx has stopped!真是一件让人头疼的事情,下面就遇到的两种可能情况给出解决方案.通常遇到的情况在于由一个Activity跳转至另一个Ac ...
- Python开发【第一篇】Python基础之自定义模块和内置模块
为什么要有模块,将代码归类.模块,用一砣代码实现了某个功能的代码集合. Python中叫模块,其他语言叫类库. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代 ...