TradeFilterService.cs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. using System;
  2. using System.Collections.Generic;
  3. using Library;
  4. using LitJson;
  5. using System.Linq;
  6. using System.Data;
  7. using System.Threading;
  8. using MySystem.PxcModels;
  9. namespace MySystem
  10. {
  11. public class TradeFilterService
  12. {
  13. public readonly static TradeFilterService Instance = new TradeFilterService();
  14. private TradeFilterService()
  15. { }
  16. public void Start()
  17. {
  18. Thread th = new Thread(dosomething);
  19. th.IsBackground = true;
  20. th.Start();
  21. }
  22. public void dosomething()
  23. {
  24. while (true)
  25. {
  26. string data = RedisDbconn.Instance.RPop<string>("TradeFilterQueue");
  27. if (!string.IsNullOrEmpty(data))
  28. {
  29. try
  30. {
  31. function.WriteLog(data, "训练营60拦截队列日志");
  32. JsonData jsonOj = JsonMapper.ToObject(data);
  33. int Kind = int.Parse(function.CheckInt(jsonOj["Kind"].ToString()));
  34. int OrderId = int.Parse(function.CheckInt(jsonOj["OrderId"].ToString()));
  35. int PrizeUserId = int.Parse(function.CheckInt(jsonOj["PrizeUserId"].ToString()));
  36. decimal Amount = decimal.Parse(function.CheckNum(jsonOj["Amount"].ToString()));
  37. WebCMSEntities db = new WebCMSEntities();
  38. Orders order = db.Orders.FirstOrDefault(m => m.Id == OrderId) ?? new Orders();
  39. Users user = db.Users.FirstOrDefault(m => m.Id == order.UserId) ?? new Users();
  40. Users prizeuser = db.Users.FirstOrDefault(m => m.Id == PrizeUserId) ?? new Users();
  41. db.TradeFilterRecord.Add(new TradeFilterRecord()
  42. {
  43. CreateDate = DateTime.Now,
  44. IntercetpAmount = Amount,
  45. OrderDate = order.PayDate,
  46. OrderNo = order.OrderNo,
  47. OrderId = order.Id,
  48. PrizeUserId = PrizeUserId,
  49. OrderUserId = order.UserId,
  50. Kind = Kind,
  51. });
  52. db.SaveChanges();
  53. db.Dispose();
  54. function.WriteLog("入库成功", "训练营60拦截队列日志");
  55. JavaModels.WebCMSEntities javadb = new JavaModels.WebCMSEntities();
  56. JavaModels.KxsCampBonusLog log = javadb.KxsCampBonusLog.FirstOrDefault(m => m.Remark.Contains(order.OrderNo));
  57. if(log != null)
  58. {
  59. log.FilterUser = prizeuser.RealName;
  60. log.FilterCode = prizeuser.MakerCode;
  61. javadb.SaveChanges();
  62. }
  63. javadb.Dispose();
  64. }
  65. catch (Exception ex)
  66. {
  67. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "训练营拦截奖励异常");
  68. }
  69. }
  70. else
  71. {
  72. Thread.Sleep(500);
  73. }
  74. }
  75. }
  76. }
  77. }