/**
* 请求响应数据
*/
class MsgResponse {
int code; // 状态代码,0 表示没有错误
Object data; // 数据内容,一般为字符串
String errmsg; // 错误消息
MsgResponse([this.code = 0, this.data = null, this.errmsg = ""]);
} static Map _makeHttpHeaders(
[String contentType,
String accept,
String token,
String XRequestWith,
String XMethodOverride]) {
Map headers = new Map<String, String>();
int i = 0; if (!strIsEmpty(contentType)) {
i++;
headers["Content-Type"] = contentType;
} if (!strIsEmpty(accept)) {
i++;
headers["Accept"] = accept;
} if (!strIsEmpty(token)) {
i++;
headers["Authorization"] = "bearer " + token;
} if (!strIsEmpty(XRequestWith)) {
i++;
headers["X-Requested-With"] = XRequestWith;
} if (!strIsEmpty(XMethodOverride)) {
i++;
headers["X-HTTP-Method-Override"] = XMethodOverride;
} if (i == 0) return null;
// print(headers.toString());
return headers;
} /** HTTP POST 上传文件 */
static Future<MsgResponse> httpUploadFile(
final String url,
final File file, {
String accept = "*/*",
String token,
String field = "picture-upload",
String file_contentType, // 默认为null,自动获取
}) async {
try {
List<int> bytes = await file.readAsBytes();
return await httpUploadFileData(url, bytes,
accept: accept,
token: token,
field: field,
file_contentType: file_contentType,
filename: file.path);
} catch (e) {
return new MsgResponse(699, null, e.toString());
}
} /** HTTP POST 上传文件 */
static Future<MsgResponse> httpUploadFileData(
final String url,
final List<int> filedata, {
String accept = "*/*",
String token,
String field = "picture-upload",
String file_contentType, // 默认为null,自动获取
String filename,
}) async {
try {
List<int> bytes = filedata;
var boundary = _boundaryString();
String contentType = 'multipart/form-data; boundary=$boundary';
Map headers =
_makeHttpHeaders(contentType, accept, token); //, "XMLHttpRequest"); // 构造文件字段数据
String data =
'--$boundary\r\nContent-Disposition: form-data; name="$field"; ' +
'filename="${getFileFullName(filename)}"\r\nContent-Type: ' +
'${(file_contentType == null) ? getMediaType(getFileExt(filename).toLowerCase()): file_contentType}\r\n\r\n';
var controller = new StreamController<List<int>>(sync: true);
controller.add(data.codeUnits);
controller.add(bytes);
controller.add("\r\n--$boundary--\r\n".codeUnits); controller.close();
bytes = await new Http.ByteStream(controller.stream).toBytes();
//print("bytes: \r\n" + UTF8.decode(bytes, allowMalformed: true)); Http.Response response =
await Http.post(url, headers: headers, body: bytes);
if (response.statusCode == 200) {
return new MsgResponse(0, response.body);
} else
return new MsgResponse(response.statusCode, response.body);
} catch (e) {
return new MsgResponse(699, null, e.toString());
}
} /** 生成随机字符串 */
static String randomStr(
[int len = 8, List<int> chars = _BOUNDARY_CHARACTERS]) {
var list = new List<int>.generate(
len, (index) => chars[_random.nextInt(chars.length)],
growable: false);
return new String.fromCharCodes(list);
} static const List<int> _BOUNDARY_CHARACTERS = const <int>[
0x30,
0x31,
0x32,
0x33,
0x34,
0x35,
0x36,
0x37,
0x38,
0x39,
0x61,
0x62,
0x63,
0x64,
0x65,
0x66,
0x67,
0x68,
0x69,
0x6A,
0x6B,
0x6C,
0x6D,
0x6E,
0x6F,
0x70,
0x71,
0x72,
0x73,
0x74,
0x75,
0x76,
0x77,
0x78,
0x79,
0x7A,
0x41,
0x42,
0x43,
0x44,
0x45,
0x46,
0x47,
0x48,
0x49,
0x4A,
0x4B,
0x4C,
0x4D,
0x4E,
0x4F,
0x50,
0x51,
0x52,
0x53,
0x54,
0x55,
0x56,
0x57,
0x58,
0x59,
0x5A
];
static const int _BOUNDARY_LENGTH = 48;
static final Random _random = new Random();
static String _boundaryString() {
var prefix = "---DartFormBoundary";
var list = new List<int>.generate(
_BOUNDARY_LENGTH - prefix.length,
(index) =>
_BOUNDARY_CHARACTERS[_random.nextInt(_BOUNDARY_CHARACTERS.length)],
growable: false);
return "$prefix${new String.fromCharCodes(list)}";
} static MediaType getMediaType(final String fileExt) {
switch (fileExt) {
case ".jpg":
case ".jpeg":
case ".jpe":
return new MediaType("image", "jpeg");
case ".png":
return new MediaType("image", "png");
case ".bmp":
return new MediaType("image", "bmp");
case ".gif":
return new MediaType("image", "gif");
case ".json":
return new MediaType("application", "json");
case ".svg":
case ".svgz":
return new MediaType("image", "svg+xml");
case ".mp3":
return new MediaType("audio", "mpeg");
case ".mp4":
return new MediaType("video", "mp4");
case ".htm":
case ".html":
return new MediaType("text", "html");
case ".css":
return new MediaType("text", "css");
case ".csv":
return new MediaType("text", "csv");
case ".txt":
case ".text":
case ".conf":
case ".def":
case ".log":
case ".in":
return new MediaType("text", "plain");
}
return null;
}

[Dart] Flutter 上传文件的更多相关文章

  1. IE8/9 JQuery.Ajax 上传文件无效

    IE8/9 JQuery.Ajax 上传文件有两个限制: 使用 JQuery.Ajax 无法上传文件(因为无法使用 FormData,FormData 是 HTML5 的一个特性,IE8/9 不支持) ...

  2. 三种上传文件不刷新页面的方法讨论:iframe/FormData/FileReader

    发请求有两种方式,一种是用ajax,另一种是用form提交,默认的form提交如果不做处理的话,会使页面重定向.以一个简单的demo做说明: html如下所示,请求的路径action为"up ...

  3. asp.net mvc 上传文件

    转至:http://www.cnblogs.com/fonour/p/ajaxFileUpload.html 0.下载 http://files.cnblogs.com/files/fonour/aj ...

  4. app端上传文件至服务器后台,web端上传文件存储到服务器

    1.android前端发送服务器请求 在spring-mvc.xml 将过滤屏蔽(如果不屏蔽 ,文件流为空) <!-- <bean id="multipartResolver&q ...

  5. .net FTP上传文件

    FTP上传文件代码实现: private void UploadFileByWebClient() { WebClient webClient = new WebClient(); webClient ...

  6. 通过cmd完成FTP上传文件操作

    一直使用 FileZilla 这个工具进行相关的 FTP 操作,而在某一次版本升级之后,发现不太好用了,连接老是掉,再后来完全连接不上去. 改用了一段时间的 Web 版的 FTP 工具,后来那个页面也 ...

  7. 前端之web上传文件的方式

    前端之web上传文件的方式 本节内容 web上传文件方式介绍 form上传文件 原生js实现ajax上传文件 jquery实现ajax上传文件 form+iframe构造请求上传文件 1. web上传 ...

  8. Django session cookie 上传文件、详解

    session 在这里先说session 配置URL from django.conf.urls import patterns, include, url from django.contrib i ...

  9. 4 django系列之HTML通过form标签来同时提交表单内容与上传文件

    preface 我们知道提交表单有2种方式,一种直接通过submit页面刷新方法来提交,另一种通过ajax异步局部刷新的方法提交,上回我们说了通过ajax来提交文件到后台,现在说说通过submit来提 ...

随机推荐

  1. 很全面的WinRAR实用技巧系列 - imsoft.cnblogs

    WinRAR也可以管理我的桌面时间长了,桌面上堆的东西实在太多,平时该如何管理呢?安装了WinRAR的朋友可以请它来帮忙,用它管理清除无用的桌面文件或图标. 以XP系统为例,系统所在目录是“c:\wi ...

  2. Spring AOP关于cglib动态代理

    一: Spring AOP的默认代理方式是jdk动态代理,还有另外一种代理方式是cglib代理,简单说前者基于接口,后者基于继承,基本思路是将被代理对象的类作为父类,然后创建子类来进行方法的调用,调用 ...

  3. HDU 2089:不要62

    Problem Description 杭州人称那些傻乎乎粘嗒嗒的人为62(音:laoer). 杭州交通管理局经常会扩充一些的士车牌照,新近出来一个好消息,以后上牌照,不再含有不吉利的数字了,这样一来 ...

  4. 2018-2019-2 网络对抗技术 20165212 Exp4 恶意代码分析

    2018-2019-2 网络对抗技术 20165212 Exp4 恶意代码分析 原理与实践说明 1.实践目标 监控你自己系统的运行状态,看有没有可疑的程序在运行. 分析一个恶意软件,就分析Exp2或E ...

  5. hdu1208 dp

    题意:给了一个 n * n 的方格图,要从图的左上角走到右下角 ,每次只能向右或者向下走,走的格数为当前格子上的数字,问共有多少中走法. 一开始我看到之后觉得这题完全可以用记忆化搜索来做,dfs 一遍 ...

  6. IP相关的方法

    1.验证是否为IP地址 def isIP(ip, with_netmask=True): """ 判断IP的格式是否正确 :param ip: IP字符串 :param ...

  7. UVA10003 【Cutting Sticks】

    [分析] 设d(i,j)为切割小木棍i-j的最优费用,则d(i,j)=min{d(i,k)+d(k,j)|i<k<j}+a[j]-a[i],其 中最后一项a[j]-a[i]代表第一刀的费用 ...

  8. hadoop之 心跳时间与冗余快清除

    1.Hadoop datanode节点超时时间设置 datanode进程死亡或者网络故障造成datanode无法与namenode通信,namenode不会立即把该节点判定为死亡,要经过一段时间,这段 ...

  9. junit 知识点

    JUnit 测试框架具有以下重要特性: 测试工具 测试套件 测试运行器 测试分类 测试工具 测试工具是一整套固定的工具用于基线测试.测试工具的目的是为了确保测试能够在共享且固定的环境中运行,因此保证测 ...

  10. Cropperjs 插件知识点

    cropper.js 通过 canvas 实现图片裁剪,最后再通过 canvas 获取裁剪区域的图片base64串. 1. Container 容器 2. canvas 图片 3. crop 裁剪框