使用快递鸟电子面单api 和 C-Lodop 打印订单 发货电子面单模板

2019-12-23 14:25:47 浏览2805次 作者: 取名麻烦

收藏

大体流程 
1、本地安装C-Lodop云打印控件 ,下载安装即可,下载地址 http://www.lodop.net/download.html ,安装后需要 定义IP端口 默认8000,若你的项目使用了https可用8443,记录并保存 端口 如下


$JS@1IP]4)M9I]C6[$T]5KC.png


2、html模板中与C-lodop建立连接 如下


IGAY3Q4B5S5H5C]~D%SY)GF.png

获取保存的IP端口 并组成 连接地址 映射到 模板


模板中 引入js 并初始化


]VYJDZC[}A517GY()TXK9%4.png

%`_U0FCS)AZW1BM(EA72~6V.png

lodopfuncs.js如下

var CreatedOKLodop7766=null;

//====判断是否需要安装CLodop云打印服务器:====
function needCLodop(){
    try{
   var ua=navigator.userAgent;
   if (ua.match(/Windows\sPhone/i) !=null) return true;
   if (ua.match(/iPhone|iPod/i) != null) return true;
   if (ua.match(/Android/i) != null) return true;
   if (ua.match(/Edge\D?\d+/i) != null) return true;
   if (ua.match(/QQBrowser/i) != null) return false;
   var verTrident=ua.match(/Trident\D?\d+/i);
   var verIE=ua.match(/MSIE\D?\d+/i);
   var verOPR=ua.match(/OPR\D?\d+/i);
   var verFF=ua.match(/Firefox\D?\d+/i);
   var x64=ua.match(/x64/i);
   if ((verTrident==null)&&(verIE==null)&&(x64!==null)) 
      return true; else
   if ( verFF !== null) {
      verFF = verFF[0].match(/\d+/);
      if ( verFF[0] >= 42 ) return true;
   } else 
   if ( verOPR !== null) {
      verOPR = verOPR[0].match(/\d+/);
      if ( verOPR[0] >= 32 ) return true;
   } else 
   if ((verTrident==null)&&(verIE==null)) {
      var verChrome=ua.match(/Chrome\D?\d+/i);      
      if ( verChrome !== null ) {
         verChrome = verChrome[0].match(/\d+/);
         if (verChrome[0]>=42) return true;
      };
   };
        return false;
    } catch(err) {return true;};
};

//====页面引用CLodop云打印必须的JS文件:====
//if (needCLodop()) {
//  //让其它电脑的浏览器通过本机打印(适用例子):
//  oscript = document.createElement("script");
//  oscript.src ="/CLodopfuncs.js";
//  var head = document.head || document.getElementsByTagName("head")[0] || document.documentElement;
//  head.insertBefore( oscript,head.firstChild );
//  //让本机浏览器打印(更优先):
//  var oscript = document.createElement("script");
//  oscript.src ="http://localhost:8000/CLodopfuncs.js?priority=1";
//  var head = document.head || document.getElementsByTagName("head")[0] || document.documentElement;
//  head.insertBefore( oscript,head.firstChild );
//};

//====获取LODOP对象的主过程:====
function getLodop(oOBJECT,oEMBED){
    var strHtmInstall="<br><font color='#FF00FF'>打印控件未安装!点击这里<a href='install_lodop32.exe' target='_self'>执行安装</a>,安装后请刷新页面或重新进入。</font>";
    var strHtmUpdate="<br><font color='#FF00FF'>打印控件需要升级!点击这里<a href='install_lodop32.exe' target='_self'>执行升级</a>,升级后请重新进入。</font>";
    var strHtm64_Install="<br><font color='#FF00FF'>打印控件未安装!点击这里<a href='install_lodop64.exe' target='_self'>执行安装</a>,安装后请刷新页面或重新进入。</font>";
    var strHtm64_Update="<br><font color='#FF00FF'>打印控件需要升级!点击这里<a href='install_lodop64.exe' target='_self'>执行升级</a>,升级后请重新进入。</font>";
    var strHtmFireFox="<br><br><font color='#FF00FF'>(注意:如曾安装过Lodop旧版附件npActiveXPLugin,请在【工具】->【附加组件】->【扩展】中先卸它)</font>";
    var strHtmChrome="<br><br><font color='#FF00FF'>(如果此前正常,仅因浏览器升级或重安装而出问题,需重新执行以上安装)</font>";
    var strCLodopInstall="<br><font color='#FF00FF'>CLodop云打印服务(localhost本地)未安装启动!点击这里<a href='CLodopPrint_Setup_for_Win32NT.exe' target='_self'>执行安装</a>,安装后请刷新页面。</font>";
    var strCLodopUpdate="<br><font color='#FF00FF'>CLodop云打印服务需升级!点击这里<a href='CLodopPrint_Setup_for_Win32NT.exe' target='_self'>执行升级</a>,升级后请刷新页面。</font>";
    var LODOP;
    try{
        var isIE = (navigator.userAgent.indexOf('MSIE')>=0) || (navigator.userAgent.indexOf('Trident')>=0);
        if (needCLodop()) {
            try{ LODOP=getCLodop();} catch(err) {};
       if (!LODOP && document.readyState!=="complete") {alert("C-Lodop没准备好,请稍后再试!"); return;};
            if (!LODOP) {
       if (isIE) document.write(strCLodopInstall); else
       document.documentElement.innerHTML=strCLodopInstall+document.documentElement.innerHTML;
                 return;
            } else {

            if (CLODOP.CVERSION<"2.0.4.0") { 
         if (isIE) document.write(strCLodopUpdate); else
         document.documentElement.innerHTML=strCLodopUpdate+document.documentElement.innerHTML;
       };
       if (oEMBED && oEMBED.parentNode) oEMBED.parentNode.removeChild(oEMBED);
       if (oOBJECT && oOBJECT.parentNode) oOBJECT.parentNode.removeChild(oOBJECT);   
       };
        } else {
            var is64IE  = isIE && (navigator.userAgent.indexOf('x64')>=0);
            //=====如果页面有Lodop就直接使用,没有则新建:==========
            if (oOBJECT!=undefined || oEMBED!=undefined) {
                if (isIE) LODOP=oOBJECT; else  LODOP=oEMBED;
            } else if (CreatedOKLodop7766==null){
                LODOP=document.createElement("object");
                LODOP.setAttribute("width",0);
                LODOP.setAttribute("height",0);
                LODOP.setAttribute("style","position:absolute;left:0px;top:-100px;width:0px;height:0px;");
                if (isIE) LODOP.setAttribute("classid","clsid:2105C259-1E0C-4534-8141-A753534CB4CA");
                else LODOP.setAttribute("type","application/x-print-lodop");
                document.documentElement.appendChild(LODOP);
                CreatedOKLodop7766=LODOP;
             } else LODOP=CreatedOKLodop7766;
            //=====Lodop插件未安装时提示下载地址:==========
            if ((LODOP==null)||(typeof(LODOP.VERSION)=="undefined")) {
                 if (navigator.userAgent.indexOf('Chrome')>=0)
                     document.documentElement.innerHTML=strHtmChrome+document.documentElement.innerHTML;
                 if (navigator.userAgent.indexOf('Firefox')>=0)
                     document.documentElement.innerHTML=strHtmFireFox+document.documentElement.innerHTML;
                 if (is64IE) document.write(strHtm64_Install); else
                 if (isIE)   document.write(strHtmInstall);    else
                     document.documentElement.innerHTML=strHtmInstall+document.documentElement.innerHTML;
                 return LODOP;
            };
        };
        if (LODOP.VERSION<"6.2.0.3") {
            if (needCLodop())
            document.documentElement.innerHTML=strCLodopUpdate+document.documentElement.innerHTML; else
            if (is64IE) document.write(strHtm64_Update); else
            if (isIE) document.write(strHtmUpdate); else
            document.documentElement.innerHTML=strHtmUpdate+document.documentElement.innerHTML;
            return LODOP;
        };
        //===如下空白位置适合调用统一功能(如注册语句、语言选择等):===

        //===========================================================
        return LODOP;
    } catch(err) {alert("getLodop出错:"+err);};
};

2、保存快递鸟需要的配置信息  快递鸟注册地址 http://www.kdniao.com/reg 如下

)W4N0VH5P(JJ%49H_A`C%W7.png

3、提交数据到 快递鸟 电子面单api接口 并返回打印模板  传递给 前端 使用js 调起打印

快递鸟 电子面单api接口 提交可以参考官方文档 http://www.kdniao.com/api-eorder
得到电子面单模板 传给 前端js 调用打印如下

$(function(){
    window.isCLodop = true;
    if(typeof getCLodop ==='undefined'){
        window.isCLodop = false;
        window.LodopTip = "打印控件错误:\r\n未开启打印控件或配置端口不正确!\r\n检查以上两项后刷新页面重试!";
        alert(LodopTip);
    }
    var LODOP=getCLodop();
    LODOP.ADD_PRINT_HTM(0,0,'100%','100%',PrintTemplate);//PrintTemplate 后端返回的 电子面单模板
    LODOP.NewPage();
    
    if(!iserr){
            // 获取打印状态
            if (LODOP.CVERSION) {
                LODOP.On_Return=function(TaskID,Value){
                    if (Value==1){
                        alert("已提交至打印机");
                    }else{
                        alert("打印已取消");
                    }
                };
                LODOP.SET_PREVIEW_WINDOW(0,0,0,0,0,"");
                LODOP.SET_SHOW_MODE("PREVIEW_NO_MINIMIZE",true)
                LODOP.PREVIEW();
                return;
            };
       }
});


当您发现内容错误或代码bug,以及下载链接无法使用等,请点击屏幕右下角的上报错误来进行提交,我们会尽快修正。
本程序所有源码和工具完全免费,当本网站内容如果侵犯了您的权益,请联系我们,我们会尽快处理,感谢您的合作。

收藏 分享

相关文章

评论:

文明上网理性发言,请遵守 新闻评论服务协议

当前还没有评论,快来评论吧

上报错误