using System; using System.Data; using BP.DA; using BP.Sys; using BP.Web; using BP.En; using ICSharpCode.SharpZipLib.Zip; using BP.Difference; using System.IO; using System.Web; namespace BP.WF.HttpHandler { /// /// 页面功能实体 /// public class WF_CommEntity : DirectoryPageBase { /// /// 构造函数 /// public WF_CommEntity() { } #region 从表. /// /// 初始化 /// /// public string Dtl_Save() { try { #region 查询出来从表数据. Entities dtls = ClassFactory.GetEns(this.EnsName); Entity dtl = dtls.GetNewEntity; dtls.Retrieve(this.GetRequestVal("RefKey"), this.GetRequestVal("RefVal")); Map map = dtl.EnMap; foreach (Entity item in dtls) { string pkval = item.GetValStringByKey(dtl.PK); foreach (Attr attr in map.Attrs) { if (attr.IsRefAttr == true) continue; if (attr.MyDataType == DataType.AppDateTime || attr.MyDataType == DataType.AppDate) { if (attr.UIIsReadonly == true) continue; string val = this.GetValFromFrmByKey("TB_" + pkval + "_" + attr.Key, null); item.SetValByKey(attr.Key, val); continue; } if (attr.UIContralType == UIContralType.TB && attr.UIIsReadonly == false) { string val = this.GetValFromFrmByKey("TB_" + pkval + "_" + attr.Key, null); item.SetValByKey(attr.Key, val); continue; } if (attr.UIContralType == UIContralType.DDL && attr.UIIsReadonly == false) { string val = this.GetValFromFrmByKey("DDL_" + pkval + "_" + attr.Key); item.SetValByKey(attr.Key, val); continue; } if (attr.UIContralType == UIContralType.CheckBok && attr.UIIsReadonly == false) { string val = this.GetValFromFrmByKey("CB_" + pkval + "_" + attr.Key, "-1"); if (val == "-1") item.SetValByKey(attr.Key, 0); else item.SetValByKey(attr.Key, val); continue; } } item.Update(); //执行更新. } #endregion 查询出来从表数据. #region 保存新加行. int newRowCount = this.GetRequestValInt("NewRowCount"); bool isEntityOID = dtl.IsOIDEntity; //已同步数据. bool isEntityNo = dtl.IsNoEntity; for (int i = 0; i < newRowCount; i++) { string val = ""; foreach (Attr attr in map.Attrs) { if (attr.MyDataType == DataType.AppDateTime || attr.MyDataType == DataType.AppDate) { if (attr.UIIsReadonly == true) continue; val = this.GetValFromFrmByKey("TB_" + i + "_" + attr.Key, null); dtl.SetValByKey(attr.Key, val); continue; } if (attr.UIContralType == UIContralType.TB && attr.UIIsReadonly == false) { val = this.GetValFromFrmByKey("TB_" + i + "_" + attr.Key); if (attr.IsNum && val == "") val = "0"; dtl.SetValByKey(attr.Key, val); continue; } if (attr.UIContralType == UIContralType.DDL && attr.UIIsReadonly == false) { val = this.GetValFromFrmByKey("DDL_" + i + "_" + attr.Key); dtl.SetValByKey(attr.Key, val); continue; } if (attr.UIContralType == UIContralType.CheckBok && attr.UIIsReadonly == false) { val = this.GetValFromFrmByKey("CB_" + i + "_" + attr.Key, "-1"); if (val == "-1") dtl.SetValByKey(attr.Key, 0); else dtl.SetValByKey(attr.Key, val); continue; } } //dtl.SetValByKey(pkval, 0); dtl.SetValByKey(this.GetRequestVal("RefKey"), this.GetRequestVal("RefVal")); //已同步数据. if (isEntityOID == true) { dtl.PKVal = "0"; dtl.Insert(); continue; } if (isEntityNo == true && dtl.EnMap.IsAutoGenerNo == true) { dtl.PKVal = dtl.GenerNewNoByKey("No"); dtl.Insert(); continue; } //直接执行保存. dtl.Insert(); } #endregion 保存新加行. return "保存成功."; } catch (Exception ex) { return "err@" + ex.Message; } } /// /// 保存 /// /// public string Dtl_Init() { //定义容器. DataSet ds = new DataSet(); //查询出来从表数据. Entities dtls = ClassFactory.GetEns(this.EnsName); dtls.Retrieve(this.GetRequestVal("RefKey"), this.GetRequestVal("RefVal")); ds.Tables.Add(dtls.ToDataTableField("Dtls")); //实体. Entity dtl = dtls.GetNewEntity; //定义Sys_MapData. MapData md = new MapData(); md.No = this.EnName; md.Name = dtl.EnDesc; #region 加入权限信息. //把权限加入参数里面. if (dtl.HisUAC.IsInsert) md.SetPara("IsInsert", "1"); if (dtl.HisUAC.IsUpdate) md.SetPara("IsUpdate", "1"); if (dtl.HisUAC.IsDelete) md.SetPara("IsDelete", "1"); if (dtl.HisUAC.IsImp) md.SetPara("IsImp", "1"); if (dtl.HisUAC.IsExp) md.SetPara("IsImp", "1"); md.SetPara("EntityPK", dtl.PKField); #endregion 加入权限信息. ds.Tables.Add(md.ToDataTableField("Sys_MapData")); #region 字段属性. MapAttrs attrs = dtl.EnMap.Attrs.ToMapAttrs; DataTable sys_MapAttrs = attrs.ToDataTableField("Sys_MapAttr"); ds.Tables.Add(sys_MapAttrs); #endregion 字段属性. #region 把外键与枚举放入里面去. foreach (MapAttr mapAttr in attrs) { string uiBindKey = mapAttr.UIBindKey; if (mapAttr.LGType != FieldTypeS.FK) continue; if (mapAttr.UIIsEnable == false) continue; if (DataType.IsNullOrEmpty(uiBindKey) == true) continue; // 判断是否存在. if (ds.Tables.Contains(uiBindKey) == true) continue; ds.Tables.Add(BP.Pub.PubClass.GetDataTableByUIBineKey(uiBindKey)); } foreach (Attr attr in dtl.EnMap.Attrs) { if (attr.IsRefAttr == true) continue; if (DataType.IsNullOrEmpty(attr.UIBindKey) || attr.UIBindKey.Length <= 10) continue; if (attr.UIIsReadonly == true) continue; if (attr.UIBindKey.Contains("SELECT") == true || attr.UIBindKey.Contains("select") == true) { /*是一个sql*/ string sqlBindKey = attr.UIBindKey.Clone() as string; // 判断是否存在. if (ds.Tables.Contains(sqlBindKey) == true) continue; sqlBindKey = BP.WF.Glo.DealExp(sqlBindKey, null, null); DataTable dt = DBAccess.RunSQLReturnTable(sqlBindKey); dt.TableName = attr.Key; if (BP.Difference.SystemConfig.AppCenterDBFieldCaseModel != FieldCaseModel.None) { foreach (DataColumn col in dt.Columns) { string colName = col.ColumnName.ToLower(); switch (colName) { case "no": col.ColumnName = "No"; break; case "name": col.ColumnName = "Name"; break; default: break; } } } ds.Tables.Add(dt); } } string enumKeys = ""; foreach (Attr attr in dtl.EnMap.Attrs) { if (attr.MyFieldType == FieldType.Enum) { enumKeys += "'" + attr.UIBindKey + "',"; } } if (enumKeys.Length > 2) { enumKeys = enumKeys.Substring(0, enumKeys.Length - 1); // Sys_Enum string sqlEnum = "SELECT * FROM " + BP.Sys.Base.Glo.SysEnum() + " WHERE EnumKey IN (" + enumKeys + ")"; DataTable dtEnum = DBAccess.RunSQLReturnTable(sqlEnum); dtEnum.TableName = "Sys_Enum"; if (BP.Difference.SystemConfig.AppCenterDBFieldCaseModel != FieldCaseModel.None) { foreach (DataColumn col in dtEnum.Columns) { string colName = col.ColumnName.ToLower(); switch (colName) { case "mypk": col.ColumnName = "MyPK"; break; case "lab": col.ColumnName = "Lab"; break; case "enumkey": col.ColumnName = "EnumKey"; break; case "intkey": col.ColumnName = "IntKey"; break; case "lang": col.ColumnName = "Lang"; break; default: break; } } } ds.Tables.Add(dtEnum); } #endregion 把外键与枚举放入里面去. return BP.Tools.Json.ToJson(ds); } public string Dtl_Exp() { string refPKVal = this.GetRequestVal("RefVal"); Entities dtls = ClassFactory.GetEns(this.EnsName); dtls.Retrieve(this.GetRequestVal("RefKey"), this.GetRequestVal("RefVal")); Entity en = dtls.GetNewEntity; string name = "数据导出"; if (refPKVal.Contains("/") == true) refPKVal = refPKVal.Replace("/", "_"); string filename = refPKVal + "_" + en.ToString() + "_" + DataType.CurrentDate + "_" + name + ".xls"; string filePath = BP.Tools.ExportExcelUtil.ExportDGToExcel(dtls.ToDataTableField(), en, name, null, filename); filePath = BP.Difference.SystemConfig.PathOfTemp + filename; string tempPath = BP.Difference.SystemConfig.PathOfTemp + refPKVal + "/"; if (System.IO.Directory.Exists(tempPath) == false) System.IO.Directory.CreateDirectory(tempPath); string myFilePath = BP.Difference.SystemConfig.PathOfDataUser + this.EnsName.Substring(0, this.EnsName.Length - 1); foreach (Entity dt in dtls) { string pkval = dt.PKVal.ToString(); string ext = string.IsNullOrWhiteSpace(dt.GetValByKey("MyFileExt") as string) ? "" : dt.GetValByKey("MyFileExt").ToString(); if (DataType.IsNullOrEmpty(ext) == true) continue; myFilePath = myFilePath + "/" + pkval + "." + ext; if (System.IO.File.Exists(myFilePath) == true) System.IO.File.Copy(myFilePath, tempPath + pkval + "." + ext, true); } System.IO.File.Copy(filePath, tempPath + filename, true); //生成压缩文件 string zipFile = BP.Difference.SystemConfig.PathOfTemp + refPKVal + "_" + en.ToString() + "_" + DataType.CurrentDate + "_" + name + ".zip"; System.IO.FileInfo finfo = new System.IO.FileInfo(zipFile); (new FastZip()).CreateZip(finfo.FullName, tempPath, true, ""); return "/DataUser/Temp/" + refPKVal + "_" + en.ToString() + "_" + DataType.CurrentDate + "_" + name + ".zip"; } #endregion 从表. #region 实体的操作. /// /// 实体初始化 /// /// public string EntityOnly_Init() { try { //是否是空白记录. bool isBlank = DataType.IsNullOrEmpty(this.PKVal); //初始化entity. string enName = this.EnName; Entity en = null; if (isBlank == true) { if (DataType.IsNullOrEmpty(this.EnsName) == true) return "err@类名没有传递过来"; Entities ens = ClassFactory.GetEns(this.EnsName); if (ens == null) return "err@类名错误" + this.EnsName; en = ens.GetNewEntity; } else { en = ClassFactory.GetEn(this.EnName); } if (en == null) return "err@参数类名不正确."; //获得描述. Map map = en.EnMap; string pkVal = this.PKVal; if (isBlank == false) { en.PKVal = pkVal; int i = en.RetrieveFromDBSources(); if (i == 0) return "err@数据[" + map.EnDesc + "]主键为[" + pkVal + "]不存在,或者没有保存。"; } else { foreach (Attr attr in en.EnMap.Attrs) en.SetValByKey(attr.Key, attr.DefaultVal); //设置默认的数据. en.ResetDefaultVal(); en.SetValByKey("RefPKVal", this.RefPKVal); //自动生成一个编号. if (en.IsNoEntity == true && en.EnMap.IsAutoGenerNo == true) en.SetValByKey("No", en.GenerNewNoByKey("No")); } //定义容器. DataSet ds = new DataSet(); //定义Sys_MapData. MapData md = new MapData(); md.No = this.EnName; md.Name = map.EnDesc; //附件类型. md.SetPara("BPEntityAthType", (int)map.HisBPEntityAthType); //多附件上传 if ((int)map.HisBPEntityAthType == 2) { //增加附件分类 DataTable attrFiles = new DataTable("AttrFiles"); attrFiles.Columns.Add("FileNo"); attrFiles.Columns.Add("FileName"); foreach (AttrFile attrFile in map.HisAttrFiles) { DataRow dr = attrFiles.NewRow(); dr["FileNo"] = attrFile.FileNo; dr["FileName"] = attrFile.FileName; attrFiles.Rows.Add(dr); } ds.Tables.Add(attrFiles); //增加附件列表 SysFileManagers sfs = new SysFileManagers(en.ToString(), en.PKVal.ToString()); ds.Tables.Add(sfs.ToDataTableField("Sys_FileManager")); } #region 加入权限信息. //把权限加入参数里面. if (en.HisUAC.IsInsert) md.SetPara("IsInsert", "1"); if (en.HisUAC.IsUpdate) md.SetPara("IsUpdate", "1"); if (isBlank == true) { if (en.HisUAC.IsDelete) md.SetPara("IsDelete", "0"); } else { if (en.HisUAC.IsDelete) md.SetPara("IsDelete", "1"); } #endregion 加入权限信息. ds.Tables.Add(md.ToDataTableField("Sys_MapData")); //把主数据放入里面去. DataTable dtMain = en.ToDataTableField("MainTable"); ds.Tables.Add(dtMain); Attrs attrs = en.EnMap.Attrs; MapAttrs mapAttrs = new MapAttrs(); //获取Map中的分组 DataTable dtGroups = new DataTable("Sys_GroupField"); dtGroups.Columns.Add("OID"); dtGroups.Columns.Add("Lab"); string groupName = ""; string groupNames = ""; foreach(Attr attr in attrs) { if (attr.MyFieldType == FieldType.RefText) continue; groupName = attr.GroupName; if (groupNames.Contains(groupName + ",") == false) { DataRow dr = dtGroups.NewRow(); groupNames += groupName + ","; dr["OID"] = groupName; dr["Lab"] = groupName; dtGroups.Rows.Add(dr); } MapAttr mapAttr = attr.ToMapAttr; mapAttr.SetPara("GroupName", attr.GroupName); mapAttrs.AddEntity(mapAttr); } ds.Tables.Add(dtGroups); DataTable sys_MapAttrs = mapAttrs.ToDataTableField("Sys_MapAttr"); ds.Tables.Add(sys_MapAttrs); #region 加入扩展属性. MapExts mapExts = new MapExts(this.EnName + "s"); DataTable Sys_MapExt = mapExts.ToDataTableField("Sys_MapExt"); ds.Tables.Add(Sys_MapExt); #endregion 加入扩展属性. #region 把外键与枚举放入里面去. //加入外键. foreach (DataRow dr in sys_MapAttrs.Rows) { string uiBindKey = dr["UIBindKey"].ToString(); string lgType = dr["LGType"].ToString(); if (lgType.Equals("2") == false) continue; string UIVisible = dr["UIVisible"].ToString(); string uiIsEnable = dr["UIIsEnable"].ToString(); if (UIVisible.Equals("0") == true || uiIsEnable.Equals("0") == true) continue; if (DataType.IsNullOrEmpty(uiBindKey) == true) { string myPK = dr["MyPK"].ToString(); /*如果是空的*/ // throw new Exception("@属性字段数据不完整,流程:" + fl.No + fl.Name + ",节点:" + nd.NodeID + nd.Name + ",属性:" + myPK + ",的UIBindKey IsNull "); } // 检查是否有下拉框自动填充。 string keyOfEn = dr["KeyOfEn"].ToString(); string fk_mapData = dr["FK_MapData"].ToString(); // 判断是否存在. if (ds.Tables.Contains(uiBindKey) == true) continue; DataTable dt = BP.Pub.PubClass.GetDataTableByUIBineKey(uiBindKey); dt.TableName = keyOfEn; ds.Tables.Add(dt); } //加入sql模式的外键. foreach (Attr attr in en.EnMap.Attrs) { if (attr.IsRefAttr == true) continue; if (DataType.IsNullOrEmpty(attr.UIBindKey) || attr.UIBindKey.Length <= 10) continue; if (attr.UIIsReadonly == true) continue; if (attr.UIBindKey.ToUpper().Contains("SELECT") == true) { /*是一个sql*/ string sqlBindKey = attr.UIBindKey.Clone() as string; sqlBindKey = BP.WF.Glo.DealExp(sqlBindKey, en, null); DataTable dt = DBAccess.RunSQLReturnTable(sqlBindKey); dt.TableName = attr.Key; //@杜. 翻译当前部分. if (BP.Difference.SystemConfig.AppCenterDBFieldCaseModel == FieldCaseModel.UpperCase) { dt.Columns["NO"].ColumnName = "No"; dt.Columns["NAME"].ColumnName = "Name"; } if (BP.Difference.SystemConfig.AppCenterDBFieldCaseModel == FieldCaseModel.Lowercase) { dt.Columns["no"].ColumnName = "No"; dt.Columns["name"].ColumnName = "Name"; } ds.Tables.Add(dt); } } //加入枚举的外键. string enumKeys = ""; foreach (Attr attr in map.Attrs) { if (attr.MyFieldType == FieldType.Enum) { enumKeys += "'" + attr.UIBindKey + "',"; } } if (enumKeys.Length > 2) { enumKeys = enumKeys.Substring(0, enumKeys.Length - 1); DataTable dtEnum = new DataTable(); string sqlEnum = ""; if (BP.Difference.SystemConfig.CCBPMRunModel == CCBPMRunModel.SAAS) { string sqlWhere = " EnumKey IN (" + enumKeys + ") AND OrgNo='" + WebUser.OrgNo + "'"; sqlEnum = "SELECT * FROM " + BP.Sys.Base.Glo.SysEnum() + " WHERE " + sqlWhere; sqlEnum += " UNION "; sqlEnum += "SELECT * FROM " + BP.Sys.Base.Glo.SysEnum() + " WHERE EnumKey IN (" + enumKeys + ") AND EnumKey NOT IN (SELECT EnumKey FROM " + BP.Sys.Base.Glo.SysEnum() + " WHERE " + sqlWhere + ") AND (OrgNo Is Null Or OrgNo='')"; dtEnum = DBAccess.RunSQLReturnTable(sqlEnum); } else { sqlEnum = "SELECT * FROM " + BP.Sys.Base.Glo.SysEnum() + " WHERE EnumKey IN (" + enumKeys + ")"; dtEnum = DBAccess.RunSQLReturnTable(sqlEnum); } dtEnum.TableName = "Sys_Enum"; if (BP.Difference.SystemConfig.AppCenterDBFieldCaseModel == FieldCaseModel.UpperCase) { dtEnum.Columns["MYPK"].ColumnName = "MyPK"; dtEnum.Columns["LAB"].ColumnName = "Lab"; dtEnum.Columns["ENUMKEY"].ColumnName = "EnumKey"; dtEnum.Columns["INTKEY"].ColumnName = "IntKey"; dtEnum.Columns["LANG"].ColumnName = "Lang"; } if (BP.Difference.SystemConfig.AppCenterDBFieldCaseModel == FieldCaseModel.Lowercase) { dtEnum.Columns["mypk"].ColumnName = "MyPK"; dtEnum.Columns["lab"].ColumnName = "Lab"; dtEnum.Columns["enumkey"].ColumnName = "EnumKey"; dtEnum.Columns["intkey"].ColumnName = "IntKey"; dtEnum.Columns["lang"].ColumnName = "Lang"; } ds.Tables.Add(dtEnum); } #endregion 把外键与枚举放入里面去. #region 增加 上方法. DataTable dtM = new DataTable("dtM"); dtM.Columns.Add("No"); dtM.Columns.Add("Title"); dtM.Columns.Add("Tip"); dtM.Columns.Add("Visable"); dtM.Columns.Add("Url"); dtM.Columns.Add("Target"); dtM.Columns.Add("Warning"); dtM.Columns.Add("RefMethodType"); dtM.Columns.Add("GroupName"); dtM.Columns.Add("W"); dtM.Columns.Add("H"); dtM.Columns.Add("Icon"); dtM.Columns.Add("IsCanBatch"); dtM.Columns.Add("RefAttrKey"); RefMethods rms = map.HisRefMethods; foreach (RefMethod item in rms) { item.HisEn = en; //item.HisAttrs = en.EnMap.Attrs;B string myurl = ""; if (item.RefMethodType != RefMethodType.Func) { myurl = item.Do(null) as string; if (myurl == null) continue; } else { myurl = "../RefMethod.htm?Index=" + item.Index + "&EnName=" + en.ToString() + "&EnsName=" + en.GetNewEntities.ToString() + "&PKVal=" + this.PKVal; } DataRow dr = dtM.NewRow(); dr["No"] = item.Index; dr["Title"] = item.Title; dr["Tip"] = item.ToolTip; dr["Visable"] = item.Visable; dr["Warning"] = item.Warning; dr["RefMethodType"] = (int)item.RefMethodType; dr["RefAttrKey"] = item.RefAttrKey; dr["Url"] = myurl; dr["W"] = item.Width; dr["H"] = item.Height; dr["Icon"] = item.Icon; dr["IsCanBatch"] = item.IsCanBatch; dr["GroupName"] = item.GroupName; dtM.Rows.Add(dr); //增加到rows. } //增加方法。 ds.Tables.Add(dtM); #endregion 增加 上方法. #region 从表 DataTable dtl = new DataTable("Dtl"); dtl.Columns.Add("No"); dtl.Columns.Add("Title"); dtl.Columns.Add("Url"); dtl.Columns.Add("GroupName"); EnDtls enDtls = en.EnMapInTime.Dtls; foreach (EnDtl enDtl in enDtls) { if (enDtl.DtlEditerModel == DtlEditerModel.DtlBatch || enDtl.DtlEditerModel == DtlEditerModel.DtlSearch || enDtl.DtlEditerModel == DtlEditerModel.DtlURL) continue; //判断该dtl是否要显示? string url = ""; if(enDtl.DtlEditerModel != DtlEditerModel.DtlURLEnonly) { Entity myEnDtl = enDtl.Ens.GetNewEntity; //获取他的en myEnDtl.SetValByKey(enDtl.RefKey, this.PKVal); //给refpk赋值. if (myEnDtl.HisUAC.IsView == false) continue; if (enDtl.DtlEditerModel == DtlEditerModel.DtlBatch) url = "DtlBatch.htm?EnName=" + this.EnName + "&PK=" + this.PKVal + "&EnsName=" + enDtl.EnsName + "&RefKey=" + enDtl.RefKey + "&RefVal=" + en.PKVal.ToString() + "&MainEnsName=" + en.ToString(); else url = "DtlSearch.htm?EnName=" + this.EnName + "&PK=" + this.PKVal + "&EnsName=" + enDtl.EnsName + "&RefKey=" + enDtl.RefKey + "&RefVal=" + en.PKVal.ToString() + "&MainEnsName=" + en.ToString(); } else { url = enDtl.UrlExt; url = BP.WF.Glo.DealExp(url, en); } DataRow dr = dtl.NewRow(); dr["No"] = enDtl.DtlEditerModel == DtlEditerModel.DtlURLEnonly? enDtl.Desc:enDtl.EnsName; dr["Title"] = enDtl.Desc; dr["Url"] = url; dr["GroupName"] = enDtl.GroupName; dtl.Rows.Add(dr); } #endregion 增加 从表. ds.Tables.Add(dtl); return BP.Tools.Json.ToJson(ds); } catch (Exception ex) { return "err@" + ex.Message; } } /// /// 实体Entity 单文件上传 /// /// public string EntityAth_Upload() { var files = HttpContextHelper.RequestFiles(); if (files.Count == 0) return "err@请选择要上传的文件。"; //获取保存文件信息的实体 string enName = this.EnName; Entity en = null; //是否是空白记录. bool isBlank = DataType.IsNullOrEmpty(this.PKVal); if (isBlank == true) return "err@请先保存实体信息然后再上传文件"; else en = ClassFactory.GetEn(this.EnName); if (en == null) return "err@参数类名不正确."; en.PKVal = this.PKVal; int i = en.RetrieveFromDBSources(); if (i == 0) return "err@数据[" + this.EnName + "]主键为[" + en.PKVal + "]不存在,或者没有保存。"; //获取文件的名称 string fileName = files[0].FileName; if (fileName.IndexOf("/") >= 0) fileName = fileName.Substring(fileName.LastIndexOf("/") + 1); fileName = fileName.Substring(0, fileName.LastIndexOf('.')); //文件后缀 string ext = System.IO.Path.GetExtension(files[0].FileName); ext = ext.Replace(".", ""); //去掉点 @李国文 //文件大小 float size = HttpContextHelper.RequestFileLength(files[0]) / 1024; //保存位置 string filepath = ""; string relativePath = ""; //如果是天业集团则保存在ftp服务器上 if (BP.Difference.SystemConfig.CustomerNo.Equals("TianYe") || BP.Difference.SystemConfig.IsUploadFileToFTP == true) { string guid = DBAccess.GenerGUID(); //把文件临时保存到一个位置. string temp = BP.Difference.SystemConfig.PathOfTemp + "" + guid + ".tmp"; try { //files[0].SaveAs(temp); HttpContextHelper.UploadFile(files[0], temp); } catch (Exception ex) { System.IO.File.Delete(temp); //files[0].SaveAs(temp); HttpContextHelper.UploadFile(files[0], temp); } /*保存到fpt服务器上.*/ FtpConnection ftpconn = new FtpConnection(BP.Difference.SystemConfig.FTPServerIP, BP.Difference.SystemConfig.FTPServerPort, SystemConfig.FTPUserNo, BP.Difference.SystemConfig.FTPUserPassword); if (ftpconn == null) return "err@FTP服务器连接失败"; string ny = DateTime.Now.ToString("yyyy_MM"); //判断目录年月是否存在. if (ftpconn.DirectoryExist(ny) == false) ftpconn.CreateDirectory(ny); ftpconn.SetCurrentDirectory(ny); //判断目录是否存在. if (ftpconn.DirectoryExist("Helper") == false) ftpconn.CreateDirectory("Helper"); //设置当前目录,为操作的目录。 ftpconn.SetCurrentDirectory("Helper"); //把文件放上去. ftpconn.PutFile(temp, guid + "." + ext); ftpconn.Close(); //删除临时文件 System.IO.File.Delete(temp); //设置路径. filepath = ny + "/Helper/" + guid + "." + ext; } else { string fileSavePath = en.EnMap.FJSavePath; if (DataType.IsNullOrEmpty(fileSavePath) == true) fileSavePath = BP.Difference.SystemConfig.PathOfDataUser + enName; if (System.IO.Directory.Exists(fileSavePath) == false) System.IO.Directory.CreateDirectory(fileSavePath); filepath = fileSavePath + "/" + this.PKVal + "." + ext; relativePath = "/DataUser/" + enName + '/' + this.PKVal + "." + ext; //存在文件则删除 if (System.IO.File.Exists(filepath) == true) System.IO.File.Delete(filepath); FileInfo info = new FileInfo(filepath); //files[0].SaveAs(filepath); HttpContextHelper.UploadFile(files[0], filepath); } //需要这样写 @李国文. en.SetValByKey("MyFileName", fileName); en.SetValByKey("MyFilePath", filepath); en.SetValByKey("MyFileExt", ext); en.SetValByKey("MyFileSize", size); en.SetValByKey("WebPath", relativePath); en.Update(); return "文件保存成功"; } /// /// 实体单附件删除 /// /// public string EntityAth_Delete() { string pkval = this.PKVal; string enName = this.EnName; if(DataType.IsNullOrEmpty(pkval) || DataType.IsNullOrEmpty(enName)) { return "err@删除实体附件需要传入PKVal和EnName"; } Entity en = ClassFactory.GetEn(this.EnName); en.PKVal = pkval; en.RetrieveFromDBSources(); string filePath = en.GetValStringByKey("MyFilePath"); try { System.IO.File.Delete(filePath); return "附件删除成功"; } catch (Exception e) { string errMsg = "err@删除失败," + "filePath: " + filePath + e.ToString(); BP.DA.Log.DebugWriteError(errMsg); return errMsg; } } public void EntityFile_Load() { //根据EnsName获取Entity Entities ens = ClassFactory.GetEns(this.EnsName); Entity en = ens.GetNewEntity; en.PKVal = this.GetRequestVal("DelPKVal"); int i = en.RetrieveFromDBSources(); if (i == 0) return; string filePath = en.GetValStringByKey("MyFilePath"); string fileName = en.GetValStringByKey("MyFileName"); string fileExt = en.GetValStringByKey("MyFileExt"); //获取使用的客存在FTP服务器上 if ( BP.Difference.SystemConfig.IsUploadFileToFTP == true) { //临时存储位置 string tempFile = BP.Difference.SystemConfig.PathOfTemp + System.Guid.NewGuid() + "." + en.GetValByKey("MyFileExt"); if (System.IO.File.Exists(tempFile) == true) System.IO.File.Delete(tempFile); //连接FTP服务器 FtpConnection conn = new FtpConnection(BP.Difference.SystemConfig.FTPServerIP, BP.Difference.SystemConfig.FTPServerPort, BP.Difference.SystemConfig.FTPUserNo, BP.Difference.SystemConfig.FTPUserPassword); conn.GetFile(filePath, tempFile, false, System.IO.FileAttributes.Archive); conn.Close(); BP.WF.HttpHandler.HttpHandlerGlo.DownloadFile(tempFile, fileName + "." + fileExt); //删除临时文件 System.IO.File.Delete(tempFile); } else { BP.WF.HttpHandler.HttpHandlerGlo.DownloadFile(filePath, fileName + "." + fileExt); } } /// /// 实体多附件上传 /// /// public string EntityMultiAth_Upload() { //HttpFileCollection files = context.Request.Files; var files = HttpContextHelper.RequestFiles(); if (files.Count == 0) return "err@请选择要上传的文件。"; //获取保存文件信息的实体 string enName = this.EnName; Entity en = null; //是否是空白记录. bool isBlank = DataType.IsNullOrEmpty(this.PKVal); if (isBlank == true) return "err@请先保存实体信息然后再上传文件"; else en = ClassFactory.GetEn(this.EnName); if (en == null) return "err@参数类名不正确."; en.PKVal = this.PKVal; int i = en.RetrieveFromDBSources(); if (i == 0) return "err@数据[" + this.EnName + "]主键为[" + en.PKVal + "]不存在,或者没有保存。"; //获取文件的名称 string fileName = files[0].FileName; if (fileName.IndexOf("/") >= 0) fileName = fileName.Substring(fileName.LastIndexOf("/") + 1); fileName = fileName.Substring(0, fileName.LastIndexOf('.')); SysFileManagers fileManagers = new SysFileManagers(); fileManagers.Retrieve(SysFileManagerAttr.RefVal, this.PKVal, SysFileManagerAttr.MyFileName, fileName); if (fileManagers.Count != 0) return "err@文件" + fileName + "已经存在"; //文件后缀 string ext = System.IO.Path.GetExtension(files[0].FileName); //文件大小 float size = HttpContextHelper.RequestFileLength(files[0]) / 1024; //保存位置 string filepath = ""; //如果是天业集团则保存在ftp服务器上 if (BP.Difference.SystemConfig.CustomerNo.Equals("TianYe") || BP.Difference.SystemConfig.IsUploadFileToFTP == true) { string guid = DBAccess.GenerGUID(); //把文件临时保存到一个位置. string temp = BP.Difference.SystemConfig.PathOfTemp + "" + guid + ".tmp"; try { //files[0].SaveAs(temp); HttpContextHelper.UploadFile(files[0], temp); } catch (Exception ex) { System.IO.File.Delete(temp); //files[0].SaveAs(temp); HttpContextHelper.UploadFile(files[0], temp); } /*保存到fpt服务器上.*/ FtpConnection ftpconn = new FtpConnection(BP.Difference.SystemConfig.FTPServerIP, BP.Difference.SystemConfig.FTPServerPort, SystemConfig.FTPUserNo, BP.Difference.SystemConfig.FTPUserPassword); if (ftpconn == null) return "err@FTP服务器连接失败"; string ny = DateTime.Now.ToString("yyyy_MM"); //判断目录年月是否存在. if (ftpconn.DirectoryExist(ny) == false) ftpconn.CreateDirectory(ny); ftpconn.SetCurrentDirectory(ny); //判断目录是否存在. if (ftpconn.DirectoryExist("Helper") == false) ftpconn.CreateDirectory("Helper"); //设置当前目录,为操作的目录。 ftpconn.SetCurrentDirectory("Helper"); //把文件放上去. ftpconn.PutFile(temp, guid + ext); ftpconn.Close(); //删除临时文件 System.IO.File.Delete(temp); //设置路径. filepath = ny + "/Helper/" + guid + ext; } else { string savePath = BP.Difference.SystemConfig.PathOfDataUser + enName + "/" + this.PKVal; if (System.IO.Directory.Exists(savePath) == false) System.IO.Directory.CreateDirectory(savePath); savePath = savePath + "/" + fileName + ext; //存在文件则删除 if (System.IO.Directory.Exists(savePath) == true) System.IO.Directory.Delete(savePath); FileInfo info = new FileInfo(savePath); //files[0].SaveAs(filepath); HttpContextHelper.UploadFile(files[0], savePath); filepath = "/DataUser/" + enName + "/" + this.PKVal + "/" + fileName + ext; } //保存上传的文件 SysFileManager fileManager = new SysFileManager(); fileManager.AttrFileNo = this.GetRequestVal("FileNo"); fileManager.AttrFileName = HttpUtility.UrlDecode(this.GetRequestVal("FileName"), System.Text.Encoding.UTF8); fileManager.EnName = this.EnName; fileManager.RefVal = this.PKVal; fileManager.MyFileName = fileName; fileManager.MyFilePath = filepath; fileManager.MyFileExt = ext; fileManager.MyFileSize = size; fileManager.WebPath = filepath; fileManager.Insert(); return fileManager.ToJson(); } public void EntityMutliFile_Load() { string oid = this.GetRequestVal("OID"); //根据SysFileManager的OID获取对应的实体 SysFileManager fileManager = new SysFileManager(); fileManager.PKVal = oid; int i = fileManager.RetrieveFromDBSources(); if (i == 0) throw new Exception("没有找到OID=" + oid + "的文件管理数据,请联系管理员"); //获取使用的客户保存在FTP服务器上 if (BP.Difference.SystemConfig.IsUploadFileToFTP == true) { string filePath = fileManager.MyFilePath; string fileName = fileManager.MyFileName; //临时存储位置 string tempFile = BP.Difference.SystemConfig.PathOfTemp + System.Guid.NewGuid() + "." + fileManager.MyFileExt; if (System.IO.File.Exists(tempFile) == true) System.IO.File.Delete(tempFile); //连接FTP服务器 FtpConnection conn = new FtpConnection(BP.Difference.SystemConfig.FTPServerIP, BP.Difference.SystemConfig.FTPServerPort, BP.Difference.SystemConfig.FTPUserNo, BP.Difference.SystemConfig.FTPUserPassword); conn.GetFile(filePath, tempFile, false, System.IO.FileAttributes.Archive); conn.Close(); BP.WF.HttpHandler.HttpHandlerGlo.DownloadFile(tempFile, fileName); //删除临时文件 System.IO.File.Delete(tempFile); } else { BP.WF.HttpHandler.HttpHandlerGlo.DownloadFile(fileManager.MyFilePath, fileManager.MyFileName+"."+ fileManager.MyFileExt); } } /// /// 删除实体多附件上传的信息 /// /// public string EntityMultiFile_Delete() { int oid = this.OID; SysFileManager fileManager = new SysFileManager(OID); //获取上传的附件路径,删除附件 string filepath = fileManager.MyFilePath; if (BP.Difference.SystemConfig.IsUploadFileToFTP == false) { if (System.IO.File.Exists(filepath) == true) System.IO.File.Delete(filepath); } else { /*保存到fpt服务器上.*/ FtpConnection ftpconn = new FtpConnection(BP.Difference.SystemConfig.FTPServerIP, BP.Difference.SystemConfig.FTPServerPort, BP.Difference.SystemConfig.FTPUserNo, BP.Difference.SystemConfig.FTPUserPassword); if (ftpconn == null) return "err@FTP服务器连接失败"; if (ftpconn.FileExist(filepath) == true) ftpconn.DeleteFile(filepath); } fileManager.Delete(); return fileManager.MyFileName + "删除成功"; } /// /// 实体初始化 /// /// public string Entity_Init() { try { //是否是空白记录. bool isBlank = DataType.IsNullOrEmpty(this.PKVal); //初始化entity. string enName = this.EnName; Entity en = null; if (DataType.IsNullOrEmpty(enName) == true) { if (DataType.IsNullOrEmpty(this.EnsName) == true) return "err@类名没有传递过来"; Entities ens = ClassFactory.GetEns(this.EnsName); en = ens.GetNewEntity; } else { en = ClassFactory.GetEn(this.EnName); } if (en == null) return "err@参数类名不正确."; //获得描述. Map map = en.EnMap; string pkVal = this.PKVal; if (isBlank == false) { en.PKVal = pkVal; en.RetrieveFromDBSources(); } //定义容器. DataSet ds = new DataSet(); //把主数据放入里面去. DataTable dtMain = en.ToDataTableField("MainTable"); ds.Tables.Add(dtMain); #region 增加 上方法. DataTable dtM = new DataTable("dtM"); dtM.Columns.Add("No"); dtM.Columns.Add("Title"); dtM.Columns.Add("Tip"); dtM.Columns.Add("Visable", System.Type.GetType("System.Boolean")); dtM.Columns.Add("Url"); dtM.Columns.Add("Target"); dtM.Columns.Add("Warning"); dtM.Columns.Add("RefMethodType"); dtM.Columns.Add("GroupName"); dtM.Columns.Add("W"); dtM.Columns.Add("H"); dtM.Columns.Add("Icon"); dtM.Columns.Add("IsCanBatch"); dtM.Columns.Add("RefAttrKey"); //判断Func是否有参数 dtM.Columns.Add("FunPara"); dtM.Columns.Add("ClassMethodName"); RefMethods rms = en.EnMapInTime.HisRefMethods; foreach (RefMethod item in rms) { item.HisEn = en; string myurl = ""; if (item.RefMethodType == RefMethodType.LinkeWinOpen || item.RefMethodType == RefMethodType.RightFrameOpen || item.RefMethodType == RefMethodType.LinkModel) { try { myurl = item.Do(null) as string; if (myurl == null) continue; } catch (Exception ex) { throw new Exception("err@系统错误:根据方法名生成url出现错误:@" + ex.Message + "@" + ex.InnerException + " @方法名:" + item.Title + " - 方法:" + item.ClassMethodName); } } else { myurl = "../RefMethod.htm?Index=" + item.Index + "&EnName=" + en.ToString() + "&EnsName=" + en.GetNewEntities.ToString() + "&PKVal=" + this.PKVal; } DataRow dr = dtM.NewRow(); dr["No"] = item.Index; dr["Title"] = item.Title; dr["Tip"] = item.ToolTip; dr["Visable"] = item.Visable; dr["Warning"] = item.Warning; dr["RefMethodType"] = (int)item.RefMethodType; dr["RefAttrKey"] = item.RefAttrKey; dr["Url"] = myurl; dr["W"] = item.Width; dr["H"] = item.Height; dr["Icon"] = item.Icon; dr["IsCanBatch"] = item.IsCanBatch; dr["GroupName"] = item.GroupName; Attrs attrs = item.HisAttrs; if (attrs.Count == 0) dr["FunPara"] = "false"; else dr["FunPara"] = "true"; dr["ClassMethodName"] = item.ClassMethodName; dtM.Rows.Add(dr); //增加到rows. } #endregion 增加 上方法. #region 加入一对多的实体编辑 AttrsOfOneVSM oneVsM = en.EnMapInTime.AttrsOfOneVSM; string sql = ""; int i = 0; if (oneVsM.Count > 0) { foreach (AttrOfOneVSM vsM in oneVsM) { string rootNo = vsM.RootNo; if (rootNo != null && rootNo.Contains("@") == true) { rootNo = rootNo.Replace("@WebUser.FK_Dept", WebUser.FK_Dept); rootNo = rootNo.Replace("@WebUser.OrgNo", WebUser.OrgNo); } //判断该dot2dot是否显示? Entity enMM = vsM.EnsOfMM.GetNewEntity; enMM.SetValByKey(vsM.AttrOfOneInMM, this.PKVal); if (enMM.HisUAC.IsView == false) continue; DataRow dr = dtM.NewRow(); dr["No"] = enMM.ToString(); // dr["GroupName"] = vsM.GroupName; if (en.PKVal != null) { //判断模式. string url = ""; if (vsM.Dot2DotModel == Dot2DotModel.TreeDept) { url = "Branches.htm?EnName=" + this.EnName + "&Dot2DotEnsName=" + vsM.EnsOfMM.ToString(); url += "&Dot2DotEnName=" + vsM.EnsOfMM.GetNewEntity.ToString(); //存储实体类. url += "&AttrOfOneInMM=" + vsM.AttrOfOneInMM; //存储表那个与主表关联. 比如: FK_Node url += "&AttrOfMInMM=" + vsM.AttrOfMInMM; //dot2dot存储表那个与实体表. 比如:FK_Station. url += "&EnsOfM=" + vsM.EnsOfM.ToString(); //默认的B实体分组依据. 比如:FK_Station. url += "&DefaultGroupAttrKey=" + vsM.DefaultGroupAttrKey; //默认的B实体分组依据. url += "&RootNo=" + rootNo; } else if (vsM.Dot2DotModel == Dot2DotModel.TreeDeptEmp) { url = "BranchesAndLeaf.htm?EnName=" + this.EnName + "&Dot2DotEnsName=" + vsM.EnsOfMM.ToString(); url += "&Dot2DotEnName=" + vsM.EnsOfMM.GetNewEntity.ToString(); //存储实体类. url += "&AttrOfOneInMM=" + vsM.AttrOfOneInMM; //存储表那个与主表关联. 比如: FK_Node url += "&AttrOfMInMM=" + vsM.AttrOfMInMM; //dot2dot存储表那个与实体表. 比如:FK_Station. url += "&EnsOfM=" + vsM.EnsOfM.ToString(); //默认的B实体分组依据. 比如:FK_Station. url += "&DefaultGroupAttrKey=" + vsM.DefaultGroupAttrKey; //默认的B实体分组依据. 比如:FK_Station. url += "&RootNo=" + rootNo; } else { url = "Dot2Dot.htm?EnName=" + this.EnName + "&Dot2DotEnsName=" + vsM.EnsOfMM.ToString(); //比如:BP.WF.Template.NodeStations url += "&AttrOfOneInMM=" + vsM.AttrOfOneInMM; //存储表那个与主表关联. 比如: FK_Node url += "&AttrOfMInMM=" + vsM.AttrOfMInMM; //dot2dot存储表那个与实体表. 比如:FK_Station. url += "&EnsOfM=" + vsM.EnsOfM.ToString(); //默认的B实体. //比如:BP.Port.Stations url += "&DefaultGroupAttrKey=" + vsM.DefaultGroupAttrKey; //默认的B实体分组依据. 比如:FK_Station. } dr["Url"] = url + "&" + en.PK + "=" + en.PKVal + "&PKVal=" + en.PKVal; dr["Icon"] = "../Img/M2M.png"; } dr["W"] = "900"; dr["H"] = "500"; dr["RefMethodType"] = (int)RefMethodType.RightFrameOpen; // 获得选择的数量. try { sql = "SELECT COUNT(*) as NUM FROM " + vsM.EnsOfMM.GetNewEntity.EnMap.PhysicsTable + " WHERE " + vsM.AttrOfOneInMM + "='" + en.PKVal + "'"; i = DBAccess.RunSQLReturnValInt(sql); } catch { sql = "SELECT COUNT(*) as NUM FROM " + vsM.EnsOfMM.GetNewEntity.EnMap.PhysicsTable + " WHERE " + vsM.AttrOfOneInMM + "=" + en.PKVal; try { i = DBAccess.RunSQLReturnValInt(sql); } catch { vsM.EnsOfMM.GetNewEntity.CheckPhysicsTable(); } } dr["Title"] = vsM.Desc + "(" + i + ")"; dr["GroupName"] = vsM.GroupName; dtM.Rows.Add(dr); } } #endregion 增加 一对多. #region 从表 EnDtls enDtls = en.EnMapInTime.Dtls; foreach (EnDtl enDtl in enDtls) { if (enDtl.DtlEditerModel == DtlEditerModel.DtlBatchEnonly || enDtl.DtlEditerModel == DtlEditerModel.DtlSearchEnonly || enDtl.DtlEditerModel == DtlEditerModel.DtlURLEnonly) continue; //判断该dtl是否要显示? Entity myEnDtl = enDtl.Ens.GetNewEntity; //获取他的en myEnDtl.SetValByKey(enDtl.RefKey, this.PKVal); //给refpk赋值. if (myEnDtl.HisUAC.IsView == false) continue; DataRow dr = dtM.NewRow(); string url = ""; if (enDtl.DtlEditerModel == DtlEditerModel.DtlBatch) url = "DtlBatch.htm?EnName=" + this.EnName + "&PK=" + this.PKVal + "&EnsName=" + enDtl.EnsName + "&RefKey=" + enDtl.RefKey + "&RefVal=" + en.PKVal.ToString() + "&MainEnsName=" + en.ToString(); else url = "DtlSearch.htm?EnName=" + this.EnName + "&PK=" + this.PKVal + "&EnsName=" + enDtl.EnsName + "&RefKey=" + enDtl.RefKey + "&RefVal=" + en.PKVal.ToString() + "&MainEnsName=" + en.ToString(); try { i = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM " + enDtl.Ens.GetNewEntity.EnMap.PhysicsTable + " WHERE " + enDtl.RefKey + "='" + en.PKVal + "'"); } catch { try { i = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM " + enDtl.Ens.GetNewEntity.EnMap.PhysicsTable + " WHERE " + enDtl.RefKey + "=" + en.PKVal); } catch { enDtl.Ens.GetNewEntity.CheckPhysicsTable(); } } dr["No"] = enDtl.EnsName; dr["Title"] = enDtl.Desc + "(" + i + ")"; dr["Url"] = url; dr["GroupName"] = enDtl.GroupName; dr["Icon"] = enDtl.Icon; dr["RefMethodType"] = (int)RefMethodType.RightFrameOpen; dtM.Rows.Add(dr); } #endregion 增加 从表. ds.Tables.Add(dtM); return BP.Tools.Json.ToJson(ds); } catch (Exception ex) { return "err@Entity_Init错误:" + ex.Message; } } #endregion 实体的操作. public string Branches_SearchByKey() { string key = this.GetRequestVal("Key"); //查询关键字. string ensOfM = this.GetRequestVal("EnsOfM"); //多的实体. Entities ensMen = ClassFactory.GetEns(ensOfM); QueryObject qo = new QueryObject(ensMen); //集合. qo.AddWhere("No", " LIKE ", "%" + key + "%"); qo.addOr(); qo.AddWhere("Name", " LIKE ", "%" + key + "%"); qo.DoQuery(); return ensMen.ToJson(); } #region 部门人员模式. public string BranchesAndLeaf_SearchByNodeID() { string dot2DotEnsName = this.GetRequestVal("Dot2DotEnsName"); string defaultGroupAttrKey = this.GetRequestVal("DefaultGroupAttrKey"); string key = this.GetRequestVal("Key"); //查询关键字. string ensOfM = this.GetRequestVal("EnsOfM"); //多的实体. //如果是部门人员信息,关联的有兼职部门. string emp1s = BP.Sys.Base.Glo.DealClassEntityName("BP.Port.Emps"); string emp2s = BP.Sys.Base.Glo.DealClassEntityName("BP.Port.Emps"); if ((ensOfM.Equals(emp1s) == true || ensOfM.Equals(emp2s) == true) && defaultGroupAttrKey.Equals("FK_Dept") == true) { string sql = "Select E." + BP.Sys.Base.Glo.UserNo + " , E.Name ,D.Name AS FK_DeptText,-1 AS TYPE From Port_DeptEmp DE, Port_Emp E,Port_Dept D Where DE.FK_Emp = E.No And DE.FK_Dept = D.No AND D.No='" + key + "'"; sql += " union "; sql += "select E." + BP.Sys.Base.Glo.UserNo + " , E.Name ,D.Name AS FK_DeptText,0 AS TYPE From Port_Emp E,Port_Dept D Where E.Fk_Dept = D.No AND D.No='" + key + "' ORDER BY TYPE DESC"; DataTable dtt = DBAccess.RunSQLReturnTable(sql); DataTable dt = dtt.Clone(); string emps = ""; foreach (DataRow drr in dtt.Rows) { if (emps.Contains(drr[0].ToString() + ",") == true) continue; emps += drr[0].ToString() + ","; DataRow dr = dt.NewRow(); dr["No"] = drr[0]; dr["Name"] = drr[1]; dr["FK_DeptText"] = drr[2]; dr["type"] = drr[3]; dt.Rows.Add(dr); } foreach (DataColumn col in dt.Columns) { string colName = col.ColumnName.ToLower(); switch (colName) { case "no": col.ColumnName = "No"; break; case "name": col.ColumnName = "Name"; break; case "fk_depttext": col.ColumnName = "FK_DeptText"; break; case "type": col.ColumnName = "TYPE"; break; default: break; } } return BP.Tools.Json.ToJson(dt); } Entities ensMen = ClassFactory.GetEns(ensOfM); QueryObject qo = new QueryObject(ensMen); //集合. qo.AddWhere(defaultGroupAttrKey, key); qo.DoQuery(); return ensMen.ToJson(); } public string BranchesAndLeaf_SearchByKey() { string dot2DotEnsName = this.GetRequestVal("Dot2DotEnsName"); string defaultGroupAttrKey = this.GetRequestVal("DefaultGroupAttrKey"); string key = this.GetRequestVal("Key"); //查询关键字. string rootno = this.GetRequestVal("RootNo"); //查询根节点. string ensOfM = this.GetRequestVal("EnsOfM"); //多的实体. Entities ensMen = ClassFactory.GetEns(ensOfM); QueryObject qo = new QueryObject(ensMen); //集合. qo.addLeftBracket(); qo.AddWhere("No", " LIKE ", "%" + key + "%"); qo.addOr(); qo.AddWhere("Name", " LIKE ", "%" + key + "%"); qo.addRightBracket(); if (SystemConfig.CCBPMRunModel != CCBPMRunModel.Single) { qo.addAnd(); qo.AddWhere("OrgNo", WebUser.OrgNo); } qo.DoQuery(); DataTable dt = ensMen.ToDataTableField(); Entity en = ensMen.GetNewEntity; string tableName = en.EnMap.PhysicsTable; if (tableName.Equals("Port_Emp") == true && dt.Columns.Contains("UserID")==true) { foreach (DataRow dr in dt.Rows) { dr["No"] = dr["UserID"]; } } return BP.Tools.Json.ToJson(dt); } public string BranchesAndLeaf_Delete() { try { string dot2DotEnName = this.GetRequestVal("Dot2DotEnName"); string AttrOfOneInMM = this.GetRequestVal("AttrOfOneInMM"); string AttrOfMInMM = this.GetRequestVal("AttrOfMInMM"); Entity mm = ClassFactory.GetEn(dot2DotEnName); mm.Delete(AttrOfOneInMM, this.PKVal, AttrOfMInMM, this.GetRequestVal("Key")); return "删除成功."; } catch (Exception ex) { return "err@" + ex.Message; } } /// /// 初始化 dt.Rows[3] error CS0103: 当前上下文中不存在名称“dt” /// /// public string BranchesAndLeaf_Init() { string dot2DotEnsName = this.GetRequestVal("Dot2DotEnsName"); string defaultGroupAttrKey = this.GetRequestVal("DefaultGroupAttrKey"); dot2DotEnsName = BP.Sys.Base.Glo.DealClassEntityName(dot2DotEnsName); //string enName = this.GetRequestVal("EnName"); Entity en = ClassFactory.GetEn(this.EnName); en.PKVal = this.PKVal; en.Retrieve(); //找到映射. AttrsOfOneVSM oneVsM = en.EnMap.AttrsOfOneVSM; AttrOfOneVSM vsM = null; foreach (AttrOfOneVSM item in oneVsM) { //if (item.Dot2DotModel != Dot2DotModel.TreeDeptEmp) // continue; //if (item.EnsOfMM.ToString().Equals(dot2DotEnsName) == false) // continue; //if (item.DefaultGroupAttrKey == null) // continue; //if (item.DefaultGroupAttrKey.Equals(dot2DotEnsName) == false) // continue; //vsM = item; //break; if (item.Dot2DotModel == Dot2DotModel.TreeDeptEmp && item.EnsOfMM.ToString().Equals(dot2DotEnsName) && item.DefaultGroupAttrKey.Equals(defaultGroupAttrKey)) { vsM = item; break; } } if (vsM == null) return "err@参数错误,没有找到VSM"; //组织数据. DataSet ds = new DataSet(); string rootNo = GetRequestVal("RootNo"); if (DataType.IsNullOrEmpty(rootNo) == true) rootNo = vsM.RootNo; if (rootNo.Equals("@WebUser.FK_Dept") || rootNo.Equals("WebUser.FK_Dept")) rootNo = WebUser.FK_Dept; if (rootNo.Equals("@WebUser.OrgNo") || rootNo.Equals("WebUser.OrgNo")) rootNo = WebUser.OrgNo; if (DataType.IsNullOrEmpty(rootNo) == true) rootNo = "0"; #region 生成树目录. string ensOfM = this.GetRequestVal("EnsOfM"); //多的实体. Entities ensMen = ClassFactory.GetEns(ensOfM); Entity enMen = ensMen.GetNewEntity; Attr attr = enMen.EnMap.GetAttrByKey(defaultGroupAttrKey); if (attr == null) return "err@在实体[" + ensOfM + "]指定的分树的属性[" + defaultGroupAttrKey + "]不存在,请确认是否删除了该属性?"; if (attr.MyFieldType == FieldType.Normal) return "err@在实体[" + ensOfM + "]指定的分树的属性[" + defaultGroupAttrKey + "]不能是普通字段,必须是外键或者枚举."; Entities trees = attr.HisFKEns; Entity tree = trees.GetNewEntity; int IsExitParentNo = 0; //是否存在ParentNo int IsExitIdx = 0; //判断改类是否存在Idx if (DBAccess.IsExitsTableCol(tree.EnMap.PhysicsTable, "Idx") == true && tree.EnMap.Attrs.Contains("Idx") == true) IsExitIdx = 1; if (DBAccess.IsExitsTableCol(tree.EnMap.PhysicsTable, "ParentNo") == true && tree.EnMap.Attrs.Contains("ParentNo") == true) IsExitParentNo = 1; if (IsExitParentNo == 1) { if (IsExitIdx == 1) { if (rootNo.Equals("0")) { Entities ens = attr.HisFKEns; ens.Retrieve("ParentNo", rootNo, "Idx"); string vals = ""; foreach (Entity item in ens) { vals += "'" + item.GetValStringByKey("No") + "'" + ","; } vals = vals + "'0'"; trees.RetrieveInOrderBy("ParentNo", vals, "Idx"); } else trees.Retrieve("No", rootNo, "Idx"); } else { if (rootNo.Equals("0")) { Entities ens = trees; ens.Retrieve("ParentNo", rootNo, "Idx"); string vals = ""; foreach (Entity item in ens) { vals += "'" + item.GetValStringByKey("No") + "'" + ","; } vals = vals + "'0'"; trees.RetrieveIn("ParentNo", vals); } else trees.Retrieve("No", rootNo); } } else { if (IsExitIdx == 1) trees.RetrieveAll("Idx"); else trees.RetrieveAll(); } DataTable dt = trees.ToDataTableField("DBTrees"); //如果没有parnetNo 列,就增加上, 有可能是分组显示使用这个模式. if (dt.Columns.Contains("ParentNo") == false) { dt.Columns.Add("ParentNo"); foreach (DataRow dr in dt.Rows) dr["ParentNo"] = rootNo; } ds.Tables.Add(dt); dt = new DataTable(); dt.TableName = "Base_Info"; dt.Columns.Add("IsExitParentNo", typeof(int)); dt.Columns.Add("ExtShowCols", typeof(string)); DataRow drr = dt.NewRow(); drr["IsExitParentNo"] = IsExitParentNo; drr["ExtShowCols"] = vsM.ExtShowCols; dt.Rows.Add(drr); ds.Tables.Add(dt); #endregion 生成树目录. #region 生成选择的数据. bool saveType = this.GetRequestValBoolen("SaveType"); Entities dot2Dots = ClassFactory.GetEns(dot2DotEnsName); DataTable dtSelected = null; Entity dot2Dot = dot2Dots.GetNewEntity; //选择的值保存在一个字段中 string para = this.GetRequestVal("Para"); string paraVal = this.GetRequestVal("ParaVal"); string para1 = this.GetRequestVal("Para1"); string paraVal1 = this.GetRequestVal("ParaVal1"); string pkval = this.PKVal; //是SAAS版并且Dot2DotEnName含有FK_Emp字段 bool isHaveSAASEmp = BP.Difference.SystemConfig.CCBPMRunModel == CCBPMRunModel.SAAS && dot2Dot.EnMap.Attrs.Contains("FK_Emp") == true ? true : false; if (isHaveSAASEmp == true) { string sql = "SELECT A.*,B.Name AS FK_EmpText FROM " + dot2Dot.EnMap.PhysicsTable + " A,Port_Emp B WHERE A.FK_Emp=B.UserID AND B.OrgNo='" + WebUser.OrgNo + "'"; if (saveType == true) { if (DataType.IsNullOrEmpty(para) == true) sql += " AND " + vsM.AttrOfOneInMM + "='" + this.PKVal + "'"; if (DataType.IsNullOrEmpty(para1) == true) { pkval = pkval.Replace("_" + paraVal, ""); sql += " AND " + vsM.AttrOfOneInMM + "='" + pkval + "' AND " + para + "='" + paraVal + "'"; } else if (DataType.IsNullOrEmpty(para) == false && DataType.IsNullOrEmpty(para1) == false) { pkval = pkval.Replace("_" + paraVal, ""); sql += " AND " + vsM.AttrOfOneInMM + "='" + pkval + "' AND " + para + "='" + paraVal + "' AND " + para1 + "='" + paraVal1 + "'"; } } else { sql += " AND " + vsM.AttrOfOneInMM + "='" + this.PKVal + "'"; } dtSelected = DBAccess.RunSQLReturnTable(sql); dtSelected.TableName = "DBMMs"; } else { if (saveType == true) { if (DataType.IsNullOrEmpty(para) == true) dot2Dots.Retrieve(vsM.AttrOfOneInMM, this.PKVal); else if (DataType.IsNullOrEmpty(para1) == true) { pkval = pkval.Replace("_" + paraVal, ""); dot2Dots.Retrieve(vsM.AttrOfOneInMM, pkval, para, paraVal); } else if (DataType.IsNullOrEmpty(para) == false && DataType.IsNullOrEmpty(para1) == false) { pkval = pkval.Replace("_" + paraVal, ""); dot2Dots.Retrieve(vsM.AttrOfOneInMM, pkval, para, paraVal, para1, paraVal1); } } else { dot2Dots.Retrieve(vsM.AttrOfOneInMM, this.PKVal); } dtSelected = dot2Dots.ToDataTableField("DBMMs"); } string attrOfMInMM = this.GetRequestVal("AttrOfMInMM"); string AttrOfOneInMM = this.GetRequestVal("AttrOfOneInMM"); dtSelected.Columns[attrOfMInMM].ColumnName = "No"; if (dtSelected.Columns.Contains(attrOfMInMM + "Text") == false && saveType == false) return "err@MM实体类字段属性需要按照外键属性编写:" + dot2DotEnsName + " - " + attrOfMInMM; if (saveType == false) dtSelected.Columns[attrOfMInMM + "Text"].ColumnName = "Name"; if (DataType.IsNullOrEmpty(vsM.ExtShowCols) == false && vsM.ExtShowCols.Contains("@" + defaultGroupAttrKey + "=") == true) { if (dtSelected.Columns.Contains(defaultGroupAttrKey + "Text") == false) { dtSelected.Columns.Add(defaultGroupAttrKey + "Text", typeof(string)); } foreach (DataRow dr in dtSelected.Rows) { enMen.PKVal = dr["No"].ToString(); if (isHaveSAASEmp == true) enMen.PKVal = WebUser.OrgNo + "_" + enMen.PKVal; enMen.RetrieveFromDBSources(); dr[defaultGroupAttrKey + "Text"] = enMen.Row[defaultGroupAttrKey + "Text"]; } } dtSelected.Columns.Remove(AttrOfOneInMM); ds.Tables.Add(dtSelected); //已经选择的数据. #endregion 生成选择的数据. return BP.Tools.Json.ToJson(ds); } public string BranchesAndLeaf_GetTreesByParentNo() { string rootNo = GetRequestVal("RootNo"); if (DataType.IsNullOrEmpty(rootNo)) rootNo = "0"; string defaultGroupAttrKey = this.GetRequestVal("DefaultGroupAttrKey"); string ensOfM = this.GetRequestVal("EnsOfM"); //多的实体. Entities ensMen = ClassFactory.GetEns(ensOfM); Entity enMen = ensMen.GetNewEntity; Attr attr = enMen.EnMap.GetAttrByKey(defaultGroupAttrKey); if (attr == null) return "err@在实体[" + ensOfM + "]指定的分树的属性[" + defaultGroupAttrKey + "]不存在,请确认是否删除了该属性?"; if (attr.MyFieldType == FieldType.Normal) return "err@在实体[" + ensOfM + "]指定的分树的属性[" + defaultGroupAttrKey + "]不能是普通字段,必须是外键或者枚举."; Entities trees = attr.HisFKEns; //判断改类是否存在Idx Entity tree = trees.GetNewEntity; if (DBAccess.IsExitsTableCol(tree.EnMap.PhysicsTable, "Idx") == true && tree.EnMap.Attrs.Contains("Idx") == true) trees.Retrieve("ParentNo", rootNo, "Idx"); else trees.Retrieve("ParentNo", rootNo); DataTable dt = trees.ToDataTableField("DBTrees"); //如果没有parnetNo 列,就增加上, 有可能是分组显示使用这个模式. if (dt.Columns.Contains("ParentNo") == false) { dt.Columns.Add("ParentNo"); foreach (DataRow dr in dt.Rows) dr["ParentNo"] = rootNo; } return BP.Tools.Json.ToJson(dt); ; } #endregion 部门人员模式. #region 分组数据. /// /// 执行保存 /// /// public string Dot2Dot_Save() { try { string eles = this.GetRequestVal("ElesAAA"); //实体集合. string dot2DotEnsName = this.GetRequestVal("Dot2DotEnsName"); string attrOfOneInMM = this.GetRequestVal("AttrOfOneInMM"); string attrOfMInMM = this.GetRequestVal("AttrOfMInMM"); bool saveType = this.GetRequestValBoolen("SaveType"); //获得点对点的实体. Entity en = ClassFactory.GetEns(dot2DotEnsName).GetNewEntity; if (saveType == true) { //选择的值保存在一个字段中 string para = this.GetRequestVal("Para"); string paraVal = this.GetRequestVal("ParaVal"); string para1 = this.GetRequestVal("Para1"); string paraVal1 = this.GetRequestVal("ParaVal1"); //首先删除. if (DataType.IsNullOrEmpty(para) == true) en.Delete(attrOfOneInMM, this.PKVal); else if (DataType.IsNullOrEmpty(para1) == true) en.Delete(attrOfOneInMM, this.PKVal, para, paraVal); else if (DataType.IsNullOrEmpty(para) == false && DataType.IsNullOrEmpty(para1) == false) en.Delete(attrOfOneInMM, this.PKVal, para, paraVal, para1, paraVal1); if (DataType.IsNullOrEmpty(eles) == true) return "没有选择值"; en.SetValByKey(attrOfOneInMM, this.PKVal); en.SetValByKey(attrOfMInMM, eles); if (en.Row.ContainsKey(para)) en.SetValByKey(para, paraVal); if (en.Row.ContainsKey(para1)) en.SetValByKey(para1, paraVal1); en.Insert(); return "数据保存成功."; } en.Delete(attrOfOneInMM, this.PKVal); string[] strs = eles.Split(','); foreach (string str in strs) { if (DataType.IsNullOrEmpty(str) == true) continue; en.SetValByKey(attrOfOneInMM, this.PKVal); en.SetValByKey(attrOfMInMM, str); en.Insert(); } return "数据保存成功."; } catch (Exception ex) { return "err@" + ex.Message; } } /// /// 获得分组的数据源 /// /// public string Dot2Dot_GenerGroupEntitis() { string key = this.GetRequestVal("DefaultGroupAttrKey"); //实体集合. string ensName = this.GetRequestVal("EnsOfM"); Entities ens = ClassFactory.GetEns(ensName); Entity en = ens.GetNewEntity; Attrs attrs = en.EnMap.Attrs; Attr attr = attrs.GetAttrByKey(key); if (attr == null) return "err@设置的分组外键错误[" + key + "],不存在[" + ensName + "]或者已经被删除."; if (attr.MyFieldType == FieldType.Normal && attr.UIContralType != UIContralType.DDL) return "err@设置的默认分组[" + key + "]不能是普通字段."; if (attr.MyFieldType == FieldType.FK) { Entities ensFK = attr.HisFKEns; ensFK.Clear(); ensFK.RetrieveAll(); return ensFK.ToJson(); } if (attr.UIContralType == UIContralType.DDL && DataType.IsNullOrEmpty(attr.UIBindKey) == false && attr.UIBindKey.ToUpper().StartsWith("SELECT")) { String sqlBindKey = Glo.DealExp(attr.UIBindKey, en, null); DataTable dt = DBAccess.RunSQLReturnTable(sqlBindKey); if (SystemConfig.AppCenterDBFieldCaseModel == FieldCaseModel.UpperCase) { dt.Columns["NO"].ColumnName = "No"; dt.Columns["NAME"].ColumnName = "Name"; } if (SystemConfig.AppCenterDBFieldCaseModel == FieldCaseModel.Lowercase) { dt.Columns["NO"].ColumnName = "No"; dt.Columns["NAME"].ColumnName = "Name"; } return BP.Tools.Json.ToJson(dt); } if (attr.MyFieldType == FieldType.Enum) { /* 如果是枚举 */ SysEnums ses = new SysEnums(); ses.Retrieve(SysEnumAttr.IntKey, attr.UIBindKey); } return "err@设置的默认分组[" + key + "]不能是普通字段."; } #endregion 分组数据. } }