O2OA使用手册
第一章 服务器部署及管理
  • 1.1 O2OA基于nginx的SSL跳转、转发配置
  • 1.2 平台服务器下载及安装部署 For WindowsServer(适用于V7.2之后的版本)
  • 1.3 平台服务器下载及安装部署 For Linux Server(适用于V7.2之后的版本)
  • 1.4 平台服务器主机架构配置推荐
  • 1.5 平台服务器下载及安装部署 For WindowsServer(适用于V7.2之前的版本)
  • 1.6 平台服务器下载及安装部署 For Linux Server(适用于O2OA V7.2之前的版本)
  • 1.7 华为云服务器部署O2OA-麒麟操作系统
  • 1.8 密码管理-超级管理员密码修改
  • 1.9 密码管理-普通用户初始化密码设置
  • 1.10 密码管理-用户重置密码操作
  • 1.11 系统配置-如何访问和操作内置数据库-H2
  • 1.12 系统配置-第三方数据库配置-MySQL
  • 1.13 日志管理-访问日志相关配置
  • 1.14 日志管理-审计日志相关配置@日志管理
  • 1.15 日志管理-平台日志文件说明
  • 1.16 系统配置-主要配置文件说明
  • 1.17 系统配置-配置服务器连接O2云
  • 1.18 系统配置-流程催办提醒配置
  • 1.19 系统配置-自定义消息提醒
  • 1.20 系统配置-消息提醒配置说明
  • 1.21 系统配置-文件存储服务器配置
  • 1.22 系统配置-工作日节假日配置
  • 1.23 系统配置-开机自动启动O2Server
  • 1.24 系统架构-集群部署配置及操作说明
  • 1.25 系统架构-基于nginx快速集群部署-上下文分发
  • 1.26 系统架构-基于nginx快速集群部署-端口分发
  • 1.27 平台维护-流转中工作数据的查询、操作和管理
  • 1.28 平台维护-待办待阅数据的查询操作和管理
  • 1.29 平台维护-自动执行平台数据的备份与恢复
  • 1.30 平台维护-备份和恢复平台数据操作
  • 1.31 平台服务器版本升级操作说明
  • 1.32 o2server无法正常显示验证码解决办法
  • 1.33 在宝塔面板中安装O2OA(For Linux)
  • 1.34 系统安全-启用HTTPS(百度云版)
  • 1.35 系统安全-启用HTTPS(腾讯云版)
  • 1.36 系统安全-自签名SSL证书验证HTTPS功能
  • 1.37 系统安全-加密登录-登录密码RSA加密
  • 1.38 功能部署-为平台增加全文检索功能
  • 1.39 平台维护-在线部署自定义应用的WAR包和JAR包
  • 1.40 平台维护-使用Web端运行服务器管理命令
  • 第十五章 开发知识及常见问题
  • 15.1 常见问题-7.2及以上版本开启web代理后请求中没有正确使用web端口问题解决方式
  • 15.2 linux环境libreoffice安装及使用
  • 15.3 在O2OA中使用网络会议(二):Openmeetings与O2OA认证配置
  • 15.4 在O2OA中使用网络会议(一):Openmeetings-5.1.0亲手安装整理 Step-By-Step
  • 15.5 藕粉社区问答系列1
  • 15.6 藕粉社区问答系列2
  • 15.7 藕粉社区问答系列3
  • 15.8 快速入门-平台相关资料汇总
  • 15.9 快速入门-服务器总体介绍汇总
  • 15.10 快速入门-流程表单载入基础数据
  • 15.11 快速入门-常用表单脚本样例汇总
  • 15.12 快速入门-自定义表数据分页样例
  • 15.13 OEM白标-如何修改平台中的Logo图标和文字
  • 15.14 云服务器-阿里云ECS服务器的端口启用
  • 15.15 开发知识-React篇:在O2OA平台框架中使用React
  • 15.16 开发知识-React篇:在O2OA门户页面中使用React
  • 15.17 开发知识-Vue篇:在Vue应用中集成O2OA
  • 15.18 开发知识-Vue篇:使用Vue-CLI开发O2应用
  • 15.19 开发知识-Vue篇:在O2门户页面中使用Vue
  • 15.20 平台中使用Druid数据库连接及监控
  • 15.21 开发知识-在PAAS平台上部署O2OA开发平台
  • 15.22 开发知识-如何使用Tomcat架设webdav服务器
  • 15.23 开发知识-单个端口模式的Nginx和系统配置
  • 15.24 开发知识-Linux非root用户如何使用80端口启动O2OA
  • 15.25 开发知识-O2OA平台启用Eruda进行移动端调试
  • 15.26 开发知识-神通数据库安装
  • 15.27 开发知识-人大金仓数据安装
  • 15.28 开发知识-中标麒麟安装达梦数据库(DM8)
  • 15.29 开发知识-中标麒麟安装人大金仓详细步骤
  • 15.30 开发知识-使用VNC连接中标麒麟V7操作系统
  • 15.31 开发知识-鲲鹏(ARM)麒麟操作系统如何替换yum源?
  • 15.32 开发知识-数据优化知识点
  • 15.33 水印安全-附件水印|加密|文档格式转换图片|PDF
  • 15.34 消息队列-配置activeMQ、kafka消息队列
  • 15.35 常见问题-数据导出或者导入时发生OOM异常
  • 15.36 常见问题-如何让用户在首次登录时,必须对初始密码进行修改
  • 15.37 常见问题-如何在模块部署中控制模块的访问权限
  • 15.38 常见问题-如何在平台中开发Ftp文件上传文件的服务?
  • 15.39 常见问题-如何使用服务管理调用WebService
  • 15.40 常见问题-如何使用脚本调用外部服务
  • 15.41 常见问题-如何使用脚本控制流程自动流转
  • 15.42 常见问题-如何通过脚本调用系统内服务
  • 15.43 常见问题-接口代码疑惑解答汇总
  • 15.44 常见问题:Maven编译o2server错误: Java Heap Space
  • 15.45 常见问题-集群配置后启动报错:NullPointerException
  • 15.46 常见问题-服务器错误:can not decrypt token
  • 15.47 常见问题-IOS移动办公无法收到验证码
  • 15.48 常见问题-服务器和日志时间相差12小时的问题
  • 15.49 常见问题-为什么127.0.0.1可以访问但其他IP无法访问
  • 15.50 藕粉社区问答系列4
  • 15.51 开发知识-React篇:在React应用中集成O2OA

  • 门户开发-门户脚本开发

    时间:2022-04-08   
    O2OA提供的门户管理平台可以让用户自由地为企业定制符合企业特色的门户系统,门户页面。可以让页面展现的内容真正满足企业自身的需求。本文主要介绍如何在O2OA中使用脚本来调用第三方服务

    1、表单引入脚本include


    this.include("initScript") //脚本配置的名称、别名或id
    //如果需要引用其他应用的脚本配置,将options设置为JsonObject
    this.include({
        type : "portal", //应用类型。可以为 portal  process  cms。如果没有该选项或者值为空字符串,则表示应用脚本和被应用的脚本配置类型相同;比如在门户的A应用脚本中引用门户B应用的脚本配置,则type可以省略。
        application : "首页", // 门户、流程、CMS的名称、别名、id。 默认为当前应用
        name : "initScript" // 脚本配置的名称、别名或id
    })


    2、脚本方法定义

    this.define("xxx",function(){}.bind(this))


    //定义一个方法
    this.define("getUserName", function(){
    return ( layout.desktop.session.user || layout.user ).name
    }.bind(this))


    3、脚本系统服务调用

    接口地址:

    http://hostip:20030/x_program_center/jest/list.html

    this.action("xxx服务根")或者MWF.Actions.get("xxxx服务根");

    例如:引入了cms的文档服务方法,删除,修改,取消发布等方法。


    var action = new this.Action("x_cms_assemble_control", {
    "del":{"uri": "/jaxrs/document/{id}", "method": "DELETE"},
    "change":{"uri": "/jaxrs/document/category/change", "method": "PUT"},
    "cancel":{"uri": "/jaxrs/document/publish/{id}/cancel", "method": "PUT"}
      }
    );




    定义方法调用服务


    this.define("change",function(data,callback){
        action.invoke({"name": "change","data":data,"parameter": {},"async": true,
    "success": function(json){
    if(callback)callback(json);
    }.bind(this)});
    }.bind(this)


    或者也可以直接调用系统内置的方法例如


    MWF.Actions.get("x_cms_assemble_control").getDocument(id,function(json){
    //code
    }.bind(this))


    getDocument是系统中已经定义的方法,具体可以查看服务调用文件o2_core/o2/xAction/service目录下的服务文件

    4、操作嵌入视图数据

    5、服务调用实现翻页


    var action = new this.Action("x_cms_assemble_control", {
        "del":{"uri": "/jaxrs/document/{id}", "method": "DELETE"},
        "change":{"uri": "/jaxrs/document/category/change", "method": "PUT"},
        "cancel":{"uri": "/jaxrs/document/publish/{id}/cancel", "method": "PUT"},
        // 获取未读消息
        "info":{"uri": "/jaxrs/viewrecord/unread", "method": "PUT"},
        // 获取文档
        "list":{"uri": "/jaxrs/document/filter/list/{id}/next/{count}", "method": "PUT"},
        "publish":{"uri": "/jaxrs/document/publish/content", "method": "PUT"},
    });
    
    this.data.add("curid","(0)");
    this.data.add("pageCount","10");
    this.define("loadList",function(id,count,data,callback){
       action.invoke({"name": "list","parameter":{"id":id,"count":count},"data":data,"async": true, "success": function(json){if(callback)callback(json);}.bind(this)});
    }.bind(this));
    
    this.define("showList",function(json){
        //alert(JSON.stringify(json));
        var content = this.form.get("content").node;
        json.data.each(function(data){
            new Element("div",{text:data.title}).inject(content);
        }.bind(this))
    }.bind(this))


    6、引入外部js框架,例如jquery

    o2.load("/o2_lib/jquery/jquery.min.js",function(){
        var jq = jQuery.noConflict(true);
        //alert(jq("#aaa").find("input").val())
        jq(document).ready(function(){
        //window.setTimeout(function(){ 
        var tab = jq("table");
        var tr = tab.find("tr");
        tr.mouseover(function(){
        jq(this).css("background-color","#ff0")
        });
        tr.mouseout(function(){
        jq(this).css("background-color","")
        })
        //},2000);
        })
    }.bind(this))

    门户开发-常用代码

    1、门户页面跳转,参数传递

                this.page.toPage("页面名称", {"keyword": “value”});

               获取: var par = this.page.parameters; //par的内容:{"type": "my type"}

    2、使用系统内置组件模板

    MWF.xDesktop.requireApp("Template", "MTooltips", null, false);
    var tt = new Class({
        Extends: MTooltips,
        _getHtml : function(){
            var html =
            "<table width='100%' bordr='0' cellpadding='7' cellspacing='0' style='margin:13px 13px 13px 13px;'>" +
            "<tr><td width='70'>title:</td>" +
            "    <td style=''>test</td></tr>" +
            "<tr><td >time:</td>" +
            "    <td style=''>2019-08-21</td></tr>" +
            "</table>";
            return html;
    		},
    });
    
    var pc = new tt(this.form.getApp().content,this.target.node,this.form.app,{},{
        axis : "x"
    });
    pc.create();


    上一篇:门户开发-页面部件设计

    下一篇:没有了!