c# httppost方法

public struct PostFile

{

public string name;

public string filename;

public Stream bitmapStream;

}

public string PostStringFormPic(Dictionary<string, string> paramData, PostFile postfile, Encoding EncodingPostData = null, Encoding EncodingReadStream = null)

{

webRequest.Method = "POST";

//string ret = string.Empty;

Stream newStream = null;

//StreamReader sr = null;

        if (EncodingReadStream == null)
{
EncodingReadStream = Encoding.UTF8;
}
if (EncodingPostData == null)
{
EncodingPostData = Encoding.UTF8;
} try
{
//EncodingPostData = Encoding.GetEncoding("GB2312");
// 边界符
var boundary = "---------------" + DateTime.Now.Ticks.ToString("x");
// 边界符
var beginBoundary = Encoding.ASCII.GetBytes("--" + boundary + "\r\n");
// 最后的结束符
var endBoundary = Encoding.ASCII.GetBytes("\r\n--" + boundary + "--\r\n");
webRequest.ContentType = "multipart/form-data; boundary=" + boundary;
var memStream = new MemoryStream();
memStream.Write(beginBoundary, 0, beginBoundary.Length); var header = "Content-Disposition: form-data; name=\"{0}\"; filename=\"{1}\"\r\n" +
"Content-Type: image/jpeg\r\n\r\n";
header = string.Format(header, postfile.name, postfile.filename);
var headerbytes = EncodingPostData.GetBytes(header);
memStream.Write(headerbytes, 0, headerbytes.Length); postfile.bitmapStream.CopyTo(memStream); var stringKeyHeader = "\r\n--" + boundary +
"\r\nContent-Disposition: form-data; name=\"{0}\"" +
"\r\n\r\n{1}"; // var rn = "\r\n";//换行
// var rnlength = rn.Length;
foreach (var item in paramData)
{ string data = string.Format(stringKeyHeader, item.Key, item.Value);
byte[] bdata = EncodingPostData.GetBytes(data);
memStream.Write(bdata, 0, bdata.Length);
//memStream.Write(EncodingPostData.GetBytes(rn), 0, rnlength); } // 写入最后的结束边界符
memStream.Write(endBoundary, 0, endBoundary.Length); webRequest.ContentLength = memStream.Length;
//byte[] byteArray = EncodingPostData.GetBytes(paramData); //转化
// byte[] byteArray = Encoding.ASCII.GetBytes(paramData);
// webRequest.ContentLength = byteArray.Length;
ServicePointManager.Expect100Continue = false; newStream = webRequest.GetRequestStream(); memStream.Position = 0;
var tempBuffer = new byte[memStream.Length];
memStream.Read(tempBuffer, 0, tempBuffer.Length);
memStream.Close(); newStream.Write(tempBuffer, 0, tempBuffer.Length);//写入参数
newStream.Close();
//webResponse = (HttpWebResponse)webRequest.GetResponse();
////CheckProxy();
//sr = new StreamReader(webResponse.GetResponseStream(), EncodingReadStream);
//ret = sr.ReadToEnd();
//return ret; string result = string.Empty;
webResponse = (HttpWebResponse)webRequest.GetResponse();
CheckProxy(); if (webResponse.ContentEncoding.ToLower() == "gzip")//如果使用了GZip则先解压
{
using (System.IO.Stream stream = webResponse.GetResponseStream())
{
using (var zipStream =
new System.IO.Compression.GZipStream(stream, System.IO.Compression.CompressionMode.Decompress))
{
using (System.IO.StreamReader sr = new System.IO.StreamReader(zipStream, EncodingReadStream))
{
result = sr.ReadToEnd();
}
}
}
}
else
{
using (System.IO.Stream stream = webResponse.GetResponseStream())
{
using (System.IO.StreamReader sr = new System.IO.StreamReader(stream, EncodingReadStream))
{
result = sr.ReadToEnd();
}
}
} return result;
}
finally
{ if (WebResponse != null)
WebResponse.Close();
if (newStream != null)
newStream.Close();
}
}

php端接收 laravel框架

public function upload_headimg(Request $request)

{

//解析回传数据

$extend_data = json_decode(urldecode($request->input('extend_data', '')));

    try {

        $wxnum_model = new Models\Wxnum();
//微信公众号信息
$wxnum_info = $wxnum_model->select_wxnuminfo($extend_data->task_id); $pb_headimg = array();
if ($request->hasFile('fileName')) {
$pb_headimg = $wxnum_model->update_headimg($wxnum_info, $request->file()['fileName']->getRealPath());
} if (count($pb_headimg) > 0) Models\Wxnum::where('id', $wxnum_info->id)->update($pb_headimg); return Models\ResponseRet::return_msg_success();
} catch (\Exception $e) {
Log::info('上传公众号头像:', $request->all());
Log::error(sprintf("%s 上传公众号头像失败 %s", $request->input('u_name', ''), $e->getMessage()));
return Models\ResponseRet::return_msg('1013');
}
}

c# 上传图片流,php端(laravel框架)接收处理方法的更多相关文章

  1. android上传图片、视频、文件,服务端使用wcf接收

    最近一直在搞android上传图片.视频.文件,服务端使用wcf接收,本文对调试中的遇到的问题进行记录. 首先android上传一些小图片是比较容易的一天下来差不多就能调试出来,但是上传一些大的文件时 ...

  2. 利用webuploader插件上传图片文件,完整前端示例demo,服务端使用SpringMVC接收

    利用WebUploader插件上传图片文件完整前端示例demo,服务端使用SpringMVC接收 Webuploader简介   WebUploader是由Baidu WebFE(FEX)团队开发的一 ...

  3. Laravel框架使用融云服务端SDK

    方法一:  使用第三方依赖安装(在项目根目录) 第一步:安装        composer require latrell/rongcloud dev-master 第二步:更新依赖包      c ...

  4. 基于laravel框架构建最小内容管理系统

    校园失物招领平台开发 --基于laravel框架构建最小内容管理系统 摘要 ​ 针对目前大学校园人口密度大.人群活动频繁.师生学习生活等物品容易遗失的基本现状,在分析传统失物招领过程中的工作效率低下. ...

  5. [php]laravel框架容器管理的一些要点

    本文面向php语言的laravel框架的用户,介绍一些laravel框架里面容器管理方面的使用要点.文章很长,但是内容应该很有用,希望有需要的朋友能看到.php经验有限,不到位的地方,欢迎帮忙指正. ...

  6. php的laravel框架快速集成微信登录

    最终的解决方案是:https://github.com/liuyunzhuge/php_weixin_provider,详细的介绍请往下阅读. 本文面向的是php语言laravel框架的用户,介绍的是 ...

  7. 使用 Laravel 框架:成为微信公众平台开发者

    转: http://ninghao.net/blog/1441 作者:王皓发布于:2014-05-30 13:16更新于:2014-05-31 12:05 我们可以使用Laravel 框架为微信公众平 ...

  8. laravel框架中所用到的依赖注入

    用Laravel开发前前后后有2个月左右了,之前一直写Java,就像找到Java和PHP之前的共同点,用Java的某些原理去理解PHP会发现还是有很多共通之处的.Java的依赖注入已经是一个很常见的概 ...

  9. 关于laravel框架的跨域请求/jsonp请求的理解

    最近刚接触laravel框架,首先要写一个跨域的单点登录.被跨域的问题卡了两三天,主要是因为对跨域这快不了解,就在刚才有点茅塞顿开的感觉,我做一下大概整理,主要给一些刚接触摸不着头脑的看,哪里写得不对 ...

随机推荐

  1. [bzoj3123][洛谷P3302] [SDOI2013]森林(树上主席树+启发式合并)

    传送门 突然发现好像没有那么难……https://blog.csdn.net/stone41123/article/details/78167288 首先有两个操作,一个查询,一个连接 查询的话,直接 ...

  2. elasticsearch5.0集群大数据量迁移方法及注意事项

    当es集群的数据量较小的情况下elasticdump这个工具比较方便,但是当数据量达到一定级别比如上百G的时候,elasticdump速度就很慢了,此时我们可以使用快照的方法进行备份 elasticd ...

  3. zabbix添加对自定义无规则的关键日志文件的监控

    zabbix添加对自定义无规则日志文件的监控 项目背景及思路: zabbix自带有针对日志文件的监控,自带的监控只能监控到指定文件或者正则匹配的固定日志文件,但当需要监控的文件名没有规律的时候自带监控 ...

  4. quartz在application中的使用

    项目结构图: TestMain.java package com; import org.quartz.Scheduler; import org.quartz.impl.StdSchedulerFa ...

  5. 请手动释放你的资源(Please release resources manually)

    作者: Laruence(   ) 本文地址: http://www.laruence.com/2012/07/25/2662.html 转载请注明出处 我从来不认为这个问题是个问题, 直到昨天. 昨 ...

  6. es6 entries(),keys() 和 values()

    for (let index of ['a', 'b'].keys()) { console.log(index); } // 0 for (let elem of ['a', 'b'].values ...

  7. OCM_第二天课程:Section1 —》配置 Oracle 网络环境

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  8. python 全栈开发,Day114(装饰器,排序规则,显示列,添加按钮,定制ModelForm,自定义列表页面,自定制URL)

    一.装饰器 装饰器本质上就是一个python函数,他可以让其他函数在不需要做任何代码变动的前提下,增加额外的功能,装饰器的返回值也是一个函数对象. 装饰器的应用场景:比如插入日志,性能测试,事务处理, ...

  9. docker安装sonarqube及实际应用

    由于平台的多样化,在不同环境的安装方式可能也不一样,为了避免环境不一致带来的差异,特记一笔容器安装: 一.Sonar可以从以下七个维度检测代码质量,而作为开发人员至少需要处理前5种代码质量问题. 1. ...

  10. python全栈开发day39-CSS继承性和层叠性、权重问题、盒模型和其属性、文本级标签和块级标签、浮动

    一.上次内容回顾 1.CSS的三种引入方式: 行内式 内接式 外接式 链接式 导入式 2.基础选择器和高级选择器 1)标签选择器 p{} 2)  id选择器 #nva{} 3) 类选择器 .nva{} ...