onlineIPMonitor.blade.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. @extends('admin.layouts')
  2. @section('css')
  3. <link href="/assets/global/vendor/bootstrap-table/bootstrap-table.min.css" rel="stylesheet">
  4. @endsection
  5. @section('content')
  6. <div class="page-content container-fluid">
  7. <div class="panel">
  8. <div class="panel-heading">
  9. <h3 class="panel-title">在线IP监控
  10. <small>2分钟内的实时数据</small>
  11. </h3>
  12. </div>
  13. <div class="panel-body">
  14. <div class="form-row">
  15. <div class="form-group col-lg-2 col-sm-2">
  16. <input type="number" class="form-control" name="id" id="id" value="{{Request::input('id')}}"
  17. placeholder="ID"/>
  18. </div>
  19. <div class="form-group col-lg-2 col-sm-5">
  20. <input type="text" class="form-control" name="email" id="email"
  21. value="{{Request::input('email')}}" placeholder="用户名"/>
  22. </div>
  23. <div class="form-group col-lg-2 col-sm-5">
  24. <input type="text" class="form-control" name="ip" id="ip" value="{{Request::input('ip')}}"
  25. placeholder="IP"/>
  26. </div>
  27. <div class="form-group col-lg-2 col-sm-3">
  28. <input type="number" class="form-control" name="port" id="port" value="{{Request::input('port')}}"
  29. placeholder="端口"/>
  30. </div>
  31. <div class="form-group col-lg-2 col-sm-5">
  32. <select name="nodeId" id="nodeId" class="form-control" onChange="Search()">
  33. <option value="" @if(Request::input('nodeId') == '') selected @endif hidden>选择节点</option>
  34. @foreach($nodes as $node)
  35. <option value="{{$node->id}}"
  36. @if(Request::input('nodeId') == $node->id) selected @endif>{{$node->name}}</option>
  37. @endforeach
  38. </select>
  39. </div>
  40. <div class="form-group col-lg-2 col-sm-4 btn-group">
  41. <button class="btn btn-primary" onclick="Search()">搜 索</button>
  42. <a href="{{route('admin.log.online')}}" class="btn btn-danger">{{trans('common.reset')}}</a>
  43. </div>
  44. </div>
  45. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  46. <thead class="thead-default">
  47. <tr>
  48. <th> #</th>
  49. <th> 类型</th>
  50. <th> 节点</th>
  51. <th> 用户</th>
  52. <th> IP</th>
  53. <th> 归属地</th>
  54. <th> 时间</th>
  55. </tr>
  56. </thead>
  57. <tbody>
  58. @foreach($onlineIPLogs as $log)
  59. <tr>
  60. <td>{{$log->id}}</td>
  61. <td>{{$log->type}}</td>
  62. <td>{{$log->node->name ?? '【节点已删除】'}}</td>
  63. <td>{{$log->user->email ?? '【用户已删除】'}}</td>
  64. <td>
  65. @if (strpos($log->ip, ',') !== false)
  66. @foreach (explode(',', $log->ip) as $ip)
  67. {{$ip}}
  68. @endforeach
  69. @else
  70. {{$log->ip}}
  71. @endif
  72. </td>
  73. <td>{{strpos($log->ip, ',') !== false? '':$log->ipInfo}}</td>
  74. <td>{{date('Y-m-d H:i:s',$log->created_at)}}</td>
  75. </tr>
  76. @endforeach
  77. </tbody>
  78. </table>
  79. </div>
  80. <div class="panel-footer">
  81. <div class="row">
  82. <div class="col-sm-4">
  83. 共 <code>{{$onlineIPLogs->total()}}</code> 个账号
  84. </div>
  85. <div class="col-sm-8">
  86. <nav class="Page navigation float-right">
  87. {{$onlineIPLogs->links()}}
  88. </nav>
  89. </div>
  90. </div>
  91. </div>
  92. </div>
  93. </div>
  94. @endsection
  95. @section('javascript')
  96. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js"></script>
  97. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"></script>
  98. <script>
  99. //回车检测
  100. $(document).on('keypress', 'input', function(e) {
  101. if (e.which === 13) {
  102. Search();
  103. return false;
  104. }
  105. });
  106. // 搜索
  107. function Search() {
  108. window.location.href = '{{route('admin.log.online')}}' + $('#id').val() + '?ip=' + $('#ip').val() + '&email=' +
  109. $('#email').val() + '&port=' + $('#port').val() + '&nodeId=' + $('#nodeId option:selected').val();
  110. }
  111. </script>
  112. @endsection