admin_log.php 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?php
  2. /**
  3. * 系统操作日志
  4. *
  5. *
  6. *
  7. ***/
  8. defined('InShopNC') or exit('Access Invalid!');
  9. class admin_logControl extends SystemControl{
  10. const EXPORT_SIZE = 5000;
  11. public function __construct(){
  12. parent::__construct();
  13. Language::read('admin_log');
  14. }
  15. /**
  16. * 日志列表
  17. *
  18. */
  19. public function listOp(){
  20. $model = Model('admin_log');
  21. $condition = array();
  22. if (!empty($_GET['admin_name'])){
  23. $condition['admin_name'] = $_GET['admin_name'];
  24. }
  25. if(!empty($_GET['time_from'])){
  26. $time1 = strtotime($_GET['time_from']);
  27. }
  28. if(!empty($_GET['time_to'])){
  29. $time2 = strtotime($_GET['time_to']);
  30. if($time2 !== false) $time2 = $time2 + 86400;
  31. }
  32. if ($time1 && $time2){
  33. $condition['createtime'] = array('between',array($time1,$time2));
  34. }elseif($time1){
  35. $condition['createtime'] = array('egt',$time1);
  36. }elseif($time2){
  37. $condition['createtime'] = array('elt',$time2);
  38. }
  39. $list = $model->where($condition)->order('id desc')->page(20)->select();
  40. // $admin = Model()->table('admin,gadmin')->field('admin_id,admin_name,gid,gname')->join('left')->on('admin.admin_gid=gadmin.gid')->select();
  41. Tpl::output('list',$list);
  42. Tpl::output('page',$model->showpage());
  43. Tpl::showpage('admin_log.index');
  44. }
  45. /**
  46. * 删除日志
  47. *
  48. */
  49. public function list_delOp(){
  50. $condition = array();
  51. if (is_numeric($_GET['delago'])){
  52. $condition['createtime'] = array('lt',time()-intval($_GET['delago']));
  53. }elseif($_GET['delago'] == 'all'){
  54. $condition = true;
  55. }elseif(is_array($_POST['del_id'])){
  56. $condition['id'] = array('in',$_POST['del_id']);
  57. }
  58. if (!Model('admin_log')->where($condition)->delete()){
  59. $this->log(L('nc_del,nc_admin_log'),0);
  60. showMessage(L('nc_common_del_fail'),'','html','error');
  61. }else{
  62. $this->log(L('nc_del,nc_admin_log'),1);
  63. showMessage(L('nc_common_del_succ'),'','html','error');
  64. }
  65. }
  66. /**
  67. * 导出第一步
  68. */
  69. public function export_step1Op(){
  70. $model = Model('admin_log');
  71. $condition = array();
  72. if (!empty($_GET['admin_name'])){
  73. $condition['admin_name'] = $_GET['admin_name'];
  74. }
  75. if(!empty($_GET['time_from'])){
  76. $time1 = strtotime($_GET['time_from']);
  77. }
  78. if(!empty($_GET['time_to'])){
  79. $time2 = strtotime($_GET['time_to']);
  80. if($time2 !== false) $time2 = $time2 + 86400;
  81. }
  82. if ($time1 && $time2){
  83. $condition['createtime'] = array('between',array($time1,$time2));
  84. }elseif($time1){
  85. $condition['createtime'] = array('egt',$time1);
  86. }elseif($time2){
  87. $condition['createtime'] = array('elt',$time2);
  88. }
  89. if (!is_numeric($_GET['curpage'])){
  90. $count = $model->where($condition)->count();
  91. $array = array();
  92. if ($count > self::EXPORT_SIZE ){ //显示下载链接
  93. $page = ceil($count/self::EXPORT_SIZE);
  94. for ($i=1;$i<=$page;$i++){
  95. $limit1 = ($i-1)*self::EXPORT_SIZE + 1;
  96. $limit2 = $i*self::EXPORT_SIZE > $count ? $count : $i*self::EXPORT_SIZE;
  97. $array[$i] = $limit1.' ~ '.$limit2 ;
  98. }
  99. Tpl::output('list',$array);
  100. Tpl::output('murl','index.php?act=admin_log&op=list');
  101. Tpl::showpage('export.excel');
  102. }else{ //如果数量小,直接下载
  103. $data = $model->where($condition)->order('id desc')->limit(self::EXPORT_SIZE)->select();
  104. $this->createExcel($data);
  105. }
  106. }else{ //下载
  107. $limit1 = ($_GET['curpage']-1) * self::EXPORT_SIZE;
  108. $limit2 = self::EXPORT_SIZE;
  109. $data = $model->where($condition)->order('id desc')->limit("{$limit1},{$limit2}")->select();
  110. $this->createExcel($data);
  111. }
  112. }
  113. /**
  114. * 生成excel
  115. *
  116. * @param array $data
  117. */
  118. private function createExcel($data = array()){
  119. Language::read('export');
  120. import('libraries.excel');
  121. $excel_obj = new Excel();
  122. $excel_data = array();
  123. //设置样式
  124. $excel_obj->setStyle(array('id'=>'s_title','Font'=>array('FontName'=>'宋体','Size'=>'12','Bold'=>'1')));
  125. //header
  126. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('admin_log_man'));
  127. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('admin_log_do'));
  128. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('admin_log_dotime'));
  129. $excel_data[0][] = array('styleid'=>'s_title','data'=>'IP');
  130. foreach ((array)$data as $k=>$v){
  131. $tmp = array();
  132. $tmp[] = array('data'=>$v['admin_name']);
  133. $tmp[] = array('data'=>$v['content']);
  134. $tmp[] = array('data'=>date('Y-m-d H:i:s',$v['createtime']));
  135. $tmp[] = array('data'=>$v['ip']);
  136. $excel_data[] = $tmp;
  137. }
  138. $excel_data = $excel_obj->charset($excel_data,CHARSET);
  139. $excel_obj->addArray($excel_data);
  140. $excel_obj->addWorksheet($excel_obj->charset(L('nc_admin_log'),CHARSET));
  141. $excel_obj->generateXML($excel_obj->charset(L('nc_admin_log'),CHARSET).$_GET['curpage'].'-'.date('Y-m-d-H',time()));
  142. }
  143. }