二开案例.表单插件.附件(数据库)
【应用场景】
在界面上显示并使用附件(数据库)字段。
该字段可以将文件上传并存储在数据库中,并提供预览、下载、删除等功能。
【案例演示】
采购订单,新增附件(数据库)字段,演示上传附件,读取附件信息等。
【实现步骤】
<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
二开案例.表单插件.附件(数据库)
本文2024-09-23 03:59:48发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-162429.html