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 ...
随机推荐
- 【学习笔记】【C语言】三目运算符
1.N目运算符 像逻辑非(!).负号(-)这种只连接一个数据的符号,称为“单目运算符”,比如!5.-5.像算术运算符.关系运算符.逻辑运算符这种连接二个数据的负号,称为“双目运算符”,比如6+7.8* ...
- jquery的clone方法 于textarea和select的bug修复
在使用jquery的clone方法时,textarea和select的值clone的时候会丢掉,这可能是这个方法的一个BUG.解决办法就是在clone的时候将val再重新赋值一下. 引入到你要用的cl ...
- python基础day2作业:购物车
#功能:1.可注册账号2.登录买家账号3.可查询编辑购物车里商品4.可以余额充值5.可提示余额不足6.购物车结算 #使用:1.第一次使用先注册账号填写账号金额2.账号金额信息保存在buyer_acco ...
- 升级ionic版本后,创建新项目报Error Initializing app错误解决
命令行,进入项目路径后,运行 ionic start myApp --v2 命令执行后,报如下错误 Installing npm packages...Error with start undefin ...
- js 引用类型比较
看到别人提的一个问题,说为什么,他们是fasle 然后自己也测试了一番觉得应该是这样的, var a=[1,2,3,4]; var b=a; var c=[1,2,3,4]; if(a==b){ al ...
- 8款HTML5动画特效推荐源码
1.HTML5 Canvas发光Loading动画 之前我们分享过很多基于CSS3的Loading动画效果,相信大家都很喜欢.今天我们要来分享一款基于HTML5 Canvas的发光Loading加载动 ...
- DataGrid实现逻辑分页
在ASP.NET内建提供的所有数据排列控件中,只有DataGrid数据控件是提供数据分页功能的.DataReapter数据控件只能提供一些简单 的.基础的数据重复排列功能,对于一些比较复杂的应用是无能 ...
- 3月3日 Mark
感觉LeetCode OJ 水题较多... 不过回复基础就是这样吧.. 刚刚和Gaewah聊了下,后续可以考虑去做Topcoder的SRM或者codeforces,Mark.
- 使用struct实现面向对象编程的封装
虽然C是面向过程的语言,但是这不代表C不能使用面向对象的思想,本质上说语言只是一种手段而已,一种外在的表现形式,支持面向对象的语言只是通过设计的特定的关键字更好的表现了面向对象编程而已.C中也可以使用 ...
- 麦子学院Android开发Java教程ClassCastException 错误解析
现在Java编程中经常碰到ClassCastException 错误,ClassCastException 是 JVM 在检测到两个类型间的转换不兼容时引发的运行时异常.此类错误通常会终止用户请求.本 ...