SetSysUserFileStringExcutor.cs 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Diagnostics;
  5. using System.IO;
  6. using System.IO.Compression;
  7. using System.Linq;
  8. using System.Text;
  9. using JLHHJSvr;
  10. using JLHHJSvr.BLL;
  11. using JLHHJSvr.Com;
  12. using JLHHJSvr.DBA.DBModle;
  13. using LJLib.Net.SPI.Server;
  14. namespace JLHHJSvr.Excutor
  15. {
  16. internal sealed class SetSysUserFileStringExcutor : ExcutorBase<SetSysUserFileStringRequest, SetSysUserFileStringResponse>
  17. {
  18. protected override void ExcuteInternal(SetSysUserFileStringRequest request, object state, SetSysUserFileStringResponse rslt)
  19. {
  20. if (request.empid == null)
  21. {
  22. rslt.ErrMsg = "参数错误,empid不能为null";
  23. return;
  24. }
  25. if (request.dwname == null)
  26. {
  27. rslt.ErrMsg = "参数错误,dwname不能为null";
  28. return;
  29. }
  30. if (request.itemname == null)
  31. {
  32. rslt.ErrMsg = "参数错误,itemname不能为null";
  33. return;
  34. }
  35. if (request.itemvalue == null)
  36. {
  37. rslt.ErrMsg = "参数错误,itemvalue不能为null";
  38. return;
  39. }
  40. var tokendata = BllHelper.GetToken(request.token);
  41. if (tokendata == null)
  42. {
  43. rslt.ErrMsg = "会话已经中断";
  44. return;
  45. }
  46. //if (string.IsNullOrEmpty(tokendata.ConStr))
  47. //{
  48. // rslt.ErrMsg = "当前账套未设置数据库";
  49. // return;
  50. //}
  51. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  52. using (var cmd = con.CreateCommand())
  53. {
  54. con.Open();
  55. using (cmd.Transaction = con.BeginTransaction())
  56. {
  57. try
  58. {
  59. //var ufs = HelperBase.GetHelper<SysUserFileString>(cmd);
  60. var ifok = BllHelper.SetValue(cmd, request.empid.Value, request.dwname, request.itemname, request.itemvalue, request.ifcompress == 1 ? true : false);
  61. if (!ifok)
  62. {
  63. rslt.ErrMsg = "自定义值保存失败,可能数据库字段长度不足";
  64. }
  65. //if (request.empid == -1)
  66. //{
  67. // BllHelper.delOtherLayout(cmd, request.dwname, request.itemname);
  68. //}
  69. cmd.Transaction.Commit();
  70. }
  71. catch (Exception e)
  72. {
  73. cmd.Transaction.Rollback();
  74. rslt.ErrMsg = e.ToString();
  75. }
  76. }
  77. }
  78. }
  79. }
  80. }