由于参数中是base64编码后的图片数据,图片比较大,导致get请求失败,提示数据太大。
get最大是256b,post是2M。
解决方式:
使用伪post方式:
//上传图片方法 function picUpload(){ var ocrImageSrc = document.querySelector('#ocr_img').childNodes[0].src; //window.parent.self.open(encodeURI((hostUrl+"?reportlet=/CRM/联系人新建_名片信息录入.cpt&op=write&photo="+ocrImageSrc)),"_self"); openPostWindow(encodeURI(hostUrl+"?reportlet=/CRM/联系人新建_名片信息录入.cpt&op=write"),encodeURI(ocrImageSrc),'_parent'); //alert(encodeURI((hostUrl+"?reportlet=/CRM/联系人新建_名片信息录入.cpt&op=write&photo="))); } /** * 使用post方式打开画面,解决self.open传输数据get方法的传输数据量限制 */ function openPostWindow(url, data, name) { var tempForm = document.createElement("form"); tempForm.id="tempForm1"; tempForm.method="post"; tempForm.action=url; tempForm.target=name; var hideInput = document.createElement("input"); hideInput.type="hidden"; hideInput.name= "photo" hideInput.value= data; tempForm.appendChild(hideInput); tempForm.addEventListener("onsubmit",function(){ openWindow(url,name); }); document.body.appendChild(tempForm); fireEvent(tempForm,"onsubmit"); tempForm.submit(); document.body.removeChild(tempForm); } /** * 打开画面 */ function openWindow(url,name) { self.open(url,name,'height=400, width=400, top=0, left=0, toolbar=yes, menubar=yes, scrollbars=yes, resizable=yes,location=yes, status=yes'); }
------------------------------------------------------------------------------------------------------------------------------------------------------------------------
重点:可以使用AJAX POST跨域方式,详情请见:http://blog.csdn.net/danfeixia/article/details/71599304