• U9二次开发之BE插件开发


    采购订单BE插件开发

    最近我们公司要做采购订单审批和OA的集成,也就是把u9的审批流程搬到OA里去做。当业务员点击标准采购提交按钮的时候,把采购订单的信息触发到OA流程,在OA里做审核,OA审核完成之后,再把审核结果回写到U9。

    要实现这个功能需要用到BE插件和BP插件。

    BE插件负责在业务员提交审核的时候,把采购订单的信息写到中间表里,然后再触发OA流程。

    BP插件负责定时查询中间表,把审核结果写回到u9系统。

    这里我讲解下BE插件的开发流程

    BE的大概开发步骤:
    在这里插入图片描述

    生成项目代码

    1.打开u9的插件工具

    这个工具做U9开发的同学应该都有(没有的同学请关注公众号“编程我也会”,然后输入“插件”即可获得)。
    在这里插入图片描述

    2.选择工具-配置,填好配置信息

    在这里插入图片描述
    u9环境配置参数如下:
    系统引用库:D:\yonyou\UBFV60\U9.VOB.Product.UBF\UBFStudio\Runtime
    界面路径:D:\yonyou\U9V60\Portal\UILib
    应用组件运行库路径:D:\yonyou\U9V60\Portal\ApplicationServer\Libs
    Portal路径:D:\yonyou\U9V60\Portal
    UI元数据库路径:D:\yonyou\UBFV60\U9.VOB.Product.Metadata\UI

    把D:\yonyou替换成你本地的u9安装路径就行了。

    3.点击文件-新建,新建一个解决方案

    在这里插入图片描述

    4.修改项目名称

    在这里插入图片描述

    5.右键解决方案-新建项目

    在这里插入图片描述
    填上名称、命名空间、程序集,类型选择BE。

    6.右键项目-添加事件集

    由于我做的是标准采购的插件,在插件模块中选择“供应链-采购管理”,然后搜索“采购”,选择“采购订单”,点确定按钮。
    在这里插入图片描述
    然后右键PurchaseOrder,选择添加事件:
    在这里插入图片描述
    选择Updating事件:
    在这里插入图片描述
    点击生成按钮,生成项目代码:
    在这里插入图片描述
    在右下角的消息记录中,可以看到工具生成的项目路径。
    在这里插入图片描述

    编写代码

    打开生成的项目,点击显示所有文件按钮,显示被隐藏的sub.xml文件。

    在这里插入图片描述

    修改sub.xml文件

    在文件“UFIDA.U9.Cust.Canaan.PurchaseOrderPlugBE.sub.xml”上右键,选择包括在项目中,双击打开文件,修改文件内容:

    <?xml version="1.0" encoding="utf-16"?>
    <pub-sub>
      <subcription event="UFIDA.U9.PM.PO.PurchaseOrder.Updating">
        <subscriber type="UFIDA.U9.Cust.Canaan.PurchaseOrderPlugBE.Updating,UFIDA.U9.Cust.Canaan.PurchaseOrderPlugBE.dll" />
      </subcription>
    </pub-sub>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    添加引用:

    把一些必要的dll文件添加进项目。
    在这里插入图片描述

    编码

    我们的代码就写在UpdatingExtend.cs中。

    在这里插入图片描述
    代码如下:

    
    
    namespace UFIDA.U9.Cust.Canaan.PurchaseOrderPlugBE
    {
        using System;
        using System.Data;
        using System.Collections.Generic;
        using System.Text;
        using UFIDA.U9.Base;
        using UFIDA.U9.Base.UserRole;
        using UFSoft.UBF.Business;
        using UFSoft.UBF.Util.DataAccess;
    
    
        public partial class Updating
        {
            
            private void Do_Notify(object[] args)
            {
                #region 从事件参数中取得当前业务实体													 
                                                                                                      
                if (args == null || args.Length == 0 || !(args[0] is UFSoft.UBF.Business.EntityEvent))
                    return;                                                                           
                BusinessEntity.EntityKey key = ((UFSoft.UBF.Business.EntityEvent)args[0]).EntityKey;  
                if (key == null)                                                                      
                    return;                                                                           
                UFIDA.U9.PM.PO.PurchaseOrder PurchaseOrderBe = key.GetEntity() as UFIDA.U9.PM.PO.PurchaseOrder;                                      
                if (PurchaseOrderBe == null)                                                                   
                    return;
    
                #endregion
    
                // 如果审核状态为核准中,插入数据到中间表Canaan_PurchaseOrder_Middle,触发OA审核流程
                if (PurchaseOrderBe.Status.Value == 1)
                {
                    String userID = Context.LoginUserID;
                    String userWorkCode = "";
                    User user = User.Finder.FindByID(userID);
                    if (user != null)
                    {
                        //获取工号
                        userWorkCode = user.Code;
                    }
    
                    DataSet ds;
                    DataParamList paras = new DataParamList();
                    StringBuilder sql = new StringBuilder();
                    sql.Append("select * from Canaan_PurchaseOrder_Middle where PRID = " + PurchaseOrderBe.ID);
                    DataAccessor.RunSQL(UFSoft.UBF.Util.DataAccess.DataAccessor.GetConn(), sql.ToString(), paras, out ds);
                    if (ds != null)
                    {
                        if (ds.Tables.Count > 0)
                        {
                            // 如果中间表已经存在改单据就不插入了
                            if (ds.Tables[0].Rows.Count == 0)
                            {
                                //供应商名称
                                string supplierName = PurchaseOrderBe.Supplier.Supplier.Name;
                                //供应商联系人
                                string supplierContact = PurchaseOrderBe.Supplier.Supplier.DescFlexField.PrivateDescSeg7;
                                //供应商联系人电话
                                string supplierContactTel = PurchaseOrderBe.Supplier.Supplier.DescFlexField.PrivateDescSeg10;
    
                                sql.Clear();
                                sql.Append("insert into Canaan_PurchaseOrder_Middle(PRID,DocNo,CreatedOn,supplier_name,supplier_contact,supplier_contact_tel,state,memo,create_by,create_time,ry) values(" +
                                    PurchaseOrderBe.ID + ",'" + PurchaseOrderBe.DocNo + "','" + PurchaseOrderBe.CreatedOn + "','" + supplierName + "','" + supplierContact + "','" + supplierContactTel + "',0,'" + "','待同步','sys',GETDATE(),'" + userWorkCode + "')");
                                DataAccessor.RunSQL(UFSoft.UBF.Util.DataAccess.DataAccessor.GetConn(), sql.ToString(), paras, out ds);
                            }
                        }
    
                    }
                }
            }
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76

    编译和复制

    编译完整个项目之后,需要复制文件到对应的文件夹下:

    1.复制UFIDA.U9.Cust.Canaan.PurchaseOrderPlugBE.dll 和 UFIDA.U9.Cust.Canaan.PurchaseOrderPlugBE.pdb 文件到U9V60\Portal\ApplicationServer\Libs目录下:

    在这里插入图片描述

    2.复制UFIDA.U9.Cust.Canaan.PurchaseOrderPlugBE.sub.xml文件到\U9V60\Portal\bin目录下:

    在这里插入图片描述

    然后在cmd中运行 iisreset ,重启iis服务器,就可以运行插件了。
    在这里插入图片描述

    调试

    如果需要调试的话,下完断点之后,选择调试-附加到进程。

    在这里插入图片描述

    搜索w3,附加w3wp.exe进程。
    在这里插入图片描述
    附加完进程之后就可以调试啦。

    测试没问题之后就可以制作补丁,发布啦。

    最后

    这就是BE开发的整个过程,没什么难度,只是过程比较繁琐,网上u9二开的资料也比较少,仅仅做个记录,以备查看。

  • 相关阅读:
    QSpace Pro for Mac(多面板文件管理器)
    基于Springboot外卖系统07:员工分页查询+ 分页插件配置+分页代码实现
    身份证号码算法解析与Java代码实现
    武汉新时标文化传媒有限公司短视频营销玩法大比拼
    React Native
    基于C#开发web网页管理系统模板流程-主界面密码维护功能完善
    python数学建模--求解线性规划问题的若干种方法
    快递查询、导出表格,批量操作效率更高
    【愚公系列】2022年07月 Tabby集成终端的使用
    【操作系统】进程间通信方式
  • 原文地址:https://blog.csdn.net/zhanyd/article/details/126596364