二开案例.表单插件.附件(数据库)

栏目:云星空知识作者:金蝶来源:金蝶云社区发布:2024-09-23浏览:1

二开案例.表单插件.附件(数据库)

【应用场景】

在界面上显示并使用附件(数据库)字段。

该字段可以将文件上传并存储在数据库中,并提供预览、下载、删除等功能。



【案例演示】

采购订单,新增附件(数据库)字段,演示上传附件,读取附件信息等。



【实现步骤】

<1>编写表单插件,代码如下。

using Kingdee.BOS;

using Kingdee.BOS.App.Data;

using Kingdee.BOS.Core.DynamicForm.PlugIn;

using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;

using Kingdee.BOS.Core.Objects.Const;

using Kingdee.BOS.JSON;

using Kingdee.BOS.Util;

using Newtonsoft.Json;

using Newtonsoft.Json.Linq;

using System.ComponentModel;

using System.Linq;

using System.Text;


namespace Jac.XkDemo.BOS.Business.PlugIn

{

    /// <summary>

    /// 【表单插件】获取附件(数据库)

    /// </summary>

    [Description("【表单插件】获取附件(数据库)"), HotUpdate]

    public class GetDbAttachmentInfoFormPlugIn : AbstractDynamicFormPlugIn

    {

        public override void BarItemClick(BarItemClickEventArgs e)

        {

            base.BarItemClick(e);

            if (e.BarItemKey.EqualsIgnoreCase("test"))

            {

                // 从数据库读取附件文件信息

                var sql = string.Format("SELECT F_JAC_FILEUPDATE FROM T_PUR_POORDER WHERE FBILLNO='{0}'", this.Model.GetValue("FBillNo"));

                var val = DBUtils.ExecuteScalar(Context, sql, string.Empty);

                if (!string.IsNullOrWhiteSpace(val))

                {

                    var array = SerializatonUtil.DeserializeFromBase64<JSONArray>(val);

                    if (array != null && array.Count > 0)

                    {

                        var sb = new StringBuilder("From Db").AppendLine();

                        for (var i = 0; i < array.Count; i++)

                        {

                            sb.Append("文件名:").Append(((JSONObject) array[i]).GetString("FileName"));

                            var fileContent = Encoding.UTF8.GetString((byte[]) ((JSONObject) array[i]).Get("FileContent"));

                            sb.Append(";文件内容:").Append(fileContent).AppendLine();

                        }


                        this.Model.SetValue("F_Jac_Remarks", sb.ToString());

                    }

                }

            }

        }


        public override void CustomEvents(CustomEventsArgs e)

        {

            base.CustomEvents(e);


            #region 文件上传,捕获文件改变事件


            if (e.EventName.EqualsIgnoreCase("FileChanged"))

            {

                if (e.EventArgs.IsNullOrEmptyOrWhiteSpace())

                {

                    return;

                }


                var data = KDObjectConverter.DeserializeObject<JSONObject>(e.EventArgs);

                if (data == null)

                {

                    return;

                }


                var array = KDObjectConverter.DeserializeObject<JSONArray>(JsonConvert.SerializeObject(data.Get("NewValue")));

                if (array != null && array.Count > 0)

                {

                    var sb = new StringBuilder("From FileChanged").AppendLine();

                    for (var i = 0; i < array.Count; i++)

                    {

                        sb.Append("文件名:").Append(((JObject) array[i])["FileName"]).AppendLine();

                    }


                    this.Model.SetValue("F_Jac_Remarks", sb.ToString());

                }

            }


            #endregion


            #region 文件上传,捕获状态改变事件


            if (e.EventName.EqualsIgnoreCase(CustomEventName.StateChanged))

            {

                if (e.EventArgs.IsNullOrEmptyOrWhiteSpace())

                {

                    return;

                }


                var data = KDObjectConverter.DeserializeObject<JSONObject>(e.EventArgs);

                if (data == null || !data.ContainsKey("State"))

                {

                    return;

                }


                int state;

                if (int.TryParse(data["State"].GetString(), out state))

                {

                    // 为0表示开始上传,为1表示上传中,为2表示上传结束,为3代表上传失败。

                    if (state == 2)

                    {

                        // TODO

                    }

                }


                return;

            }


            #endregion

        }


        public override void DataChanged(DataChangedEventArgs e)

        {

            base.DataChanged(e);

            if (e.Field.Key == "F_Jac_FileUpdate")

            {

                // 从附件字段中读取附件文件信息

                var value = e.NewValue;

                if (value != null && (value is JSONArray || value is object[]))

                {

                    var array = value as JSONArray;

                    if (value is object[])

                    {

                        array = ObjArrayToJsonArray(value as object[]);

                    }


                    if (array.Count > 0)

                    {

                        var sb = new StringBuilder("From Model.DataChanged").AppendLine();

                        for (var i = 0; i < array.Count; i++)

                        {

                            sb.Append("文件名:").Append(((JSONObject) array[i]).GetString("FileName"));

                            var fileContent = Encoding.UTF8.GetString((byte[]) ((JSONObject) array[i]).Get("FileContent"));

                            sb.Append(";文件内容:").Append(fileContent).AppendLine();

                        }


                        //this.Model.SetValue("F_Jac_Remarks", sb.ToString());

                    }

                }

            }

        }


        private JSONArray ObjArrayToJsonArray(object[] objArray)

        {

            if (objArray != null && objArray.Any())

            {

                var jarray = new JSONArray();

                for (var i = 0; i < objArray.Count(); i++)

                {

                    jarray.Add(objArray[i]);

                }


                return jarray;

            }


            return new JSONArray();

        }

    }

}


<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。


<3>BOSIDE扩展采购订单,添加附件(数据库)字段,添加多行文本字段,菜单集合新增菜单项,注册表单插件,保存元数据,开发完毕。



【功能演示】

登录业务系统,打开采购订单编辑界面,上传附件,此时通过CustomEvents事件和DataChanged事件都能捕获到当前已上传的附件信息,保存单据后,还可以从数据库直接读取附件信息。

---------------------------------------------------------------------------------------------------------













【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696

二开案例.表单插件.附件(数据库)

【应用场景】在界面上显示并使用附件(数据库)字段。该字段可以将文件上传并存储在数据库中,并提供预览、下载、删除等功能。【案例演示】采...
点击下载文档
确认删除?
回到顶部
客服QQ
  • 客服QQ点击这里给我发消息