Index.php 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. <?php
  2. namespace app\index\controller;
  3. use think\Controller;
  4. use think\Request;
  5. use think\Db;
  6. use think\Session;
  7. class Index
  8. {
  9. //登录函数(后续做成有权限的)
  10. public function index(Request $request)
  11. {
  12. if ($request->isPost()){
  13. $data = input();
  14. $username = $data['username']; //用户名
  15. $password = md5($data['password']); //获取加密后的密码
  16. $where=[
  17. 'username'=>$username,
  18. 'password'=>$password
  19. ];
  20. $result = Db::name('admin')->where($where)->find();
  21. if($result){
  22. return json(['code'=>'00','user'=>$result['nickname'],'msg'=>'登录成功']);
  23. }else{
  24. return json(['code'=>'01','msg'=>'用户名或密码错误']);
  25. }
  26. }else{
  27. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  28. }
  29. }
  30. //获取用户的函数 (根据条件筛选出来)
  31. public function getuser(Request $request){
  32. if ($request->isPost()){
  33. $data = input();
  34. $group = isset($data['group'])?$data['group']:''; //组
  35. $user = isset($data['user'])?$data['user']:''; //用户
  36. $order = isset($data['order'])?$data['order']:''; //用户
  37. $group = explode(",", $group); //使用字符串切割
  38. $user = explode(",", $user); //使用字符串切割
  39. $where1=[]; //后面一个字符的选择
  40. $where2=[]; //后面多个字符的选择
  41. foreach ($group as $key => $value) {
  42. // 对其中的通配符和单字符进行匹配
  43. $pos = strpos($value,"*"); //是否全字匹配
  44. if($pos===false){
  45. $pos_one = strpos($value,"?");
  46. if($pos_one===false){
  47. continue;
  48. }else{
  49. $value = str_replace("?","",$value);
  50. if($pos_one==0){
  51. $where1['GROUP'] = ['like','_'.$value]; //前面一个字符的选择
  52. }else{
  53. $where1['GROUP'] = ['like',$value.'_']; //后面一个字符的选择
  54. }
  55. unset($group[$key]);
  56. }
  57. }else{
  58. $value = str_replace("*","",$value);
  59. if($pos==0){
  60. $where2['GROUP'] = ['like','%'.$value]; //前面多个字符的选择
  61. }else{
  62. $where2['GROUP'] = ['like',$value.'%']; //后面多个字符的选择
  63. }
  64. unset($group[$key]);
  65. }
  66. }
  67. $where['GROUP'] = ['in',$group]; //精准选择(组的成员)
  68. $whereuser['LOGIN']=['in',$user]; //精准选择(用户成员)
  69. $result = Db::name('mt4_users')->where($where)->whereOr($where1)->whereOr($where2)->whereOr($whereuser)->distinct(true)->select(); //筛选函数
  70. $result1 = Db::name('order_progress')->where(['orig_order'=>$order])->select(); //筛选函数(当前跟踪的订单)
  71. //外层筛选出来之前做过的订单
  72. foreach ($result as $key => $value) {
  73. //自己选择的用户
  74. foreach ($result1 as $k => $v) {
  75. if($value['LOGIN']==$v['dest_login']){
  76. unset($result[$key]);
  77. }
  78. }
  79. }
  80. $result = array_values($result); //重新组织数组的键值对
  81. if($result){
  82. return json(['code'=>'00','user'=>$result,'msg'=>'获得数据成功']);
  83. }else{
  84. return json(['code'=>'01','msg'=>'没有对应的数据']);
  85. }
  86. }else{
  87. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  88. }
  89. }
  90. //点击订单后获取到的信息
  91. public function getorder(Request $request){
  92. if ($request->isPost()){
  93. $data = input(); //获取订单的信息
  94. $result = Db::name('mt4_trades')->where(['TICKET'=>$data['orderid']])->find(); //从数据库获取到订单信息
  95. if($result){
  96. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  97. }else{
  98. return json(['code'=>'01','msg'=>'没有找到匹配的订单']);
  99. }
  100. }else{
  101. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  102. }
  103. }
  104. // 点击订单后查询函数(rollback)
  105. public function rollback_order(Request $request){
  106. if ($request->isPost()){
  107. $data = input(); //获取订单的信息
  108. $result = Db::name('order_progress')->where(['type'=>"insert","orig_order"=>$data['orderid'],'error_code'=>0])->select(); //insert成功后插入的订单
  109. $result1 = Db::name('order_progress')->where(['type'=>"rollback","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //rollback失败后的订单
  110. $result2 = Db::name('order_progress')->where(['type'=>"retry","orig_order"=>$data['orderid']])->where('error_code','eq',0)->select(); //retry成功的订单
  111. $result = array_merge($result,$result1,$result2); //对数据进行合并
  112. if($result){
  113. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  114. }else{
  115. return json(['code'=>'01','msg'=>'暂无数据']);
  116. }
  117. }else{
  118. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  119. }
  120. }
  121. // 点击订单后查询函数(retry)
  122. public function retry_order(Request $request){
  123. if ($request->isPost()){
  124. $data = input(); //获取订单的信息
  125. $result = Db::name('order_progress')->where(['type'=>"insert","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //insert失败的订单
  126. $result1 = Db::name('order_progress')->where(['type'=>"retry","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //retry失败的订单
  127. $result2 = Db::name('order_progress')->where(['type'=>"except_rollback","orig_order"=>$data['orderid']])->where('error_code','neq',0)->select(); //except_rollback失败的订单
  128. $result = array_merge($result,$result1,$result2); //对数据进行合并
  129. if($result){
  130. return json(['code'=>'00','data'=>$result,'msg'=>'获得数据成功']);
  131. }else{
  132. return json(['code'=>'01','msg'=>'暂无数据']);
  133. }
  134. }else{
  135. return json(['code'=>'01','msg'=>'请使用post方式访问']);
  136. }
  137. }
  138. }