c#http 请求接口 类型From-data

c#http 请求接口 类型From-data

转发请注明由来

public static class HttpClientHelper
{
public static int count = 0;
///
/// Http web 请求 类型From-data
///
/// 请求路径
/// 参数字典类型
/// 是否文件
///
public static string postFileMessage(string Url, Dictionary<string,string> keys,bool isfile)
{
try
{
string responseContent = “”;
var memStream = new MemoryStream();
var webRequest = (HttpWebRequest)WebRequest.Create(Url);
// 边界符
var boundary = “---------------” + DateTime.Now.Ticks.ToString(“x”);
// 边界符
var beginBoundary = Encoding.ASCII.GetBytes("–" + boundary + “\r\n”);
// 最后的结束符
var endBoundary = Encoding.ASCII.GetBytes("–" + boundary + “–\r\n”);
memStream.Write(beginBoundary, 0, beginBoundary.Length);
// 设置属性
webRequest.Method = “POST”;
webRequest.Timeout = 10000;
webRequest.ContentType = “multipart/form-data; boundary=” + boundary;
foreach (KeyValuePair<string, string> kvp in keys)
{
count += 1;
// 写入文件
if (isfile)
{
var fileStream = new FileStream(kvp.Value, FileMode.Open, FileAccess.Read);
const string filePartHeader =
“Content-Disposition: form-data; name=”{0}"; filename="{1}"\r\n" +
“Content-Type: application/octet-stream\r\n\r\n”;
var header = string.Format(filePartHeader, kvp.Key, kvp.Value);
var headerbytes = Encoding.UTF8.GetBytes(header);
memStream.Write(headerbytes, 0, headerbytes.Length);
var buffer = new byte[1024];
int bytesRead;
while ((bytesRead = fileStream.Read(buffer, 0, buffer.Length)) != 0)
{
memStream.Write(buffer, 0, bytesRead);
}
string end = “\r\n”;
headerbytes = Encoding.UTF8.GetBytes(end);
memStream.Write(headerbytes, 0, headerbytes.Length);
fileStream.Close();
}
else
{
// 写入字符串的Key
var stringKeyHeader = “Content-Disposition: form-data; name=”{0}"" +
“\r\n\r\n{1}\r\n”;
var header = string.Format(stringKeyHeader, kvp.Key, kvp.Value);
var headerbytes = Encoding.UTF8.GetBytes(header);
memStream.Write(headerbytes, 0, headerbytes.Length);
}
if (count != keys.Count - 1)
memStream.Write(beginBoundary, 0, beginBoundary.Length);
else
// 写入最后的结束边界符
memStream.Write(endBoundary, 0, endBoundary.Length);
}
webRequest.ContentLength = memStream.Length;
var requestStream = webRequest.GetRequestStream();
memStream.Position = 0;
var tempBuffer = new byte[memStream.Length];
memStream.Read(tempBuffer, 0, tempBuffer.Length);
memStream.Close();
requestStream.Write(tempBuffer, 0, tempBuffer.Length);
requestStream.Close();
using (HttpWebResponse res = (HttpWebResponse)webRequest.GetResponse())
{

                using (Stream resStream = res.GetResponseStream())
                {
                    byte[] buffer = new byte[1024];
                    int read;
                    while ((read = resStream.Read(buffer, 0, buffer.Length)) > 0)
                    {
                        responseContent += Encoding.UTF8.GetString(buffer, 0, read);
                    }
                }
                res.Close();
            }
            return responseContent;
        }
        catch (Exception e)
        {
            ToolBox.LogTools.PubliceLog.WriteLog("请求失败: 异常" + e.Message);
        }
        return null;
    }
}
#创作不易请打赏!!!!!!!!!!!
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用SQL Server的CLR集成功能来实现发送HTTP请求。CLR集成是SQL Server提供的一种机制,允许开发人员使用.NET编程语言编写存储过程、函数和触发器等托管代码。 以下是一个简单的示例,演示如何使用CLR集成发送HTTP请求: 1. 创建一个C#类库项目,添加以下代码: ``` using System; using System.Data.SqlTypes; using System.Net; public class HttpHelper { [Microsoft.SqlServer.Server.SqlFunction] public static SqlString SendHttpRequest(SqlString url) { try { WebClient client = new WebClient(); string response = client.DownloadString(url.ToString()); return new SqlString(response); } catch (Exception ex) { return new SqlString(ex.Message); } } } ``` 2. 在项目中添加引用 System.Data和 System.Data.SqlServer。 3. 在项目属性中,选择“生成”选项卡,将目标框架设置为.NET Framework 4.0或更高版本。选择“生成”菜单,生成项目。 4. 将DLL文件添加到SQL Server中。在SQL Server Management Studio中,右键单击“数据库”节点,选择“新建查询”。 5. 输入以下命令,创建一个程序集: ``` CREATE ASSEMBLY HttpHelper FROM 'C:\Path\To\HttpHelper.dll' WITH PERMISSION_SET = SAFE; ``` 6. 创建一个存储过程,调用CLR函数: ``` CREATE PROCEDURE GetHttpData (@url NVARCHAR(200)) AS EXTERNAL NAME HttpHelper.[HttpHelper].SendHttpRequest; ``` 7. 调用存储过程: ``` EXEC GetHttpData 'http://www.example.com'; ``` 执行以上命令,即可通过SQL Server调用CLR函数发送HTTP请求,并返回响应结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值