ajax上传图片

场景:
1、使用cropper裁剪图片、html2canvas合成图片后将图片上传至顽兔空间
2、运行环境手淘、天猫
3、C2B定制
采用方案及遇到的问题:
1、IOS+手淘/天猫环境无法使用顽兔Jssdk上传(由于走后台绕一圈必然浪费时间和性能,所以判断如果是Android则依然使用Jssdk)
2、使用js FormData,没有图片太大而无法上传的问题。然而IOS+手淘/天猫环境依然无法使用

canvas.toBlob(function(blob) {
    var formdata=new FormData();
    formdata.append('file',blob);
    $.ajax({
        url : url,
        data :  formdata,
        processData : false,
        contentType : false,
        dataType: 'json',
        type : "POST",
        success : function(data){}
    });
}, "image/png", 1.0);

3、转成base64字符串传递到后台(Android/IOS+手淘/天猫都可行)。但是图片一大就无法传输,直接进ajax的error了。
方案a:损失少量精度的情况下增加压缩率,使用jpeg格式

canvas.toDataURL("image/jpeg", 1.0);
canvas.toDataURL("image/jpeg", 0.9);
ajax:
data : {
    dataUrl: dataUrl.split(',')[1]
}

客户:有的图片太小了,连1M都不到。我:好的,马上改(mmp,包装那么小,明明大几百K的jpeg已经够清楚了)
方案b:还是采用无损的png,增加post方式提交数据的大小限制:

js:
canvas.toDataURL("image/png");
if(convertBase64UrlToFile(dataUrl).size < (1024 * 1024)) {
    Tida.toast("亲,裁剪图片小于1M会影响包装效果,请缩放裁切区域或上传更清晰的照片试试!");
    Tida.hideLoading();
    upBgPicAccess = 1;
    return;
}
服务器配置:
tomcat/conf/server.xml的Connector节点添加属性maxPostSize="8000000"#设置成0,负值都无效
本地maven jetty运行配置:启动命令添加:
jetty:run -Djetty.port=80 -Dorg.eclipse.jetty.server.Request.maxFormContentSize=5000000

使用阿里云Docker Tomcat镜像创建容器的话,处理上述问题有个坑:上述添加的属性需要添加在/acs/user/tomcat/conf/server.xml.temp,因为每次启动容器时(/acs/bin/start),会先删除server.xml,然后复制server.xml.temp到server.xml:


ps:cropper用起来很爽,效果也不错;html2canvas去官网下载最新的版本,老的版本兼容性差一些!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335