using MES.Service.Models;
|
using NewPdaSqlServer.DB;
|
using NewPdaSqlServer.util;
|
using Newtonsoft.Json;
|
using Newtonsoft.Json.Linq;
|
using System.Collections;
|
using System.Data;
|
using System.Net;
|
using System.Net.Http.Headers;
|
using System.Text;
|
using System.Data.SqlClient;
|
using System.Data;
|
using static NewPdaSqlServer.Controllers.Warehouse.MesXkyController;
|
|
namespace NewPdaSqlServer.service.QC;
|
|
public class MesXkyService : RepositoryNoEntity
|
{
|
/// <summary>
|
/// 系统自动日志模板(用于携客云接口调用记录)
|
/// </summary>
|
private string _logMessageDHD = "";
|
|
/// <summary>
|
/// 系统自动日志模板(用于携客云接口调用记录)
|
/// </summary>
|
private string _logMessageDhdDetail = "";
|
|
/// <summary>
|
/// 系统自动日志模板(用于携客云接口调用记录)
|
/// </summary>
|
private string _logMessageDhdBar = "";
|
|
//获取携客云到货单
|
public dynamic GetXkyDhd(XKYGetDhdRequest entity)
|
{
|
_logMessageDHD = "【SysAuto】获取携客云送货单。";
|
/// <summary>
|
/// 请求报文缓存(存储序列化后的JSON请求内容)
|
/// </summary>
|
string _requestJson = string.Empty;
|
|
/// <summary>
|
/// 动态响应对象(存储反序列化的携客云接口响应)
|
/// </summary>
|
dynamic _responseData = new System.Dynamic.ExpandoObject();
|
|
/// <summary>
|
/// 接口执行时间戳(格式:yyyy-MM-dd HH:mm:ss)
|
/// </summary>
|
string _executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
|
/// <summary>
|
/// 接口调用状态(0-失败 1-成功)
|
/// </summary>
|
int sendStatus = 0;
|
|
try
|
{
|
string ErrorMsg = "";
|
ApiCommonParam Apiparam = ApiCommonParam.NewApiCommon();
|
|
_executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
//string data_inserted = "{\r\n \"startDate\": 1746759300000,\r\n \"endDate\": 1746762300000,\r\n \"erpCode\": \"GXF001\"\r\n}";
|
string sendJson = JsonConvert.SerializeObject(entity);
|
ArrayList SQLStringList = new ArrayList();
|
// var client = new HttpClient();
|
var url = "https://openapi.xiekeyun.com/delivery/getNoList.json";
|
HttpClient httpClient = new HttpClient();
|
httpClient.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
|
|
_requestJson = "{\"commonParam\":" + JsonConvert.SerializeObject(Apiparam) + ",\"body\":" + sendJson + "}";
|
byte[] postData = Encoding.UTF8.GetBytes(_requestJson);
|
|
// 创建请求对象
|
HttpWebRequest request = (HttpWebRequest)WebRequest.Create("https://openapi.xiekeyun.com/delivery/getNoList.json");
|
request.Method = "POST";
|
request.ContentType = "application/json";
|
request.ContentLength = postData.Length;
|
|
// 发送请求数据
|
using (Stream stream = request.GetRequestStream())
|
{
|
stream.Write(postData, 0, postData.Length);
|
}
|
|
// 发送请求并获取响应
|
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
|
using (Stream stream = response.GetResponseStream())
|
using (StreamReader reader = new StreamReader(stream))
|
{
|
string result2 = reader.ReadToEnd();
|
|
_responseData = JsonConvert.DeserializeObject(result2);
|
}
|
|
if (_responseData.result != 1)
|
throw new ApplicationException(_responseData.errorMsg);
|
|
sendStatus = _responseData.result;
|
//储存送货单号详细
|
if (SaveDeliveryNotice(_responseData) > 0)
|
sendStatus = 1;
|
else
|
sendStatus = 0;
|
|
var logService = new LogService();
|
logService.CreateLogI(
|
db: Db,
|
edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
|
abtGuid: null,
|
abtTable: "DELIVERY_NOTICE",
|
detail: _logMessageDHD,
|
orderNo: "",
|
sendJson: _requestJson,
|
rtnJson: JsonConvert.SerializeObject(_responseData),
|
xkyBeginTime: (entity.startDate / 1000).ToString(),
|
xkyEndTime: (entity.endDate / 1000).ToString(),
|
sendStatus: sendStatus,
|
executeTime: _executeTimestamp
|
);
|
|
return _responseData;
|
}
|
catch (Exception e)
|
{
|
var logService = new LogService();
|
logService.CreateLogI(
|
db: Db,
|
edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
|
abtGuid: null,
|
abtTable: "DELIVERY_NOTICE",
|
detail: _logMessageDHD+ $"系统异常错误:{e.Message}\n跟踪:{e.StackTrace}",
|
orderNo: "",
|
sendJson: _requestJson,
|
rtnJson: JsonConvert.SerializeObject(_responseData),
|
xkyBeginTime: (entity.startDate / 1000).ToString(),
|
xkyEndTime: (entity.endDate / 1000).ToString(),
|
sendStatus: 0,
|
executeTime: _executeTimestamp
|
);
|
throw new Exception(e.Message);
|
}
|
|
}
|
|
//对获取到的携客云送货单做处理
|
private int SaveDeliveryNotice(dynamic responseJson)
|
{
|
var result = 1;
|
List<DeliveryNotice> noticeList = JsonConvert.DeserializeObject<List<DeliveryNotice>>(responseJson.dataList.ToString());
|
|
// 新增列表空值检查
|
if (noticeList == null || !noticeList.Any() || noticeList.Count < 1)
|
{
|
_logMessageDhdBar += $"本次获取收货单数据为空";
|
return result;
|
}
|
|
|
noticeList.ForEach(n => n.Id = Guid.NewGuid());
|
|
var deliveryNos = noticeList.Select(n => n.DeliveryNo).Distinct().ToList();
|
//var noticeIds = noticeList.Select(n => n.Id).ToList(); // 保持GUID类型
|
|
Db.Ado.UseTran(() =>
|
{
|
// 添加空值检查
|
if (deliveryNos.Any())
|
{
|
// 删除关联送货明细数据
|
Db.Deleteable<DeliveryNoticeDetail>()
|
.Where(d => deliveryNos.Contains(d.DeliveryNo))
|
.ExecuteCommand();
|
|
|
//删除关联送货条码明细
|
Db.Deleteable<TblBarcodeInformation>()
|
.Where(b => deliveryNos.Contains(b.DeliveryNo))
|
.ExecuteCommand();
|
|
//删除送货单
|
Db.Deleteable<DeliveryNotice>()
|
.Where(n => deliveryNos.Contains(n.DeliveryNo))
|
.ExecuteCommand();
|
}
|
|
// 批量插入优化
|
result = Db.Fastest<DeliveryNotice>().BulkCopy(noticeList);
|
},
|
ex => {
|
// 增强异常信息
|
//_logMessageDHD = _logMessageDHD + $"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}";
|
throw new Exception($"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}");
|
});
|
|
return result;
|
}
|
|
//获取携客云到货单明细
|
public dynamic GetXkyDhdDetail(XKYGetDhdDeatilRequest entity)
|
{
|
_logMessageDhdDetail = "【SysAuto】获取携客云送货单明细。";
|
/// <summary>
|
/// 请求报文缓存(存储序列化后的JSON请求内容)
|
/// </summary>
|
string _requestJson = string.Empty;
|
|
/// <summary>
|
/// 动态响应对象(存储反序列化的携客云接口响应)
|
/// </summary>
|
dynamic _responseData = new System.Dynamic.ExpandoObject();
|
|
/// <summary>
|
/// 接口执行时间(格式:yyyy-MM-dd HH:mm:ss)
|
/// </summary>
|
string _executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
|
/// <summary>
|
/// 接口调用状态(0-失败 1-成功)
|
/// </summary>
|
int sendStatus = 0;
|
|
try
|
{
|
string ErrorMsg = "";
|
ApiCommonParam Apiparam = ApiCommonParam.NewApiCommon();
|
|
_executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
string sendJson = JsonConvert.SerializeObject(entity);
|
ArrayList SQLStringList = new ArrayList();
|
var url = "https://openapi.xiekeyun.com/delivery/getDetail.json";
|
HttpClient httpClient = new HttpClient();
|
httpClient.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
|
|
_requestJson = "{\"commonParam\":" + JsonConvert.SerializeObject(Apiparam) + ",\"body\":" + sendJson + "}";
|
byte[] postData = Encoding.UTF8.GetBytes(_requestJson);
|
|
// 创建请求对象
|
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
|
request.Method = "POST";
|
request.ContentType = "application/json";
|
request.ContentLength = postData.Length;
|
|
// 发送请求数据
|
using (Stream stream = request.GetRequestStream())
|
{
|
stream.Write(postData, 0, postData.Length);
|
}
|
|
// 发送请求并获取响应
|
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
|
using (Stream stream = response.GetResponseStream())
|
using (StreamReader reader = new StreamReader(stream))
|
{
|
string result2 = reader.ReadToEnd();
|
|
_responseData = JsonConvert.DeserializeObject(result2);
|
}
|
|
if (_responseData.result != 1)
|
throw new ApplicationException(_responseData.errorMsg);
|
|
sendStatus = _responseData.result;
|
// 对数据做处理存入mes
|
if (SaveDeliveryNoticeDetail(_responseData, entity.deliveryNo) > 0)
|
sendStatus = 1;
|
else
|
sendStatus = 0;
|
|
var logService = new LogService();
|
logService.CreateLogI(
|
db: Db,
|
edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
|
abtGuid: null,
|
abtTable: "DELIVERY_NOTICE_DETAIL",
|
detail: _logMessageDhdDetail,
|
orderNo: "",
|
sendJson: _requestJson,
|
rtnJson: JsonConvert.SerializeObject(_responseData),
|
xkyBeginTime: "",
|
xkyEndTime: "",
|
sendStatus: sendStatus,
|
executeTime: _executeTimestamp
|
);
|
|
return _responseData;
|
}
|
catch (Exception e)
|
{
|
var logService = new LogService();
|
logService.CreateLogI(
|
db: Db,
|
edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
|
abtGuid: null,
|
abtTable: "DELIVERY_NOTICE_DETAIL",
|
detail: _logMessageDhdDetail + $"系统异常错误:{e.Message}\n跟踪:{e.StackTrace}",
|
orderNo: "",
|
sendJson: _requestJson,
|
rtnJson: JsonConvert.SerializeObject(_responseData),
|
xkyBeginTime: "",
|
xkyEndTime: "",
|
sendStatus: 0,
|
executeTime: _executeTimestamp
|
);
|
throw new Exception(e.Message);
|
}
|
|
}
|
|
//对获取到的携客云送货单做处理
|
private int SaveDeliveryNoticeDetail(dynamic responseJson,string deliveryNo)
|
{
|
var result = 1;
|
List<DeliveryNoticeDetail> noticeList = JsonConvert.DeserializeObject<List<DeliveryNoticeDetail>>(responseJson.data.lineList.ToString());
|
|
// 新增列表空值检查
|
if (noticeList == null || !noticeList.Any() || noticeList.Count < 1)
|
{
|
_logMessageDhdBar += $"送货明细数据为空,送货单号:{deliveryNo}";
|
return result;
|
}
|
|
|
// 获取送货单号并校验
|
var deliveryNoObj = responseJson.data.deliveryNo;
|
if (deliveryNoObj == null || string.IsNullOrEmpty(deliveryNoObj.ToString()))
|
{
|
throw new Exception($"【异常】获取送货单失败:{responseJson}");
|
}
|
deliveryNo = deliveryNoObj.ToString();
|
|
//赋值guid和到货单号
|
noticeList.ForEach(n => n.Id = Guid.NewGuid());
|
noticeList.ForEach(n => n.DeliveryNo = deliveryNo);
|
noticeList.ForEach(n => n.SynchronousDate = DateTime.Now);
|
|
|
Db.Ado.UseTran(() =>
|
{
|
// 删除关联送货明细数据
|
Db.Deleteable<DeliveryNoticeDetail>()
|
.Where(d => d.DeliveryNo == deliveryNo)
|
.ExecuteCommand();
|
|
// 批量插入优化
|
result = Db.Fastest<DeliveryNoticeDetail>().BulkCopy(noticeList);
|
},
|
ex => {
|
// 增强异常信息
|
//_logMessageDhdDetail = _logMessageDhdDetail + $"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}";
|
throw new Exception($"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}");
|
});
|
|
return result;
|
}
|
|
//获取携客云到货单条码
|
public dynamic GetXkyDhdBar(XKYGetDhdDeatilRequest entity)
|
{
|
_logMessageDhdBar = "【SysAuto】获取携客云送货单条码。";
|
/// <summary>
|
/// 请求报文缓存(存储序列化后的JSON请求内容)
|
/// </summary>
|
string _requestJson = string.Empty;
|
|
/// <summary>
|
/// 动态响应对象(存储反序列化的携客云接口响应)
|
/// </summary>
|
dynamic _responseData = new System.Dynamic.ExpandoObject();
|
|
/// <summary>
|
/// 接口执行时间(格式:yyyy-MM-dd HH:mm:ss)
|
/// </summary>
|
string _executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
|
/// <summary>
|
/// 接口调用状态(0-失败 1-成功)
|
/// </summary>
|
int sendStatus = 0;
|
|
try
|
{
|
string ErrorMsg = "";
|
ApiCommonParam Apiparam = ApiCommonParam.NewApiCommon();
|
|
_executeTimestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
string sendJson = JsonConvert.SerializeObject(entity);
|
ArrayList SQLStringList = new ArrayList();
|
var url = "https://openapi.xiekeyun.com/barcode/byDeliveryNo.json";
|
HttpClient httpClient = new HttpClient();
|
httpClient.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
|
|
_requestJson = "{\"commonParam\":" + JsonConvert.SerializeObject(Apiparam) + ",\"body\":" + sendJson + "}";
|
byte[] postData = Encoding.UTF8.GetBytes(_requestJson);
|
|
// 创建请求对象
|
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
|
request.Method = "POST";
|
request.ContentType = "application/json";
|
request.ContentLength = postData.Length;
|
|
// 发送请求数据
|
using (Stream stream = request.GetRequestStream())
|
{
|
stream.Write(postData, 0, postData.Length);
|
}
|
|
// 发送请求并获取响应
|
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
|
using (Stream stream = response.GetResponseStream())
|
using (StreamReader reader = new StreamReader(stream))
|
{
|
string result2 = reader.ReadToEnd();
|
|
_responseData = JsonConvert.DeserializeObject(result2);
|
}
|
|
if (_responseData.result != 1)
|
throw new ApplicationException(_responseData.errorMsg);
|
|
sendStatus = _responseData.result;
|
// 对数据做处理存入mes
|
if (SaveDeliveryNoticeBar(_responseData, entity.deliveryNo) > 0)
|
sendStatus = 1;
|
else
|
sendStatus = 0;
|
|
var logService = new LogService();
|
logService.CreateLogI(
|
db: Db,
|
edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
|
abtGuid: null,
|
abtTable: "TBL_BARCODE_INFORMATION",
|
detail: _logMessageDhdBar,
|
orderNo: "",
|
sendJson: _requestJson,
|
rtnJson: JsonConvert.SerializeObject(_responseData),
|
xkyBeginTime: "",
|
xkyEndTime: "",
|
sendStatus: sendStatus,
|
executeTime: _executeTimestamp
|
);
|
|
return _responseData;
|
}
|
catch (Exception e)
|
{
|
var logService = new LogService();
|
logService.CreateLogI(
|
db: Db,
|
edtUserGuid: Guid.Parse("11111111-1111-1111-1111-111111111111"),
|
abtGuid: null,
|
abtTable: "TBL_BARCODE_INFORMATION",
|
detail: _logMessageDhdBar + $"系统异常错误:{e.Message}\n跟踪:{e.StackTrace}",
|
orderNo: "",
|
sendJson: _requestJson,
|
rtnJson: JsonConvert.SerializeObject(_responseData),
|
xkyBeginTime: "",
|
xkyEndTime: "",
|
sendStatus: 0,
|
executeTime: _executeTimestamp
|
);
|
throw new Exception(e.Message);
|
}
|
|
}
|
|
//对获取到的携客云送货单条码做处理
|
private int SaveDeliveryNoticeBar(dynamic responseJson,string deliveryNo)
|
{
|
var result = 1;
|
List<TblBarcodeInformation> noticeList = JsonConvert.DeserializeObject<List<TblBarcodeInformation>>(responseJson.dataList.ToString());
|
|
// 新增列表空值检查
|
if (noticeList == null || !noticeList.Any() || noticeList.Count < 1)
|
{
|
_logMessageDhdBar += $"条码数据为空,送货单号:{deliveryNo}";
|
return result;
|
}
|
|
// 赋值guid和到货单号
|
noticeList.ForEach(n => n.Id = Guid.NewGuid());
|
noticeList.ForEach(n => n.DeliveryNo = deliveryNo);
|
noticeList.ForEach(n => n.SynchronousDate = DateTime.Now);
|
|
|
Db.Ado.UseTran(() =>
|
{
|
// 删除关联送货明细数据
|
Db.Deleteable<TblBarcodeInformation>()
|
.Where(d => d.DeliveryNo == deliveryNo)
|
.ExecuteCommand();
|
|
// 批量插入优化
|
result = Db.Fastest<TblBarcodeInformation>().BulkCopy(noticeList);
|
},
|
ex => {
|
// 增强异常信息
|
//_logMessageDhdBar = _logMessageDhdBar + $"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}";
|
throw new Exception($"数据库操作失败:{ex.Message}\n跟踪:{ex.StackTrace}");
|
});
|
|
return result;
|
}
|
}
|