POST 方式上传图片

Post 方式 模仿 form表单 上传 图片 设置enctype = multipart/form-data

<form  enctype="multipart/form-data"></form>

 

自定义 MultipartFormData 类  (4.5以上版本好像有这个类  类名称叫啥忘记了)

/// <summary>
    /// multipart/form-data 数据类型
    /// </summary>
    public class MultipartFormData
    {
        public static string ContentType = "multipart/form-data; boundary=A300x";
        private string headerStream = "--A300x\r\nContent-Disposition: form-data; name=\"{0}\"; filename=\"{1}\"\r\nContent-Type: application/octet-stream\r\n\r\n";
        private string footerString = "--A300x--\r\n";
        private string compart = "\r\n";
        private string headerString = "--A300x\r\nContent-Disposition: form-data; name=\"{0}\"\r\n\r\n";

        private List<byte> lists = new List<byte>();
        private byte[] footerBytes;
        private byte[] comparts;
        public MultipartFormData()
        {
            footerBytes = Encoding.UTF8.GetBytes(footerString);
            comparts = Encoding.UTF8.GetBytes(compart);
        }
        public byte[] Buffer
        {
            get
            {
                return lists.ToArray();
            }
        }

        private bool IsEnd = false;
        /// <summary>
        ///
        /// </summary>
        public void End()
        {
            if (!IsEnd)
            {
                IsEnd = true;
                //lists.AddRange(footerBytes.ToList());
                this.AddRanges(footerBytes);
            }

        }

        public void AddRanges(byte[] array) {
            foreach (byte b in array)
                lists.Add(b);
        }

        /// <summary>
        /// 向序列化到多部/窗体数据 MIME 类型的 对象集合添加 HTTP 内容
        /// </summary>
        /// <param name="content">要添加到集合中的 HTTP 内容</param>
        /// <param name="name">要添加的 HTTP 内容的名称</param>
        public void Add(string content, string name)
        {

            byte[] headerBytes = Encoding.UTF8.GetBytes(String.Format(headerString, name));
            this.AddRanges(headerBytes);
            byte[] buffer = Encoding.UTF8.GetBytes(content);
            this.AddRanges(buffer);
            this.AddRanges(comparts);

        }

        /// <summary>
        /// 向序列化到多部/窗体数据 MIME 类型的 对象集合添加 HTTP 内容
        /// </summary>
        /// <param name="content">要添加到集合中的 HTTP 内容</param>
        /// <param name="name">要添加的 HTTP 内容的名称</param>
        /// <param name="fileName">要添加到集合中的 HTTP 内容的文件名</param>
        public void Add(Stream content, string name, string fileName)
        {
            byte[] headerBytes = Encoding.UTF8.GetBytes(String.Format(headerStream, name, fileName));
            this.AddRanges(headerBytes);
            byte[] buffer = new byte[content.Length];
            content.Read(buffer, 0, buffer.Length);
            content.Seek(0, SeekOrigin.Begin);
            this.AddRanges(buffer);
            this.AddRanges(comparts);
        }

        /// <summary>
        /// 向序列化到多部/窗体数据 MIME 类型的 对象集合添加 HTTP 内容
        /// </summary>
        /// <param name="content">要添加到集合中的 HTTP 内容</param>
        /// <param name="name">要添加的 HTTP 内容的名称</param>
        /// <param name="fileName">要添加到集合中的 HTTP 内容的文件名</param>
        public void Add(byte[] content, string name, string fileName)
        {
            byte[] headerBytes = Encoding.UTF8.GetBytes(String.Format(headerStream, name, fileName));
            this.AddRanges(headerBytes);
            this.AddRanges(content);
            this.AddRanges(comparts);
        }

    }
 
 
上传图片代码
        /// <summary>
        /// form-data 数据类型传递数据
        /// </summary>
        private MultipartFormData multiparFormData = new MultipartFormData();

        /// <summary>
        /// 键值对应
        /// </summary>
        /// <param name="key"></param>
        /// <param name="value"></param>
        public void AddFormData(string key, string value)
        {
            this.multiparFormData.Add(value, key);
        }
		/// <summary>
        /// 传递一个 strem 类型
        /// </summary>
        /// <param name="key"></param>
        /// <param name="value"></param>
        /// <param name="fileName"></param>
        public void AddFormData(string key, Stream value, string fileName)
        {
            this.multiparFormData.Add(value, key, fileName);
        }
        /// <summary>
        /// 传递一个 byte[] 类型
        /// </summary>
        /// <param name="key"></param>
        /// <param name="value"></param>
        /// <param name="fileName"></param>
        public void AddFormData(string key, byte[] value, string fileName)
        {
            this.multiparFormData.Add(value, key, fileName);
        }
        private static CookieContainer m_Cookie = new CookieContainer();
		/// <summary>
        /// POST form-data 方式请求消息
        /// </summary>
        /// <param name="url"></param>
        /// <param name="isHttps"></param>
        /// <returns></returns>
        public string PostFromData(string url, bool isHttps) {
            try
            {
                multiparFormData.End();

                HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(url);
                request.Method = "POST";
                request.ContentType = MultipartFormData.ContentType;
                request.CookieContainer = m_Cookie;//设置上一个访问页面的cookie 保持session
                request.ContentLength = multiparFormData.Buffer.Length;

                Stream stream = request.GetRequestStream();

                stream.Write(multiparFormData.Buffer, 0, multiparFormData.Buffer.Length);
                stream.Close();

                WebResponse response = request.GetResponse();
                Stream streamResponse = response.GetResponseStream();
                StreamReader sr = new StreamReader(streamResponse);

                return sr.ReadToEnd();
            }
            catch (Exception ex) {
                Log.WriteLog("POST form-data 方式请求消息:" + ex.Message);
                return "error";
            }
        }
时间: 2024-11-05 07:58:02

POST 方式上传图片的相关文章

MVC 使用AJAX POST上传图片的方式

我们来总结一下使用AJAX以POST方式上传图片的方法. 一.普遍的一种是以file的格式请求.在Request.Files中获取文件. public ActionResult UploadFile(HttpContext request) { HttpPostedFileBase img = Request.Files[0]; string path = AppDomain.CurrentDomain.BaseDirectory + @"Upload/"; img.SaveAs(Pa

ueditor1.4.3---php版本上传图片路径的修改

在ueditor文件目录里面找到php/config.json文件进行修改 我的目的是想将上传目录修改到网站根目录下面的uploadfile目录,,我是这样修改的,直接看代码就明白...上面标志出来的就是我修改过的代码 /* 前后端通信相关的配置,注释只允许使用多行方式 */ { /* 上传图片配置项 */ "imageActionName": "uploadimage", /* 执行上传图片的action名称 */ "imageFieldName&quo

部分安卓手机微信浏览器中使用XMLHttpRequest 2上传图片显示字节数为0的解决办法

前端JS中使用XMLHttpRequest 2上传图片到服务器,PC端和大部分手机上都正常,但在少部分安卓手机上上传失败,服务器上查看图片,显示字节数为0.下面是上传图片的核心代码: HTML <input type="file" id="choose" capture="camera" accept="image/*"> JavaScript var filechooser = document.getEleme

百度编辑器在服务器置顶路径 解决上传图片创建目录失败的方法(Thinkphp)

1.设置文件夹权限 2.修改 /* 前后端通信相关的配置,注释只允许使用多行方式 */ { /* 上传图片配置项 */ "imageActionName": "uploadimage", /* 执行上传图片的action名称 */ "imageFieldName": "upfile", /* 提交的图片表单名称 */ "imageMaxSize": 2048000, /* 上传大小限制,单位B */ &qu

使用data:uri上传图片

上传图片的方式有两种,一种是使用传统的html控件的方式,设置form属性为multipart/form-data.这种方式兼容ie6,ie7.另一种方式是使用data:uri,将base64编码从浏览器端post到服务器端,然后利用Base64解码即可.这种方式只是用与比较modern的浏览器,比如ie9,chrome,firefox,safari.本文主要讲讲我们如何利用data:uri的方式上传图片的. Data URI 格式  data URI的格式非常简单,具体可以看RFC2397,d

微信小程序/网站 上传图片到腾讯云COS

COS简介: 腾讯云提供的一种对象存储服务,供开发者存储海量文件的分布式存储服务.可以将自己开发的应用的存储部分全部接入COS的存储桶中,有效减少应用服务器的带宽,请求等.个人也可以通过腾讯云账号免费使用COS6个月,https://cloud.tencent.com/product/cos 整体流程简介:  1. 前端引入cos的SDK文件 2. 监听上传控件,并在图片加载至网页临时流中发起签名请求 3.后端根据上传的请求方式和路径参数返回签名Authorization和token XCosS

100offer举办的「寻找实干和坚持的技术力量」开源项目投票排名分析程序

由于100offer举办的「寻找实干和坚持的技术力量」开源项目投票活动没有按照票数排序的功能,所以本文写了个小程序来实现这个功能,代码如下: import org.jsoup.Jsoup; import org.jsoup.nodes.Element; import java.net.URL; import java.util.HashMap; import java.util.Map; import java.util.concurrent.atomic.AtomicInteger; /**

解决PHPCMS使用ueditor时缩略图上传问题

/* 前后端通信相关的配置,注释只允许使用多行方式 */ {     /* 上传图片配置项 */     "imageActionName": "uploadimage", /* 执行上传图片的action名称 */     "imageFieldName": "upfile", /* 提交的图片表单名称 */     "imageMaxSize": 2048000, /* 上传大小限制,单位B */   

TeamCity编译执行selenium上传窗口脚本缺陷

TeamCity编译selenium脚本,对于上传窗口处理只支持sendKeys的使用,不支持模拟人为按下Enter键和使用autoIt等操作,即使本地调试通过的脚本,提交编译执行后,也是报错,原因是teamCity编译执行脚本的过程中,只是后台启动相应浏览器的driver,没有真实打开一个浏览器导致的.发现这个缺陷还得从编写上传课件测试用例脚本说起. 一个上传课程测试用例,功能测试是,填写课程的基本信息后,上传课程的图片,如图1,图片上传成功后,系统会提示“图片上传成功”,然后点击[选择]按钮