using Apache.NMS.ActiveMQ.Commands; using Aspose.Words.Lists; using Microsoft.SqlServer.Dts.Runtime; using Model; using Newtonsoft.Json; using Newtonsoft.Json.Linq; using Org.BouncyCastle.Ocsp; using SgManager.AI; using System; using System.Collections; using System.Collections.Generic; using System.Globalization; using System.IO; using System.Linq; using System.Net; using System.Security.Cryptography; using System.Security.Policy; using System.ServiceModel.Channels; using System.Text; namespace BLL { /// /// IDP平台接口服务 /// public static class IDPDataService { /// /// 测试环境api地址 /// private static readonly string IDPApiUrl = "http://10.5.6.151:8100/"; ///// ///// 正式环境api地址 ///// //private static readonly string IDPApiUrl = "https://idp.cwcec.com/"; //private static readonly string IDPApiUrl = SysConstSetService.WuHuanIDPPath; #region 接口授权认证 /// /// 加密公钥 /// private static readonly string publicKey = "g1sk7Xtc1TJouHdY4+FAe5atGCu2n17NhoKVDV57pki1IL+9+S7BY4gxAjmMkUU2/cbCCdbPoUJLBrCBCjX7yI3UJW6FZwQWkn3kVoeulLEwdPCIq/GUjMXaWf3Iaaad5wBUFbfXAzv15VN6z48Nt1IY/O8YEzhIpuZdtEgDdos=AQAB"; //private static readonly string publicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQChnc2YD0YzJPx6QTh+/n7XzjR1ugFzrsmPolJhpCfWMKrSGbT7iX/Kgcm1AI+T95K4Jzv3KS42QTecZ1ziJ4Rr9Luzw+9ZCSjMZgrmAUbY5IeBaA6GzaSk8UWHZ4n5PL+GUGq+2f+COL7+KCS2AxEpaqDZVrJrIfg/UektdgNyzwIDAQAB"; /// /// 第三方加密认证接口 /// /// 五环IDP系统SessionId有效期30分钟 /// public static SessionItem GetAuthenticationSession() { SessionItem session = new SessionItem(); try { //// 创建RSA加密服务提供者 ////using (RSA rsa = RSA.Create()) //using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider()) //{ //// 获取公钥false表示只导出公钥 //string publicKey = rsa.ToXmlString(false); //// 获取私钥true表示导出公钥和私钥 //string privateKey = rsa.ToXmlString(true); ////用户名加密 //string encryptedUsername = EncryptData("dataviewer", publicKey); ////密码加密 //string encryptedPassword = EncryptData("a3365$!", publicKey); //用户名加密后的密文 string encryptedUsername = "k0N0tx/hfRPY0v2lq1G8eH6hCO+UiMqlSZi1PD6bhGf4YpP/koJq5hfMsDSzdn3dZjzExrwyrjFWp/1jZLde0+gRbQ0D7tzm0R5D6AmriodD2cJvrEiwtDy7SeGNloSaNmpTEMuycpuueiOeGhMkKnTwWfRkEw73lxEpTmaahq4="; //密码加密后的密文 string encryptedPassword = "HLLroiNJJzyTWJt9td1xgChbVzyQkoxWCGGXqdwI2cvlUF/A30FAPaInszSwEhNRQlJZZ01EODElemkgv36DMF+XGwfDi0BfIq9jKG+/+wq0TVOHNhiu2NPzpn5Ji2X3yXIXpH1zv6XEtkvx/qiLToZYfRQCufsl5vH1cZxk2fQ="; string url = $"{IDPApiUrl}UAMS/authEncrypt"; //string url = $"http://10.5.6.151:8100/UAMS/authEncrypt"; string contenttype = "application/json;charset=utf-8"; var body = new { encryptedUsername = encryptedUsername, encryptedPassword = encryptedPassword }; string pushContent = JsonConvert.SerializeObject(body); string strJosn = APIGetHttpService.Http(url, "POST", contenttype, null, pushContent); //string strJosn = HttpHelper.Post(url, null, pushContent); JObject obj = JObject.Parse(strJosn); if (!string.IsNullOrEmpty(strJosn)) { string value = obj["value"].ToString(); string name = obj["name"].ToString(); session.value = value; session.name = name; } //} } catch (WebException ex) { return null; } finally { } return session; } /// /// 加密字符串 /// /// 加密信息 /// 公钥 /// public static string EncryptData(string data, string publicKey) { using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider()) { string result = string.Empty; try { rsa.FromXmlString(publicKey); //从字符串加载公钥 byte[] dataBytes = Encoding.UTF8.GetBytes(data); byte[] encryptedBytes = rsa.Encrypt(dataBytes, false); //使用公钥加密数据,false表示使用OAEP填充方式 result = Convert.ToBase64String(encryptedBytes); //返回Base64编码的加密数据 } catch (Exception ex) { Console.WriteLine("Error encrypting: {0}", ex.Message); } return result; } } #endregion #region 质量管理设计图纸 #region IDP /// /// 质量管理设计图纸 /// /// 项目Id /// 获取指定日期之后到现在的异动数据 public static void GetIDPProjectDesignDrawingData(string projectId = "", string startDate = "") { try { //五环主数据项目Code string projectCode = string.Empty; if (!string.IsNullOrWhiteSpace(projectId)) {//根据施工平台项目Id获取主数据项目Code var getPro = ProjectService.GetProjectByProjectId(projectId); projectCode = getPro.ProjectCode; } string timeStampStr = string.Empty; if (!string.IsNullOrWhiteSpace(startDate)) { string format = "yyyy-MM-dd"; DateTimeOffset dateTimeOffset = DateTimeOffset.ParseExact(startDate, format, CultureInfo.InvariantCulture); long timeStamp = Funs.GetDateTimeStamp(dateTimeOffset, 13); timeStampStr = timeStamp.ToString(); } var session = GetAuthenticationSession(); //ErrLogInfo.WriteLog($"【Session】name:{session.name};value:{session.value}"); Hashtable newToken = new Hashtable { { "Cookie", $"{session.name}={session.value}" } }; List listAdd = new List(); List listModify = new List(); int pageSize = 1000;//一次性最多返回1000条数据 int maxPageNum = 100; List idpFileIds = DesignDrawingService.GetIDPDesignDrawingFileId(); List idpFiles = DesignDrawingService.GetIDPDesignDrawingFile(); for (int pageNum = 1; pageNum < 100000; pageNum++) { if (pageNum > maxPageNum) { break; } string url = $"{IDPApiUrl}EDC/third/workitems?pageNum={pageNum}&pageSize={pageSize}"; if (!string.IsNullOrWhiteSpace(timeStampStr)) { url = $"{url}&lastTimestamp={timeStampStr}"; } if (!string.IsNullOrWhiteSpace(projectCode)) { url = $"{url}&projectCode={projectCode}"; } var returndata = BLL.APIGetHttpService.OutsideHttp(url, "GET", null, newToken, null); if (!string.IsNullOrEmpty(returndata)) { IDPDesignDrawingResponseData responseData = IDPDesignDrawingResponseData.FromJson(returndata); maxPageNum = responseData.page.pages; foreach (var item in responseData.page.results) { IDP_DesignDrawing newItem = new IDP_DesignDrawing(); if (!string.IsNullOrWhiteSpace(projectId)) { newItem.ProjectId = projectId; } else { if (string.IsNullOrWhiteSpace(item.projectCode)) { continue; } var getProject = ProjectService.GetProjectByProjectCode(item.projectCode); if (getProject == null) { continue; } newItem.ProjectId = getProject.ProjectId; } newItem.IdpfileId = item.fileId; newItem.StockId = item.stockId; newItem.ThirdId = item.thirdId; newItem.ProjectCode = item.projectCode; newItem.DisplayProjectName = item.displayProjectName; newItem.ProjectDeviceProcedureSubjectCode = item.projectDeviceProcedureSubjectCode; newItem.WbsFullPath = item.wbsFullPath; newItem.FormatFileName = item.formatFileName; newItem.FileVersion = item.fileVersion; newItem.MajorNo = item.majorNo; newItem.MajorName = item.majorName; newItem.Status = item.status; newItem.DesignUserName = item.designUserName; newItem.JiaoheUserName = item.jiaoheUserName; newItem.ShenheUserName = item.shenheUserName; newItem.ShendingUserName = item.shendingUserName; newItem.MajorResponsibleUserName = item.majorResponsibleUserName; newItem.ClassificationLevelInProject = item.classificationLevelInProject; newItem.UpdateTime = item.updateTime; newItem.Remark = item.remark; if (!string.IsNullOrWhiteSpace(item.fileId) && idpFileIds.Contains(item.fileId)) {//编辑 newItem.Id = idpFiles.Where(x => x.IdpfileId == item.fileId).FirstOrDefault().Id; listModify.Add(newItem); } else {//新增 newItem.Id = SQLHelper.GetNewID(typeof(IDP_DesignDrawing)); listAdd.Add(newItem); } } } else { break; } } if (listAdd.Any()) { AddIDP_DesignDrawing(listAdd); } if (listModify.Any()) { ModifyIDP_DesignDrawing(listModify); } } catch (WebException ex) { } } /// /// 批量插入数据 /// /// public static void AddIDP_DesignDrawing(List list) { Model.SGGLDB db = Funs.DB; db.IDP_DesignDrawing.InsertAllOnSubmit(list); db.SubmitChanges(); } /// /// 更新数据 /// /// public static void ModifyIDP_DesignDrawing(List list) { Model.SGGLDB db = Funs.DB; foreach (var obj in list) { IDP_DesignDrawing newItem = db.IDP_DesignDrawing.FirstOrDefault(x => x.Id == obj.Id); if (newItem != null) { newItem.StockId = obj.StockId; newItem.ThirdId = obj.ThirdId; newItem.ProjectId = obj.ProjectId; newItem.ProjectCode = obj.ProjectCode; newItem.DisplayProjectName = obj.DisplayProjectName; newItem.ProjectDeviceProcedureSubjectCode = obj.ProjectDeviceProcedureSubjectCode; newItem.WbsFullPath = obj.WbsFullPath; newItem.FormatFileName = obj.FormatFileName; newItem.FileVersion = obj.FileVersion; newItem.MajorNo = obj.MajorNo; newItem.MajorName = obj.MajorName; newItem.Status = obj.Status; newItem.DesignUserName = obj.DesignUserName; newItem.JiaoheUserName = obj.JiaoheUserName; newItem.ShenheUserName = obj.ShenheUserName; newItem.ShendingUserName = obj.ShendingUserName; newItem.MajorResponsibleUserName = obj.MajorResponsibleUserName; newItem.ClassificationLevelInProject = obj.ClassificationLevelInProject; newItem.UpdateTime = obj.UpdateTime; newItem.Remark = obj.Remark; db.SubmitChanges(); } } } #endregion #region 数字档案馆 /// /// 接收保存数据 /// /// public static string SaveDesignDrawingData(List items) { try { string message = string.Empty; int succ = 0; int err = 0; using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString)) { foreach (var item in items) { if (!string.IsNullOrWhiteSpace(item.RdpId) && !string.IsNullOrWhiteSpace(item.fileid)) { IDP_DesignDrawing newItem = db.IDP_DesignDrawing.FirstOrDefault(x => x.StockId == item.RdpId && x.ThirdId == item.fileid); if (newItem != null) { newItem.RdpId = item.RdpId; newItem.Fileid = item.fileid; newItem.Upfileid = item.upfileid; newItem.Maintitle = item.maintitle; newItem.Doc_no = item.doc_no; newItem.Bc = item.bc; newItem.Archnumber = item.archnumber; newItem.Sendtime = item.sendtime; newItem.Printtime = item.printtime; newItem.Ifmail = item.ifmail; db.SubmitChanges(); succ++; } else { err++; } } else { err++; } } message = $"总数{(succ + err)}条;失败{err}条,成功{succ}条!"; } return message; } catch (WebException ex) { return ex.Message; } } #endregion #endregion #region 试车工作包 /// /// 获取工作包结构化数据 /// public static void GetIDPProjectMasterData() { string projectId = string.Empty;//五环主数据项目Id string wbsCode = string.Empty;//五环主数据wbs编码 string workitemCode = string.Empty;//五环主数据文件类别码 //https://idp.cwcec.com/OSS/projects/9100168/wbs/000000/workitems/CP2100/objects/latest //string url = $"{IDPApiUrl}/OSS/projects/{projectId}/wbs/{wbsCode}/workitems/{workitemCode}/objects/latest"; string url = $"{IDPApiUrl}/OSS/projects/9100168/wbs/000000/workitems/CP2100/objects/latest"; //测试环境接口地址 var testApiUrl = "http://10.5.6.151:8100/OSS/projects/9100168/wbs/000000/workitems/CP2100/objects/latest"; try { var session = GetAuthenticationSession(); ErrLogInfo.WriteLog($"Session——name:{session.name};value:{session.value}"); Hashtable newToken = new Hashtable { { session.name, session.value } }; var returndata = BLL.APIGetHttpService.OutsideHttp(url, "GET", null, newToken, null); } catch (WebException ex) { } finally { } } //public static void AddPMP_Project(List newtables) //{ // Model.SGGLDB db = Funs.DB; // db.PMP_Project.InsertAllOnSubmit(newtables); // db.SubmitChanges(); //} //public static void DeleteAllPMP_Project() //{ // Model.SGGLDB db = Funs.DB; // if (db.PMP_Project.FirstOrDefault() != null) // { // db.PMP_Project.DeleteAllOnSubmit(db.PMP_Project); // db.SubmitChanges(); // } //} #endregion } public class SessionItem { /// /// value /// public string value { get; set; } /// /// name /// public string name { get; set; } } }