首页 > 编程语言 >c# form-data上传图片流到远程服务器

c# form-data上传图片流到远程服务器

时间:2022-08-30 09:00:37浏览次数:92  
标签:ch string form c# buffer 数组 new byte data

 先贴代码,后面做一些简单说明:

public static string sendPostHttpRequest_2(string url, byte[] postBytes, string contentType= "multipart/form-data; boundary=--------------------------71b23e4066ed")
        {
            string delimiter = "--------------------------71b23e4066ed";
            string eol = Environment.NewLine;
            string head = delimiter + eol
        + "Content-Disposition: form-data;piclen=" + postBytes.Length + eol
       + "Content-Type:image/jpeg" + "\r\n\r\n";
            string foot = "\r\n" + delimiter + "--\r\n";
 
            byte[] h_c = new ASCIIEncoding().GetBytes(head);
            byte[] f_c = new ASCIIEncoding().GetBytes(foot);
 
            WebRequest request = (WebRequest)HttpWebRequest.Create(url);
            request.Method = "POST";
            request.ContentType = contentType;
 
 
            request.ContentLength = postBytes.Length+ h_c.Length+f_c.Length;
            using (Stream outstream = request.GetRequestStream())
            {
                outstream.Write(h_c, 0, h_c.Length);//输出head
                outstream.Write(postBytes, 0, postBytes.Length);//输出图片字节
                outstream.Write(f_c, 0, f_c.Length);//输出尾部
            }
            string result = string.Empty;
            using (WebResponse response = request.GetResponse())
            {
                if (response != null)
                {
                    using (Stream stream = response.GetResponseStream())
                    {
                        using (StreamReader reader = new StreamReader(stream, Encoding.UTF8))
                        {
                            result = reader.ReadToEnd();
                        }
                    }
 
                }
            }
            return result;
        }

  

说明:

1)上面的代码中我的boundary=xxx是写死的,因为我对接的接口对方已经写死只获取这个分隔符.正常时候这里是会根据当前时间获取一个动态的字符串当做分隔符

2)输出的时候, outstream.Write 以前我的思路是先把参数拼接好以后直接一个输出就好了.结果拼接了好几个,发送出去以后对方都不能正常解析.最后在参考了一篇其他文章以后才恍然大悟.我可以分层次的输出呀.

 

备注:

下面放了一个很有启发的知识:

======================================开始

流:二进制

字节:无符号整数

字符:Unicode编码字符

字符串:多个Unicode编码字符

 

那么在.net下它们之间如何转化呢?

一般是遵守以下规则:

流->字节数组->字符数组->字符串

下面就来具体谈谈转化的语法

流->字节数组

MemoryStream ms = new MemoryStream();

byte[] buffer = new byte[ms.Length];

ms.Read(buffer, 0, (int)ms.Length);

 

字节数组->流

byte[] buffer = new byte[10];

MemoryStream ms = new MemoryStream(buffer);

 

字节数组->字符数组

1.

byte[] buffer = new byte[10];

char[] ch = new ASCIIEncoding().GetChars(buffer);

//或者:char[] ch = Encoding.UTF8.GetChars(buffer)

2.

byte[] buffer = new byte[10];

char[] ch = new char[10];

for(int i=0; i<buffer.Length; i++)

{

ch[i] = Convert.ToChar(buffer[i]);

}

 

字符数组->字节数组

1.

char[] ch = new char[10];

byte[] buffer = new ASCIIEncoding().GetBytes(ch);

//或者:byte[] buffer = Encoding.UTF8.GetBytes(ch)

2.

char[] ch = new char[10];

byte[] buffer = new byte[10];

for(int i=0; i<ch.Length; i++)

{

buffer[i] = Convert.ToByte(ch[i]);

}

 

字符数组->字符串

char[] ch = new char[10];

string str = new string(ch);

 

字符串->字符数组

string str = "abcde";

char[] ch=str .ToCharArray();

 

字节数组->字符串

byte[] buffer = new byte[10];

string str = System.Text.Encoding.UTF8.GetString(buffer);

//或者:string str = new ASCIIEncoding().GetString(buffer);

 

字符串->字节数组

string str = "abcde";

byte[] buffer=System.Text.Encoding.UTF8.GetBytes(str);

//或者:byte[] buffer= new ASCIIEncoding().GetBytes(str);

以上转的是 https://www.cnblogs.com/cc1120/p/9139454.html

======================================结束

在我的想法中,把所有的参数先转换为字符数组,然后拼接head,图片字节转换的字符数组,结束字符数组,然后把字符数组转换为字节进行发送.猜测应该是可行的,不过我自己在实际应用中是没有成功,可能是某一步转换格式的问题.因为项目要求太紧就没有继续尝试.

对了还有下面的一个知识点,有人知道是这样的吗?我是没有研究过不知道是不是.希望有大佬可以回答一下.

 

 

以上内容来源于百科书,可以关注我了解更多.

 

标签:ch,string,form,c#,buffer,数组,new,byte,data
From: https://www.cnblogs.com/sdjlq/p/16638092.html

相关文章

  • HCIA学习笔记二十六:手工负载分担模式二层链路聚合
    一、链路聚合的应用场景• 链路聚合一般部署在核心结点,以便提升整个网络的数据吞吐量。二、链路聚合• 链路聚合能够提高链路带宽,增强网络可用性,支持负载分担。三......
  • Mysql8.0修改lower_case_table_names参数导致重启失败
    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。GreatSQL是MySQL的国产分支版本,使用上与MySQL一致。事件起因:在测试一个数据迁移工具时,源端orac......
  • nacos2.1 新增配置发布失败。请检查参数是否正确
    使用官方的docker部署方式,部署了一个单节点nacosserver,部署完了后发布配置信息,报错“新增配置发布失败。请检查参数是否正确”解决方法:在nacosmysql数据库中分别在conf......
  • 关于c# 扩展方法
    1·c#如何扩展类型的内置方法c#如何扩展类型的内置方法-风之语者-博客园(cnblogs.com)https://www.cnblogs.com/WindBlog/archive/2011/07/29/2120655.html2·C#......
  • vue PC端调用摄像头实现人脸识别
    一、思路vue打开摄像头获取视频流数据->截取视频流通过canvas绘制图片->图片传到服务器识别(后端使用的是阿里的人脸识别api)二、直接上代码<template><divclass="fac......
  • VMware Workstation 不可恢复错误: (vcpu-0) c.382
    今天把虚拟机从旧机器拷贝到新机器,启动虚拟机报了个错:VMwareWorkstation不可恢复错误:(vcpu-0)vcpu-0:VERIFYvmcore/vmm/main/cpuid.c.382bugNr=1036521......看......
  • C++ inline
    1.inline可以免除函数调用时的保存上下文时的一些开销,其本质就是对此函数的每一个调用都以函数本体替换之。 inline的坏处:若在一台内存有限的机器上,过度热衷inlining会......
  • DataFrame与rdd之间的转换(val rdd1 = dataFrame.rdd)
    核心语句valrdd1=dataFrame.rddpackageSparkSQL.DataFreamCreate.dataframetorddimportorg.apache.spark.SparkConfimportorg.apache.spark.rdd.RDDimportorg.......
  • #1030 - Got error 176 "Read page with wrong checksum" from storage engine Aria
    从数据库列表中选择mysql。在表格列表中,勾选“db”旁边的框。滚动到页面底部,在显示“已选择”的选择框中,向下滚动至并选择“修复表”,然后选择“执行”。 ......
  • 【MySQL】DDL因Waiting for table metadata lock卡住
    在数据库空闲时间,对表做碎片整理:altertablemy_abcengine=innodb;发现会话被阻塞,显示状态是:Waitingfortablemetadatalock 手动断开alter操作后,通过showpr......