wps加载项在vue2项目中的应用(publish模式)

wps加载项在vue2项目中的应用

应用代码:
wps.js

/**
 * WPS OA助手-WPS启动方法入口
 */
var pluginsMode = location.search.split("=")[1]; //截取url中的参数值
var pluginType = WpsInvoke.ClientType.wps; //加载项类型wps,et,wpp
var pluginName = "WpsOAAssist"; //加载项名称
var wpsClient = new WpsClient(pluginType); //初始化一个多进程对象,多进程时才需要
var clientStr = pluginName + pluginType + "ClientId";
//单进程封装开始
/**
 * 此方法是根据wps_sdk.js做的调用方法封装
 * 可参照此定义
 * @param {*} funcs         这是在WPS加载项内部定义的方法,采用JSON格式(先方法名,再参数)
 * @param {*} front         控制着通过页面执行WPS加载项方法,WPS的界面是否在执行时在前台显示
 * @param {*} jsPluginsXml  指定一个新的WPS加载项配置文件的地址,动态传递jsplugins.xml模式,例如:http://127.0.0.1:3888/jsplugins.xml
 * @param {*} isSilent      隐藏打开WPS,如果需要隐藏,那么需要传递front参数为false
 */

export function _Wps(funcs, front, jsPluginsXml, isSilent) {
    var info = {};
    info.funcs = funcs;
    if (isSilent) {
        //隐藏启动时,front必须为false
        front = false;
    }
    /**
     * 下面函数为调起WPS,并且执行加载项WpsOAAssist中的函数dispatcher,该函数的参数为业务系统传递过去的info
     */
    if (pluginsMode != 2) {
        //单进程
        singleInvoke(info, front, jsPluginsXml, isSilent);
    } else {
        //多进程
        multInvoke(info, front, jsPluginsXml, isSilent);
    }
}

//单进程
function singleInvoke(info, front, jsPluginsXml, isSilent) {
    WpsInvoke.InvokeAsHttp(
        pluginType, // 组件类型
        pluginName, // 插件名,与wps客户端加载的加载的插件名对应
        "dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
        info, // 传递给插件的数据
        function (result) {
            console.log(result, 44545)
            // 调用回调,status为0为成功,其他是错误
            if (result.status) {
                if (result.status == 100) {
                    WpsInvoke.AuthHttpesCert(
                        '请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。'
                    );
                    return;
                }
                alert(result.message);
            } else {
                console.log(result.response);
                showresult(result.response);
            }
        },
        front,
        jsPluginsXml,
        isSilent
    );

    /**
     * 接受WPS加载项发送的消息
     * 接收消息:WpsInvoke.RegWebNotify(type,name,callback)
     * WPS客户端返回消息: wps.OAAssist.WebNotify(message)
     * @param {*} type 加载项对应的插件类型
     * @param {*} name 加载项对应的名字
     * @param {func} callback 接收到WPS客户端的消息后的回调函数,参数为接受到的数据
     */
    WpsInvoke.RegWebNotify(pluginType, pluginName, handleOaMessage);
}
//多进程
function multInvoke(info, front, jsPluginsXml, isSilent) {
    wpsClient.jsPluginsXml = jsPluginsXml
        ? jsPluginsXml
        : "http://192.168../cdn/wps-oa/jsplugins.xml"; //这里改成自己起的服务地址
    if (localStorage.getItem(clientStr)) {
        wpsClient.clientId = localStorage.getItem(clientStr);
    }
    if (isSilent) {
        wpsClient.StartWpsInSilentMode(pluginName, function () {
            //隐藏启动后的回调函数
            mult(info, front);
        });
    } else {
        mult(info, front);
    }
    wpsClient.onMessage = handleOaMessage;
}
//多进程二次封装
function mult(info, front) {
    wpsClient.InvokeAsHttp(
        pluginName, // 插件名,与wps客户端加载的加载的插件名对应
        "dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
        info, // 传递给插件的数据
        function (result) {
            // 调用回调,status为0为成功,其他是错误
            if (wpsClient.clientId) {
                localStorage.setItem(clientStr, wpsClient.clientId);
            }
            if (result.status !== 0) {
                console.log(result);
                if (result.message == '{"data": "Failed to send message to WPS."}') {
                    wpsClient.IsClientRunning(function (status) {
                        console.log(status);
                        if (status.response == "Client is running.")
                            alert(
                                "任务发送失败,WPS 正在执行其他任务,请前往WPS完成当前任务"
                            );
                        else {
                            wpsClient.clientId = "";
                            wpsClient.notifyRegsitered = false;
                            localStorage.setItem(clientStr, "");
                            mult(info);
                        }
                    });
                    return;
                } else if (result.status == 100) {
                    // WpsInvoke.AuthHttpesCert('请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。')
                    return;
                }
                alert(result.message);
            } else {
                console.log(result.response);
            }
        },
        front
    );
}
function handleOaMessage(data) {
    console.log(data);
}

function handleOaFunc1(message) {
    alert("我是函数handleOaFunc1,我接收到的参数是:" + message);
}
function handleOaFunc2(message) {
    alert("我是函数handleOaFunc2,我接收到的参数是:" + message);
    var span = window.parent.document.getElementById("webnotifyspan");
    span.innerHTML = message;
}
/**
 * 处理WPS加载项的方法返回值
 *
 * @param {*} resultData
 */
function showresult(resultData) {
    let json = eval("(" + resultData + ")");
    switch (json.message) {
        case "GetDocStatus": {
            let docstatus = json.docstatus;
            if (typeof docstatus != "undefined") {
                let str =
                    "文档保存状态:" +
                    docstatus.saved +
                    "\n文档字数:" +
                    docstatus.words +
                    "\n文档页数:" +
                    docstatus.pages;
                alert(str);
            }
        }
    }
}

wpsFun.js

/**
 * WPS OA助手公用方法
 *
 */
import { wps_sdk } from "@/util/wpsjsrpcsdk.js";
import { _Wps } from "@/util/wps.js";
import { _Et } from "@/util/et.js";
// 打开文档
export function openDoc(data) {
    //  保存文档上传路径
    let baseUrl = "";
    let port = "/path";
    data.uploadPath = baseUrl + port + "? "filepath=" + data.filePath + "&originalName=" + data.originalName;
    if (data.onLoadType == "wps") {
        _Wps([
            {
                OpenDoc: {
                    docId: data.docId || "", // 文档ID
                    uploadPath: data.uploadPath, // 保存文档上传路径
                    fileName: data.fileName, // 文件路径
                    uploadFieldName: data.uploadFieldName || "", // 文件上传名称
                    userName: store.state.user.userInfo.nick_name || ""
                }
            }
        ]); // OpenDoc方法对应于OA助手dispatcher支持的方法名
    } else if (data.onLoadType == "et") {
        _Et([
            {
                OpenDoc: {
                    docId: data.docId || "", // 文档ID
                    uploadPath: data.uploadPath, // 保存文档上传路径
                    fileName: data.fileName, // 文件路径
                    uploadFieldName: data.uploadFieldName || "", // 文件上传名称
                    userName: store.state.user.userInfo.nick_name || ""
                },
            }
        ]); // OpenDoc方法对应于OA助手dispatcher支持的方法名
    }
}

/**
 * WPS OA助手启动封装方法
 */
(function(global, factory) {
  "use strict";

  if (typeof module === "object" && typeof module.exports === "object") {
    module.exports = factory(global, true);
  } else {
    factory(global);
  }
})(typeof window !== "undefined" ? window : this, function(window, noGlobal) {
  "use strict";

  var bFinished = true;

  /**
   * 兼容IE低版本的创建httpobj对象的方法
   * @returns httpobj,可用于进行数据传输的http的对象
   */
  function getHttpObj() {
    var httpobj = null;
    if (IEVersion() < 10) {
      try {
        httpobj = new XDomainRequest();
      } catch (e1) {
        httpobj = new createXHR();
      }
    } else {
      httpobj = new createXHR();
    }
    return httpobj;
  }
  //兼容IE低版本的创建xmlhttprequest对象的方法
  /**
   * 兼容IE低版本的创建xmlhttprequest对象的方法
   * @returns xmlhttprequest对象,兼容低版本IE
   */
  function createXHR() {
    if (typeof XMLHttpRequest != "undefined") {
      //兼容高版本浏览器
      return new XMLHttpRequest();
    } else if (typeof ActiveXObject != "undefined") {
      //IE6 采用 ActiveXObject, 兼容IE6
      var versions = [
        //由于MSXML库有3个版本,因此都要考虑
        "MSXML2.XMLHttp.6.0",
        "MSXML2.XMLHttp.3.0",
        "MSXML2.XMLHttp"
      ];

      for (var i = 0; i < versions.length; i++) {
        try {
          return new ActiveXObject(versions[i]);
        } catch (e) {
          //跳过
        }
      }
    } else {
      throw new Error("您的浏览器不支持XHR对象");
    }
  }

  /**
   * 通过该接口给服务器发请求
   * @param {*} options       参数对象,具体包含的参数如下:
   * @param {*} url           网页路径,传输地址
   * @param {*} type          传输类型,POST / GET / PUT
   * @param {*} sendData      传输的数据
   * @param {*} callback      回调函数
   * @param {*} tryCount      请求失败后的尝试次数
   * @param {*} bPop          是否弹出浏览器提示对话框
   * @param {*} timeout       请求等待响应的时间,超过时间请求实效
   * @param {*} concurrent    请求是否同步发送
   * @param {*} client        wpsclient对象
   * @returns NULL
   */
  function startWps(options) {
    console.log("startWps",options);
    if (!bFinished && !options.concurrent) {
      if (options.callback)
        options.callback({
          status: 1,
          message: "上一次请求没有完成"
        });
      return;
    }
    bFinished = false;

    function startWpsInnder(tryCount) {
      console.log("startWpsInnder",tryCount);
      if (tryCount <= 0) {
        if (bFinished) return;
        bFinished = true;
        if (options.callback)
          options.callback({
            status: 2,
            message: "请允许浏览器打开WPS Office"
          });
        return;
      }
      var xmlReq = getHttpObj();
      //WPS客户端提供的接收参数的本地服务,HTTP服务端口为58890,HTTPS服务端口为58891
      //这俩配置,取一即可,不可同时启用
      xmlReq.open("POST", options.url);
      xmlReq.onload = function(res) {
        bFinished = true;
        if (initCloudsvr == true) {
          initCloudsvr = false;
        }
        if (options.callback) {
          if (
            res.target.response == '{"data": "Failed to send message to WPS."}'
          ) {
            options.callback({
              status: 1,
              message:
                IEVersion() < 10 ? xmlReq.responseText : res.target.response
            });
          } else {
            options.callback({
              status: 0,
              response:
                IEVersion() < 10 ? xmlReq.responseText : res.target.response
            });
          }
        }
      };
      xmlReq.ontimeout = xmlReq.onerror = function(res) {
        xmlReq.bTimeout = true;
        if (
          tryCount == options.tryCount &&
          options.bPop &&
          initCloudsvr == false
        ) {
          //打开wps并传参
          InitWpsCloudSvr();
        }
        setTimeout(function() {
          startWpsInnder(tryCount - 1);
        }, 1000);
      };
      if (IEVersion() < 10) {
        xmlReq.onreadystatechange = function() {
          if (xmlReq.readyState != 4) return;
          if (xmlReq.bTimeout) {
            return;
          }
          if (xmlReq.status === 200) xmlReq.onload();
          else xmlReq.onerror();
        };
      }
      xmlReq.timeout = options.timeout;
      xmlReq.send(options.sendData);
    }
    startWpsInnder(options.tryCount);
    return;
  }

  var fromCharCode = String.fromCharCode;
  // encoder stuff
  var cb_utob = function(c) {
    if (c.length < 2) {
      var cc = c.charCodeAt(0);
      return cc < 0x80
        ? c
        : cc < 0x800
        ? fromCharCode(0xc0 | (cc >>> 6)) + fromCharCode(0x80 | (cc & 0x3f))
        : fromCharCode(0xe0 | ((cc >>> 12) & 0x0f)) +
          fromCharCode(0x80 | ((cc >>> 6) & 0x3f)) +
          fromCharCode(0x80 | (cc & 0x3f));
    } else {
      var cc =
        0x10000 +
        (c.charCodeAt(0) - 0xd800) * 0x400 +
        (c.charCodeAt(1) - 0xdc00);
      return (
        fromCharCode(0xf0 | ((cc >>> 18) & 0x07)) +
        fromCharCode(0x80 | ((cc >>> 12) & 0x3f)) +
        fromCharCode(0x80 | ((cc >>> 6) & 0x3f)) +
        fromCharCode(0x80 | (cc & 0x3f))
      );
    }
  };
  var re_utob = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g;
  var utob = function(u) {
    return u.replace(re_utob, cb_utob);
  };
  var _encode = function(u) {
    var isUint8Array =
      Object.prototype.toString.call(u) === "[object Uint8Array]";
    if (isUint8Array) return u.toString("base64");
    else return btoa(utob(String(u)));
  };

  if (typeof window.btoa !== "function") window.btoa = func_btoa;

  function func_btoa(input) {
    var str = String(input);
    var chars =
      "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
    for (
      // initialize result and counter
      var block, charCode, idx = 0, map = chars, output = "";
      // if the next str index does not exist:
      //   change the mapping table to "="
      //   check if d has no fractional digits
      str.charAt(idx | 0) || ((map = "="), idx % 1);
      // "8 - idx % 1 * 8" generates the sequence 2, 4, 6, 8
      output += map.charAt(63 & (block >> (8 - (idx % 1) * 8)))
    ) {
      charCode = str.charCodeAt((idx += 3 / 4));
      if (charCode > 0xff) {
        throw new InvalidCharacterError(
          "'btoa' failed: The string to be encoded contains characters outside of the Latin1 range."
        );
      }
      block = (block << 8) | charCode;
    }
    return output;
  }

  /**
   * 将字符串进行Base64编码
   * @param {*} u         需要编码的数据
   * @param {*} urisafe   返回值,编码后的数据
   * @returns             urisafe
   */
  var encode = function(u, urisafe) {
    return !urisafe
      ? _encode(u)
      : _encode(String(u))
          .replace(/[+\/]/g, function(m0) {
            return m0 == "+" ? "-" : "_";
          })
          .replace(/=/g, "");
  };

  /**
   * 获取IE浏览器版本
   * @returns     IE浏览器版本
   */
  function IEVersion() {
    var userAgent = navigator.userAgent; //取得浏览器的userAgent字符串
    var isIE =
      userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1; //判断是否IE<11浏览器
    var isEdge = userAgent.indexOf("Edge") > -1 && !isIE; //判断是否IE的Edge浏览器
    var isIE11 =
      userAgent.indexOf("Trident") > -1 && userAgent.indexOf("rv:11.0") > -1;
    if (isIE) {
      var reIE = new RegExp("MSIE (\\d+\\.\\d+);");
      reIE.test(userAgent);
      var fIEVersion = parseFloat(RegExp["$1"]);
      if (fIEVersion == 7) {
        return 7;
      } else if (fIEVersion == 8) {
        return 8;
      } else if (fIEVersion == 9) {
        return 9;
      } else if (fIEVersion == 10) {
        return 10;
      } else {
        return 6; //IE版本<=7
      }
    } else if (isEdge) {
      return 20; //edge
    } else if (isIE11) {
      return 11; //IE11
    } else {
      return 30; //不是ie浏览器
    }
  }

  /**
   * 启动wps客户端,加载项执行操作,无返回值
   * @param {*} options       参数对象,详情见下:
   * @param {*} clientType    加载项类型, wps / wpp / et
   * @param {*} name          加载项名称
   * @param {*} func          客户端加载项要执行的方法
   * @param {*} param         客户端家乡执行方法的参数
   * @param {*} urlBase       网页路径前缀
   * @param {*} callback      回调函数
   * @param {*} tryCount      请求失败后的尝试次数
   * @param {*} bPop          是否弹出浏览器提示对话框
   * @param {*} wpsclient     wpsclient对象
   */
  function WpsStart(options) {
    console.log("WpsStart", options);
    var startInfo = {
      name: options.name,
      function: options.func,
      info: options.param.param,
      jsPluginsXml: options.param.jsPluginsXml
    };
    var strData = JSON.stringify(startInfo);
    if (IEVersion() < 10) {
      try {
        eval("strData = '" + JSON.stringify(startInfo) + "';");
      } catch (err) {}
    }

    var baseData = encode(strData);
    var url = options.urlBase + "/" + options.clientType + "/runParams";
    var data = "ksowebstartup" + options.clientType + "://" + baseData;
    startWps({
      url: url,
      sendData: data,
      callback: options.callback,
      tryCount: options.tryCount,
      bPop: options.bPop,
      timeout: 5000,
      concurrent: false,
      client: options.wpsclient
    });
  }

  /**
   * 服务端版本为空时,通过该接口启动wps
   * @param {*} options       参数对象,详情见下:
   * @param {*} clientType    加载项类型, wps / wpp / et
   * @param {*} name          加载项名称
   * @param {*} func          客户端加载项要执行的方法
   * @param {*} param         客户端家乡执行方法的参数
   * @param {*} urlBase       网页路径前缀
   * @param {*} callback      回调函数
   * @param {*} wpsclient     wpsclient对象
   * @param {*} concurrent    请求是否同步发送
   */
  function WpsStartWrap(options) {
    console.log("WpsStartWrap");
    WpsStart({
      clientType: options.clientType,
      name: options.name,
      func: options.func,
      param: options.param,
      urlBase: options.urlBase,
      callback: options.callback,
      tryCount: 4,
      bPop: true,
      wpsclient: options.wpsclient
    });
  }

  /**
   * 支持浏览器触发,WPS有返回值的启动
   *
   * @param {*} clientType	组件类型
   * @param {*} name			WPS加载项名称
   * @param {*} func			WPS加载项入口方法
   * @param {*} param			参数:包括WPS加载项内部定义的方法,参数等
   * @param {*} callback		回调函数
   * @param {*} tryCount		重试次数
   * @param {*} bPop			是否弹出浏览器提示对话框
   */
  var exId = 0;
  function WpsStartWrapExInner(options) {
    console.log("WpsStartWrapExInner", options);
    var infocontent = options.param.param;
    if (!options.wpsclient || options.wpsclient.single) {
      infocontent = JSON.stringify(options.param.param);
      var rspUrl = options.urlBase + "/transferEcho/runParams";
      var time = new Date();
      var cmdId = "js" + time.getTime() + "_" + exId;
      var funcEx = "var res = " + options.func;
      var cbCode =
        "var xhr = new XMLHttpRequest();xhr.open('POST', '" +
        rspUrl +
        "');xhr.send(JSON.stringify({id: '" +
        cmdId +
        "', response: res}));"; //res 为func执行返回值
      var infoEx = infocontent + ");" + cbCode + "void(0";
      options.func = funcEx;
      infocontent = infoEx;
    }
    var startInfo = {
      name: options.name,
      function: options.func,
      info: infocontent,
      showToFront: options.param.showToFront,
      jsPluginsXml: options.param.jsPluginsXml
    };

    var strData = JSON.stringify(startInfo);
    if (IEVersion() < 10) {
      try {
        eval("strData = '" + JSON.stringify(startInfo) + "';");
      } catch (err) {}
    }

    var baseData = encode(strData);
    var wrapper;

    if (!options.wpsclient || options.wpsclient.single) {
      var url = options.urlBase + "/transfer/runParams";
      var data = "ksowebstartup" + options.clientType + "://" + baseData;
      wrapper = {
        id: cmdId,
        app: options.clientType,
        data: data,
        serverId: serverId,
        mode: options.silentMode ? "true" : "false"
      };
    } else {
      var url = options.urlBase + "/transferEx/runParams";
      wrapper = {
        id: options.wpsclient.clientId,
        app: options.clientType,
        data: baseData,
        mode: options.wpsclient.silentMode ? "true" : "false",
        serverId: serverId
      };
    }
    wrapper = JSON.stringify(wrapper);
    startWps({
      url: url,
      sendData: wrapper,
      callback: options.callback,
      tryCount: options.tryCount,
      bPop: options.bPop,
      timeout: 0,
      concurrent: options.concurrent,
      client: options.wpsclient
    });
  }

  var serverVersion = "wait";
  var cloudSvrStart = true;
  var initCloudsvr = false;
  /**
   * 获取服务端版本号的接口
   * @param {*} options       参数对象,详情见下:
   * @param {*} clientType    加载项类型, wps / wpp / et
   * @param {*} name          加载项名称
   * @param {*} func          客户端加载项要执行的方法
   * @param {*} param         客户端家乡执行方法的参数
   * @param {*} urlBase       网页路径前缀
   * @param {*} callback      回调函数
   * @param {*} wpsclient     wpsclient对象
   * @param {*} concurrent    请求是否同步发送
   */
  function WpsStartWrapVersionInner(options) {
    console.log("WpsStartWrapVersionInner",options);
    if (serverVersion == "wait") {
      if (cloudSvrStart == false) {
        InitWpsCloudSvr();
        initCloudsvr = true;
      }
      startWps({
        url: options.urlBase + "/version",
        sendData: JSON.stringify({ serverId: serverId }),
        callback: function(res) {
          if (res.status !== 0) {
            options.callback(res);
            return;
          }
          serverVersion = res.response;
          cloudSvrStart = true;
          options.tryCount = 1;
          options.bPop = false;
          if (serverVersion === "") {
            WpsStart(options);
          } else if (serverVersion < "1.0.1" && options.wpsclient) {
            options.wpsclient.single = true;
            WpsStartWrapExInner(options);
          } else {
            WpsStartWrapExInner(options);
          }
        },
        tryCount: 4,
        bPop: true,
        timeout: 5000,
        concurrent: options.concurrent
      });
    } else {
      options.tryCount = 4;
      options.bPop = true;
      if (serverVersion === "") {
        WpsStartWrap(options);
      } else if (serverVersion < "1.0.1" && options.wpsclient) {
        options.wpsclient.single = true;
        WpsStartWrapExInner(options);
      } else {
        WpsStartWrapExInner(options);
      }
    }
  }

  var HeartBeatCode =
    "function getHttpObj() {\n" +
    "            var httpobj = null;\n" +
    "            if (IEVersion() < 10) {\n" +
    "                try {\n" +
    "                    httpobj = new XDomainRequest();\n" +
    "                } catch (e1) {\n" +
    "                    httpobj = new createXHR();\n" +
    "                }\n" +
    "            } else {\n" +
    "                httpobj = new createXHR();\n" +
    "            }\n" +
    "            return httpobj;\n" +
    "        }\n" +
    "        \n" +
    "        function createXHR() {\n" +
    "            if (typeof XMLHttpRequest != 'undefined') {\n" +
    "                return new XMLHttpRequest();\n" +
    "            } else if (typeof ActiveXObject != 'undefined') {\n" +
    "                var versions = [\n" +
    "                    'MSXML2.XMLHttp.6.0',\n" +
    "                    'MSXML2.XMLHttp.3.0',\n" +
    "                    'MSXML2.XMLHttp'\n" +
    "                ];\n" +
    "        \n" +
    "                for (var i = 0; i < versions.length; i++) {\n" +
    "                    try {\n" +
    "                        return new ActiveXObject(versions[i]);\n" +
    "                    } catch (e) {\n" +
    "                        \n" +
    "                    }\n" +
    "                }\n" +
    "            } else {\n" +
    "                throw new Error('您的浏览器不支持XHR对象');\n" +
    "            }\n" +
    "        }\n" +
    "        \n" +
    "        function IEVersion() {\n" +
    "            var userAgent = navigator.userAgent; \n" +
    "            var isIE = userAgent.indexOf('compatible') > -1 && userAgent.indexOf('MSIE') > -1;\n" +
    "            var isEdge = userAgent.indexOf('Edge') > -1 && !isIE; \n" +
    "            var isIE11 = userAgent.indexOf('Trident') > -1 && userAgent.indexOf('rv:11.0') > -1;\n" +
    "            if (isIE) {\n" +
    "                var reIE = new RegExp('MSIE (\\d+\\.\\d+);');\n" +
    "                reIE.test(userAgent);\n" +
    "                var fIEVersion = parseFloat(RegExp['$1']);\n" +
    "                if (fIEVersion == 7) {\n" +
    "                    return 7;\n" +
    "                } else if (fIEVersion == 8) {\n" +
    "                    return 8;\n" +
    "                } else if (fIEVersion == 9) {\n" +
    "                    return 9;\n" +
    "                } else if (fIEVersion == 10) {\n" +
    "                    return 10;\n" +
    "                } else {\n" +
    "                    return 6; \n" +
    "                }\n" +
    "            } else if (isEdge) {\n" +
    "                return 20; \n" +
    "            } else if (isIE11) {\n" +
    "                return 11; \n" +
    "            } else {\n" +
    "                return 30; \n" +
    "            }\n" +
    "        }\n" +
    "        var heartBeatStart = false;\n" +
    "        function checkLastRegTime() {\n" +
    "            var now = new Date().valueOf();\n" +
    "            var TimeGap = now - LastRegTime;\n" +
    "            if (TimeGap > 5000 && !heartBeatStart) {\n" +
    "                HeartBeat();\n" +
    "                heartBeatStart = true;\n" +
    "            }\n" +
    "        }\n" +
    "        \n" +
    "        function HeartBeat() {\n" +
    "            var heartBeatItem = function () {\n" +
    "                var xhr = getHttpObj();\n" +
    "                xhr.onload = function (e) {\n" +
    "                    self.setTimeout(heartBeatItem, 5000);\n" +
    "                }\n" +
    "                xhr.onerror = function (e) {\n" +
    "                    self.setTimeout(heartBeatItem, 5000);\n" +
    "                }\n" +
    "                xhr.ontimeout = function (e) {\n" +
    "                    self.setTimeout(heartBeatItem, 5000);\n" +
    "                }\n" +
    "                xhr.open('POST', 'http://127.0.0.1:58890/askwebnotify', true);\n" +
    "                xhr.timeout = 2000;\n" +
    "                xhr.send(JSON.stringify(paramStr));\n" +
    "            }\n" +
    "            heartBeatItem();\n" +
    "        }\n" +
    "        \n" +
    "        var paramStr;\n" +
    "        var startCheck = false;\n" +
    "        self.addEventListener('message', function (event) {\n" +
    "            var data = event.data;\n" +
    "                paramStr = data.param\n" +
    "                paramStr.heartBeat = true\n" +
    "                LastRegTime = data.LastRegTime;\n" +
    "                if (!startCheck) {\n" +
    "                    startCheck = true;\n" +
    "                    self.setInterval(checkLastRegTime, 5000)\n" +
    "                }\n" +
    "        }, false);\n";
  /**
   * 生成guid的接口
   * @returns guid
   */
  function guid() {
    return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function(c) {
      var r = (Math.random() * 16) | 0,
        v = c == "x" ? r : (r & 0x3) | 0x8;
      return v.toString(16);
    });
  }

  /**
   * 开启多用户的接口
   */
  var serverId = undefined;
  function EnableMultiUser() {
    serverId = getServerId();
  }

  /**
   * 自定义协议启动服务端
   * 默认不带参数serverId,linux未升级之前不要使用多用户
   */
  function InitWpsCloudSvr() {
    if (serverId == undefined)
      window.location.href = "ksoWPSCloudSvr://start=RelayHttpServer";
    //是否启动wps弹框
    else
      window.location.href =
        "ksoWPSCloudSvr://start=RelayHttpServer" + "&serverId=" + serverId; //是否启动wps弹框
  }

  /**
   * 获取serverId的接口
   * @returns serverId
   */
  function getServerId() {
    if (window.localStorage) {
      if (localStorage.getItem("serverId")) {
        //
      } else {
        localStorage.setItem("serverId", guid());
      }
      return localStorage.getItem("serverId");
    } else {
      return guid();
    }
  }

  /**
   * 将字符串转成二进制,这里用来将字符串化后的js代码转成二进制文件
   * @param {*} code
   * @returns js文件对象的url
   */
  function codeToBlob(code) {
    var blob = new Blob([code], { type: "text/javascript" }); // 生成js文件对象
    var objectURL = window.URL.createObjectURL(blob); // 生成js文件的url
    return objectURL;
  }

  var RegWebNotifyMap = { wps: {}, wpp: {}, et: {} };
  var bWebNotifyUseTimeout = true;
  function WebNotifyUseTimeout(value) {
    bWebNotifyUseTimeout = value ? true : false;
  }
  var g_businessId = Number(
    Math.random()
      .toString()
      .substr(3, 5) + Date.parse(new Date())
  ).toString(36);
  var HeartBeatWorker;
  if (window.Worker) {
    try {
      HeartBeatWorker = new Worker(codeToBlob(HeartBeatCode));
    } catch (error) {
      //
    }
  }
  var g_LastRegTime;
  /**
   * 注册一个前端页面接收WPS传来消息的方法
   * @param {*} clientType wps | et | wpp
   * @param {*} name WPS加载项的名称
   * @param {*} callback 回调函数
   * @param {*} wpsclient wpsclient对象
   */
  function RegWebNotify(clientType, name, callback, wpsclient) {
    if (clientType != "wps" && clientType != "wpp" && clientType != "et")
      return;
    var paramStr = {};
    if (wpsclient) {
      if (wpsclient.notifyRegsitered == true) {
        return;
      }
      wpsclient.notifyRegsitered = true;
      paramStr = {
        clientId: wpsclient.clientId,
        name: name,
        type: clientType,
        serverId: serverId
      };
      if (HeartBeatWorker) paramStr.businessId = g_businessId;
    } else {
      if (typeof callback != "function") return;
      if (RegWebNotifyMap[clientType][name]) {
        RegWebNotifyMap[clientType][name] = callback;
        return;
      }
      var RegWebNotifyID = new Date().valueOf() + "";
      paramStr = {
        id: RegWebNotifyID,
        name: name,
        type: clientType,
        serverId: serverId
      };
      if (HeartBeatWorker) paramStr.businessId = g_businessId;
      RegWebNotifyMap[clientType][name] = callback;
    }

    var askItem = function() {
      var xhr = getHttpObj();
      xhr.onload = function(e) {
        if (xhr.responseText == "WPSInnerMessage_quit") {
          return;
        }
        try {
          var resText = JSON.parse(xhr.responseText);
          if (typeof resText == "object") {
            paramStr.messageId = resText.msgId;
          }
          if (wpsclient) {
            if (typeof resText.data == "object")
              // 如果发的数据是字符串化后的json对象,这里的resText.data就是一个json对象,可以输出自己想要的json数据
              wpsclient.OnRegWebNotify(resText.data.data);
            else wpsclient.OnRegWebNotify(resText.data);
          } else {
            var func = RegWebNotifyMap[clientType][name];
            if (typeof resText.data == "object")
              // 如果发的数据是字符串化后的json对象,这里的resText.data就是一个json对象,可以输出自己想要的json数据
              func(resText.data.data);
            else func(resText.data);
          }
        } catch (e) {
          // 这里做一个容错,即使json解析失败,也要把msgId提取出来,发回给服务端,避免消息清不掉一直重复发送
          // 同时把data也取出来,但是格式无法保证
          var str = xhr.responseText;
          var idx1 = str.indexOf(":");
          var idx2 = str.indexOf(",");
          paramStr.messageId = parseInt(str.substring(idx1 + 1, idx2));
          var idx3 = str.indexOf('"data"');
          var idx4 = str.indexOf("}");
          var data = str.substring(idx3, idx4);
          if (wpsclient) {
            if (data) wpsclient.OnRegWebNotify(data);
            else wpsclient.OnRegWebNotify(xhr.responseText);
          } else {
            var func = RegWebNotifyMap[clientType][name];
            if (data) func(data);
            else func(xhr.responseText);
          }
        }
        window.setTimeout(askItem, 300);
      };
      xhr.onerror = function(e) {
        if (bWebNotifyUseTimeout) window.setTimeout(askItem, 1000);
        else window.setTimeout(askItem, 10000);
      };
      xhr.ontimeout = function(e) {
        if (bWebNotifyUseTimeout) window.setTimeout(askItem, 300);
        else window.setTimeout(askItem, 10000);
      };
      if (IEVersion() < 10) {
        xhr.onreadystatechange = function() {
          if (xhr.readyState != 4) return;
          if (xhr.bTimeout) {
            return;
          }
          if (xhr.status === 200) xhr.onload();
          else xhr.onerror();
        };
      }
      xhr.open("POST", GetUrlBase() + "/askwebnotify", true);
      if (bWebNotifyUseTimeout) xhr.timeout = 2000;
      if (HeartBeatWorker) {
        g_LastRegTime = new Date().valueOf();
        var param = {
          param: {
            name: name,
            type: clientType,
            businessId: g_businessId,
            serverId: serverId
          },
          LastRegTime: g_LastRegTime
        };
        HeartBeatWorker.postMessage(param);
      }
      xhr.send(JSON.stringify(paramStr));
    };
    window.setTimeout(askItem, 2000);
  }

  /**
   * 获取网页路径前缀
   * @returns url前缀
   */
  function GetUrlBase() {
    if (location.protocol == "https:") return "https://127.0.0.1:58891";
    return "http://127.0.0.1:58890";
  }

  /**
   * 获取服务端版本号的接口,这里主要是初始化一些参数
   * @param {*} clientType    加载项类型, wps / wpp / et
   * @param {*} name          加载项名称
   * @param {*} func          客户端加载项要执行的方法
   * @param {*} param         客户端家乡执行方法的参数
   * @param {*} callback      回调函数
   * @param {*} showToFront   设置客户端是否显示到前面
   * @param {*} jsPluginsXml  设置加载项路径
   * @param {*} silentMode    静默启动WPS
   */
  function WpsStartWrapVersion(
    clientType,
    name,
    func,
    param,
    callback,
    showToFront,
    jsPluginsXml,
    silentMode
  ) {
    var paramEx = {
      jsPluginsXml: jsPluginsXml ? jsPluginsXml : "",
      showToFront: typeof showToFront == "boolean" ? showToFront : true,
      param: typeof param == "object" ? param : JSON.parse(param)
    };
    var options = {
      clientType: clientType,
      name: name,
      func: func,
      param: paramEx,
      urlBase: GetUrlBase(),
      callback: callback,
      wpsclient: undefined,
      concurrent: true,
      silentMode: silentMode
    };
    WpsStartWrapVersionInner(options);
  }

  //从外部浏览器远程调用 WPS 加载项中的方法
  var WpsInvoke = {
    InvokeAsHttp: WpsStartWrapVersion,
    InvokeAsHttps: WpsStartWrapVersion,
    RegWebNotify: RegWebNotify,
    ClientType: {
      wps: "wps",
      et: "et",
      wpp: "wpp"
    },
    CreateXHR: getHttpObj,
    IsClientRunning: IsClientRunning
  };

  window.wpsclients = [];
  /**
   * @constructor WpsClient           wps客户端
   * @param {string} clientType       必传参数,加载项类型,有效值为"wps","wpp","et";分别表示文字,演示,电子表格
   */
  function WpsClient(clientType) {
    /**
     * 设置RegWebNotify的回调函数,加载项给业务端发消息通过该函数
     * @memberof WpsClient
     * @member onMessage
     */
    this.onMessage;

    /**
     * 设置加载项路径
     * @memberof WpsClient
     * @member jsPluginsXml
     */
    this.jsPluginsXml;

    /**
     * 内部成员,外部无需调用
     */
    this.notifyRegsitered = false;
    this.clientId = "";
    this.concurrent = false;
    this.clientType = clientType;
    this.firstRequest = true;

    /**
     * 内部函数,外部无需调用
     * @param {*} options
     */
    this.initWpsClient = function(options) {
      options.clientType = this.clientType;
      options.wpsclient = this;
      options.concurrent = this.firstRequest ? true : this.concurrent;
      this.firstRequest = false;
      WpsStartWrapVersionInner(options);
    };

    /**
     * 以http启动
     * @param {string} name              加载项名称
     * @param {string} func              要调用的加载项中的函数行
     * @param {string} param             在加载项中执行函数func要传递的数据
     * @param {function({int, string})} callback        回调函数,status = 0 表示成功,失败请查看message信息
     * @param {bool} showToFront         设置wps是否显示到前面来
     * @return {string}                  "Failed to send message to WPS." 发送消息失败,客户端已关闭;
     *                                   "WPS Addon is not response." 加载项阻塞,函数执行失败
     */
    this.InvokeAsHttp = function(name, func, param, callback, showToFront) {
      function clientCallback(res) {
        //this不是WpsClient
        if (res.status !== 0 || serverVersion < "1.0.1") {
          if (callback) callback(res);
          RegWebNotify(clientType, name, this.client.onMessage);
          return;
        }
        var resObject = JSON.parse(res.response);
        if (this.client.clientId == "") {
          this.client.clientId = resObject.clientId;
        }
        this.client.concurrent = true;
        if (typeof resObject.data == "object")
          res.response = JSON.stringify(resObject.data);
        else res.response = resObject.data;
        if (IEVersion() < 10) eval(" res.response = '" + res.response + "';");
        if (callback) callback(res);
        this.client.RegWebNotify(name);
      }
      var paramEx = {
        jsPluginsXml: this.jsPluginsXml ? this.jsPluginsXml : "",
        showToFront: typeof showToFront == "boolean" ? showToFront : true,
        param: typeof param == "object" ? param : JSON.parse(param)
      };
      this.initWpsClient({
        name: name,
        func: func,
        param: paramEx,
        urlBase: GetUrlBase(),
        callback: clientCallback
      });
    };

    /**
     * 以https启动
     * @param {string} name              加载项名称
     * @param {string} func              要调用的加载项中的函数行
     * @param {string} param             在加载项中执行函数func要传递的数据
     * @param {function({int, string})} callback        回调函数,status = 0 表示成功,失败请查看message信息
     * @param {bool} showToFront         设置wps是否显示到前面来
     */
    this.InvokeAsHttps = function(name, func, param, callback, showToFront) {
      var paramEx = {
        jsPluginsXml: this.jsPluginsXml ? this.jsPluginsXml : "",
        showToFront: typeof showToFront == "boolean" ? showToFront : true,
        param: typeof param == "object" ? param : JSON.parse(param)
      };
      this.initWpsClient({
        name: name,
        func: func,
        param: paramEx,
        urlBase: GetUrlBase(),
        callback: callback
      });
    };

    /**
     * 内部函数,外部无需调用
     * @param {*} name
     */
    this.RegWebNotify = function(name) {
      RegWebNotify(this.clientType, name, null, this);
    };

    /**
     * 消息注册函数的回调函数
     * @param {*} message   客户端发来的消息
     */
    this.OnRegWebNotify = function(message) {
      if (this.onMessage) this.onMessage(message);
    };

    /**
     * 以静默模式启动客户端
     * @param {string} name                 必传参数,加载项名称
     * @param {function({int, string})} [callback]         回调函数,status = 0 表示成功,失败请查看message信息
     */
    this.StartWpsInSilentMode = function(name, callback) {
      function initCallback(res) {
        //this不是WpsClient
        if (res.status !== 0 || serverVersion < "1.0.1") {
          if (callback) callback(res);
          RegWebNotify(clientType, name, this.client.onMessage);
          return;
        }
        if (this.client.clientId == "") {
          this.client.clientId = JSON.parse(res.response).clientId;
          window.wpsclients[window.wpsclients.length] = {
            name: name,
            client: this.client
          };
        }
        res.response = JSON.stringify(JSON.parse(res.response).data);
        this.client.concurrent = true;
        if (callback) {
          callback(res);
        }
        this.client.RegWebNotify(name);
      }
      var paramEx = {
        jsPluginsXml: this.jsPluginsXml,
        showToFront: false,
        param: { status: "InitInSilentMode" }
      };
      this.silentMode = true;
      this.initWpsClient({
        name: name,
        func: "",
        param: paramEx,
        urlBase: GetUrlBase(),
        callback: initCallback
      });
    };

    /**
     * 显示客户端到最前面
     * @param {string} name             必传参数,加载项名称
     * @param {function({int, string})} [callback]     回调函数
     */
    this.ShowToFront = function(name, callback) {
      if (serverVersion < "1.0.1") {
        if (callback) {
          callback({
            status: 4,
            message: "当前客户端不支持,请升级客户端"
          });
          return;
        }
        return;
      }
      if (this.clientId == "") {
        if (callback)
          callback({
            status: 3,
            message: "没有静默启动客户端"
          });
        return;
      }
      var paramEx = {
        jsPluginsXml: "",
        showToFront: true,
        param: { status: "ShowToFront" }
      };
      this.initWpsClient({
        name: name,
        func: "",
        param: paramEx,
        urlBase: GetUrlBase(),
        callback: callback
      });
    };

    /**
     * 关闭未显示出来的静默启动客户端
     * @param {string} name             必传参数,加载项名称
     * @param {function({int, string})} [callback]     回调函数
     */
    this.CloseSilentClient = function(name, callback) {
      if (serverVersion < "1.0.1") {
        if (callback) {
          callback({
            status: 4,
            message: "当前客户端不支持,请升级客户端"
          });
          return;
        }
        return;
      }
      if (this.clientId == "") {
        if (callback)
          callback({
            status: 3,
            message: "没有静默启动客户端"
          });
        return;
      }
      var paramEx = {
        jsPluginsXml: "",
        showToFront: false,
        param: undefined
      };
      var func;
      if (this.clientType == "wps") func = "wps.WpsApplication().Quit";
      else if (this.clientType == "et") func = "wps.EtApplication().Quit";
      else if (this.clientType == "wpp") func = "wps.WppApplication().Quit";

      function closeSilentClient(res) {
        if (res.status == 0) this.client.clientId = "";
        if (callback) callback(res);
        return;
      }
      this.initWpsClient({
        name: name,
        func: func,
        param: paramEx,
        urlBase: GetUrlBase(),
        callback: closeSilentClient
      });
    };

    /**
     * 当前客户端是否在运行,使用WpsClient.IsClientRunning()进行调用
     * @param {function({int, string})} [callback]      回调函数,"Client is running." 客户端正在运行
     *                                                  "Client is not running." 客户端没有运行
     */
    this.IsClientRunning = function(callback) {
      if (serverVersion < "1.0.1") {
        if (callback) {
          callback({
            status: 4,
            message: "当前客户端不支持,请升级客户端"
          });
          return;
        }
        return;
      }
      IsClientRunning(this.clientType, callback, this);
    };
  }

  /**
   * 初始化sdk,用来减少在服务进程启动时自定义协议弹框出现的次数
   */
  function InitSdk() {
    var url = GetUrlBase() + "/version";
    startWps({
      url: url,
      callback: function(res) {
        if (res.status !== 0) {
          cloudSvrStart = false;
          return;
        }
        if (serverVersion == "wait") {
          InitMultiUser();
        }
      },
      tryCount: 1,
      bPop: false,
      timeout: 1000
    });
  }
  InitSdk();

  /**
   * 初始化多用户模式
   */
  function InitMultiUser() {
    var url = GetUrlBase() + "/version";
    startWps({
      url: url,
      sendData: JSON.stringify({ serverId: serverId }),
      callback: function(res) {
        if (res.status !== 0) {
          cloudSvrStart = false;
          return;
        }
        if (serverVersion == "wait") {
          serverVersion = res.response;
          cloudSvrStart = true;
        }
      },
      tryCount: 1,
      bPop: false,
      timeout: 1000
    });
  }

  if (typeof noGlobal === "undefined") {
    window.WpsInvoke = WpsInvoke;
    window.WpsClient = WpsClient;
    window.WebNotifyUseTimeout = WebNotifyUseTimeout;
    window.EnableMultiUser = EnableMultiUser;
  }

  /**
   * 当前客户端是否在运行,使用WpsInvoke.IsClientRunning()进行调用
   * @param {string} clientType       加载项类型
   * @param {function} [callback]      回调函数,"Client is running." 客户端正在运行
   *                                   "Client is not running." 客户端没有运行
   */
  function IsClientRunning(clientType, callback, wpsclient) {
    var url = GetUrlBase() + "/isRunning";
    var wrapper = {
      id: wpsclient == undefined ? undefined : wpsclient.clientId,
      app: clientType,
      serverId: serverId
    };
    wrapper = JSON.stringify(wrapper);
    startWps({
      url: url,
      sendData: wrapper,
      callback: callback,
      tryCount: 1,
      bPop: false,
      timeout: 2000,
      concurrent: true,
      client: wpsclient
    });
  }

  /**
   * 获取publish.xml的内容
   * @param {*} callBack 回调函数
   */
  function WpsAddonGetAllConfig(callBack) {
    var baseData = JSON.stringify({ serverId: serverId });
    startWps({
      url: GetUrlBase() + "/publishlist",
      type: "POST",
      sendData: baseData,
      callback: callBack,
      tryCount: 3,
      bPop: true,
      timeout: 5000,
      concurrent: true
    });
  }

  /**
   * 检查ribbon.xml文件是否有效
   * @param {*} element   参数对象
   * @param {*} callBack  回调函数
   */
  function WpsAddonVerifyStatus(element, callBack) {
    var xmlReq = getHttpObj();
    var offline = element.online === "false";
    var url = offline ? element.url : element.url + "ribbon.xml";
    xmlReq.open("POST", GetUrlBase() + "/redirect/runParams");
    xmlReq.onload = function(res) {
      if (offline && !res.target.response.startsWith("7z")) {
        callBack({ status: 1, msg: "不是有效的7z格式" + url });
      } else if (!offline && !res.target.response.startsWith("<customUI")) {
        callBack({ status: 1, msg: "不是有效的ribbon.xml, " + url });
      } else {
        callBack({ status: 0, msg: "OK" });
      }
    };
    xmlReq.onerror = function(res) {
      xmlReq.bTimeout = true;
      callBack({
        status: 2,
        msg: "网页路径不可访问,如果是跨域问题,不影响使用" + url
      });
    };
    xmlReq.ontimeout = function(res) {
      xmlReq.bTimeout = true;
      callBack({ status: 3, msg: "访问超时" + url });
    };
    if (IEVersion() < 10) {
      xmlReq.onreadystatechange = function() {
        if (xmlReq.readyState != 4) return;
        if (xmlReq.bTimeout) {
          return;
        }
        if (xmlReq.status === 200) xmlReq.onload();
        else xmlReq.onerror();
      };
    }
    xmlReq.timeout = 5000;
    var data = {
      method: "get",
      url: url,
      data: ""
    };
    var sendData = FormatSendData(data);
    xmlReq.send(sendData);
  }

  /**
   * 部署加载项,包括启动enable / disable禁用 / disableall禁用所有
   * @param {*} element   参数对象
   * @param {*} cmd       具体操作,enable / disable / disableall
   * @param {*} callBack  回调函数
   */
  function WpsAddonHandleEx(element, cmd, callBack) {
    console.log("WpsAddonHandleEx", element, cmd, callBack)
    var data = FormatData(element, cmd);
    startWps({
      url: GetUrlBase() + "/deployaddons/runParams",
      type: "POST",
      sendData: data,
      callback: callBack,
      tryCount: 3,
      bPop: true,
      timeout: 5000,
      concurrent: true
    });
  }

  /**
   * 启用加载项
   * @param {*} element   参数对象
   * @param {*} callBack  回调函数
   */
  function WpsAddonEnable(element, callBack) {
    WpsAddonHandleEx(element, "enable", callBack);
  }

  /**
   * 禁用加载项
   * @param {*} element   参数对象
   * @param {*} callBack  回调函数
   */
  function WpsAddonDisable(element, callBack) {
    WpsAddonHandleEx(element, "disable", callBack);
  }

wpsjsrpcsdk.js
  /**
   * 生成json格式的数据
   * @param {*} element   参数对象
   * @param {*} cmd       具体操作,enable / disable / disableall
   * @returns base64编码后的数据
   */
  function FormatData(element, cmd) {
    var data = {
      cmd: cmd, //"enable", 启用, "disable", 禁用, "disableall", 禁用所有
      name: element.name,
      url: element.url,
      addonType: element.addonType,
      online: element.online,
      version: element.version
    };
    return FormatSendData(data);
  }

  /**
   * 将json格式的数据字符串化,并进行base64编码
   * @param {*} data  数据
   * @returns base64编码后的数据
   */
  function FormatSendData(data) {
    var strData = JSON.stringify(data);
    if (IEVersion() < 10) eval("strData = '" + JSON.stringify(strData) + "';");

    if (serverVersion == "1.0.2") {
      var base64Data = encode(strData);
      return JSON.stringify({
        serverId: serverId,
        data: base64Data
      });
    } else {
      return encode(strData);
    }
  }
  //管理 WPS 加载项
  var WpsAddonMgr = {
    getAllConfig: WpsAddonGetAllConfig,
    verifyStatus: WpsAddonVerifyStatus,
    enable: WpsAddonEnable,
    disable: WpsAddonDisable
  };

  if (typeof noGlobal === "undefined") {
    window.WpsAddonMgr = WpsAddonMgr;
  }

  return { WpsInvoke: WpsInvoke, WpsAddonMgr: WpsAddonMgr, version: "1.0.21" };
});

et.js

var pluginsMode = location.search.split("=")[1];//截取url中的参数值
var pluginType = WpsInvoke.ClientType.et//加载项类型wps,et,wpp
var pluginName = "EtOAAssist";//加载项名称
var wpsClient = new WpsClient(pluginType);//初始化一个多进程对象,多进程时才需要
var clientStr = pluginName + pluginType + "ClientId"
//单进程封装开始
/**
 * 此方法是根据wps_sdk.js做的调用方法封装
 * 可参照此定义
 * @param {*} funcs         这是在WPS加载项内部定义的方法,采用JSON格式(先方法名,再参数)
 * @param {*} front         控制着通过页面执行WPS加载项方法,WPS的界面是否在执行时在前台显示
 * @param {*} jsPluginsXml  指定一个新的WPS加载项配置文件的地址,动态传递jsplugins.xml模式,例如:http://127.0.0.1:3888/jsplugins.xml
 * @param {*} isSilent      隐藏打开WPS,如果需要隐藏,那么需要传递front参数为false
 */


export function _Et(funcs, front, jsPluginsXml, isSilent) {
    var info = {};
    info.funcs = funcs;
    if (isSilent) {//隐藏启动时,front必须为false
        front = false;
    }
    /**
     * 下面函数为调起WPS,并且执行加载项WpsOAAssist中的函数dispatcher,该函数的参数为业务系统传递过去的info
     */
    if (pluginsMode != 2) {//单进程
        singleInvoke(info, front, jsPluginsXml, isSilent)
    } else {//多进程
        multInvoke(info, front, jsPluginsXml, isSilent)
    }

}

//单进程
function singleInvoke(info, front, jsPluginsXml, isSilent) {
    WpsInvoke.InvokeAsHttp(pluginType, // 组件类型
        pluginName, // 插件名,与wps客户端加载的加载的插件名对应
        "dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
        info, // 传递给插件的数据        
        function (result) { // 调用回调,status为0为成功,其他是错误
            if (result.status) {
                if (result.status == 100) {
                    WpsInvoke.AuthHttpesCert('请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。')
                    return;
                }
                alert(result.message)

            } else {
                console.log(result.response)
            }
        },
        front,
        jsPluginsXml,
        isSilent)

    /**
     * 接受WPS加载项发送的消息
     * 接收消息:WpsInvoke.RegWebNotify(type,name,callback)
     * WPS客户端返回消息: wps.OAAssist.WebNotify(message)
     * @param {*} type 加载项对应的插件类型
     * @param {*} name 加载项对应的名字
     * @param {func} callback 接收到WPS客户端的消息后的回调函数,参数为接受到的数据
     */
    WpsInvoke.RegWebNotify(pluginType, pluginName, handleOaMessage)
}
//多进程
function multInvoke(info, front, jsPluginsXml, isSilent) {
    wpsClient.jsPluginsXml = jsPluginsXml ? jsPluginsXml : "http://192.168.21.5:9998/wps/jsplugins.xml"; //这里改成自己起的服务地址
    if (localStorage.getItem(clientStr)) {
        wpsClient.clientId = localStorage.getItem(clientStr)
    }
    if (isSilent) {
        wpsClient.StartWpsInSilentMode(pluginName, function () {//隐藏启动后的回调函数
            mult(info, front)
        })
    } else {
        mult(info, front)
    }
    wpsClient.onMessage = handleOaMessage
}
//多进程二次封装
function mult(info, front) {
    wpsClient.InvokeAsHttp(
        pluginName, // 插件名,与wps客户端加载的加载的插件名对应
        "dispatcher", // 插件方法入口,与wps客户端加载的加载的插件代码对应,详细见插件代码
        info, // 传递给插件的数据        
        function (result) { // 调用回调,status为0为成功,其他是错误
            if (wpsClient.clientId) {
                localStorage.setItem(clientStr, wpsClient.clientId)
            }
            if (result.status !== 0) {
                console.log(result)
                if (result.message == '{\"data\": \"Failed to send message to WPS.\"}') {
                    wpsClient.IsClientRunning(function (status) {
                        console.log(status)
                        if (status.response == "Client is running.")
                            alert("任务发送失败,WPS 正在执行其他任务,请前往WPS完成当前任务")
                        else {
                            wpsClient.clientId = "";
                            wpsClient.notifyRegsitered = false;
                            localStorage.setItem(clientStr, "")
                            mult(info)
                        }
                    })
                    return;
                }
                else if (result.status == 100) {
                    // WpsInvoke.AuthHttpesCert('请在稍后打开的网页中,点击"高级" => "继续前往",完成授权。')
                    return;
                }
                alert(result.message)
            } else {
                console.log(result.response)
            }
        },
        front)
}

function handleOaMessage(data) {
    console.log(data)
}
function GetUploadPath() {
    var url = document.location.host;
    return document.location.protocol + "//" + url + "/Upload";
}

function GetDemoPath(fileName) {

    var url = document.location.host;
    return document.location.protocol + "//" + url + "/file/" + fileName;
}

function newDoc() {
    _WpsInvoke([{
        "OpenDoc": {
            showButton: "btnSaveFile;btnSaveAsLocal"
        }
    }])
}

wps文件:我是放在public\cdn\wps-oa的,所以LoadPublishAddons方法里面的/cdn/wps-oa要随你放置的位置进行变动。

function LoadPublishAddons() {
         var addonList = document.getElementById("addonList");
  		var origin = window.location.origin
  var curList = [{"name":"WpsOAAssist","addonType":"wps","online":"true","multiUser":"false","url":origin + "/cdn/wps-oa/WpsOAAssist/"},{"name":"EtOAAssist","addonType":"et","online":"true","multiUser":"false","url":origin + "/cdn/wps-oa/EtOAAssist/"},{"name":"WppOAAssist","addonType":"wpp","online":"true","multiUser":"false","url":origin + "/cdn/wps-oa/WppOAAssist/"}];
  curList.forEach(function (element) {
      var param = JSON.stringify(element).replace("\"", "\'");
      UpdateElement(element, 'enable')
  });
}

wps文件下载

posted @ 2024-05-10 17:29  健伟博客  阅读(809)  评论(0编辑  收藏  举报