| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- <?php
- namespace app\user\controller;
- use think\Lang;
- class Adminlog extends AdminControl
- {
- const EXPORT_SIZE = 5000;
- public function _initialize()
- {
- parent::_initialize(); // TODO: Change the autogenerated stub
- Lang::load(APP_PATH . 'admin/lang/' . config('default_lang') . '/adminlog.lang.php');
- }
- /**
- * 日志列表
- *
- */
- public function index()
- {
- $condition = array();
- $time1 = '';
- $time2 = '';
- if (!empty(input('param.admin_name'))) {
- $condition['admin_name'] = input('param.admin_name');
- }
- if (!empty(input('param.time_from'))) {
- $time1 = strtotime(input('param.time_from'));
- }
- if (!empty(input('param.time_to'))) {
- $time2 = strtotime(input('param.time_to'));
- if ($time2 !== false)
- $time2 = $time2 + 86400;
- }
- if ($time1 && $time2) {
- $condition['createtime'] = array('between', array($time1, $time2));
- } elseif ($time1) {
- $condition['createtime'] = array('egt', $time1);
- } elseif ($time2) {
- $condition['createtime'] = array('elt', $time2);
- }
- $list = db('adminlog')->where($condition)->order('adminlog_id desc')->paginate(9, false, ['query' => request()->param()]);
- $page = $list->render();
- $allpower = $this->qxhans();
- $this->assign('allpower',$allpower);
- $this->assign('list', $list);
- $this->assign('page', $page);
- $this->setAdminCurItem('loglist');
- return $this->fetch();
- }
- /**
- * 删除日志
- *
- */
- public function list_del()
- {
- $adminlog_id = input('param.adminlog_id');
- $adminlog_id_array = ds_delete_param($adminlog_id);
- if ($adminlog_id_array == FALSE) {
- $this->error(lang('param_error'));
- }
- $condition = array();
- $condition['adminlog_id'] = array('in', $adminlog_id_array);
- if (db('adminlog')->where($condition)->delete()) {
- $this->log(lang('ds_adminlog').'-'.lang('del_succ').'->' .lang('ds_number_id'). '[' . $adminlog_id . ']', null);
- $this->success(lang('admin_log_del_succ'), url('adminlog/index'));
- } else {
- $this->error(lang('admin_log_del_fail'));
- }
- }
- /**
- * 导出第一步
- */
- public function export_step1()
- {
- $time1 = '';
- $time2 = '';
- $condition = array();
- if (!empty(input('param.admin_name'))) {
- $condition['admin_name'] = input('param.admin_name');
- }
- if (!empty(input('param.time_from'))) {
- $time1 = strtotime(input('param.time_from'));
- }
- if (!empty(input('param.time_to'))) {
- $time2 = strtotime(input('param.time_to'));
- if ($time2 !== false)
- $time2 = $time2 + 86400;
- }
- if ($time1 && $time2) {
- $condition['createtime'] = array('between', array($time1, $time2));
- } elseif ($time1) {
- $condition['createtime'] = array('egt', $time1);
- } elseif ($time2) {
- $condition['createtime'] = array('elt', $time2);
- }
- if (!is_numeric(input('param.curpage'))) {
- $count = db('adminlog')->where($condition)->count();
- $array = array();
- if ($count > self::EXPORT_SIZE) { //显示下载链接
- $page = ceil($count / self::EXPORT_SIZE);
- for ($i = 1; $i <= $page; $i++) {
- $limit1 = ($i - 1) * self::EXPORT_SIZE + 1;
- $limit2 = $i * self::EXPORT_SIZE > $count ? $count : $i * self::EXPORT_SIZE;
- $array[$i] = $limit1 . ' ~ ' . $limit2;
- }
- $this->assign('list', $array);
- $this->assign('murl', url('adminlog/list'));
- return $this->fetch('excel');
- } else { //如果数量小,直接下载
- $data = db('adminlog')->where($condition)->order('adminlog_id desc')->limit(self::EXPORT_SIZE)->select();
- $this->createExcel($data);
- }
- } else { //下载
- $limit1 = (input('param.curpage') - 1) * self::EXPORT_SIZE;
- $limit2 = self::EXPORT_SIZE;
- $data = db('adminlog')->where($condition)->order('adminlog_id desc')->limit("{$limit1},{$limit2}")->select();
- $this->createExcel($data);
- }
- }
- /**
- * 生成excel
- *
- * @param array $data
- */
- private function createExcel($data = array())
- {
- Lang::load(APP_PATH . 'admin/lang/zh-cn/export.php');
- $excel_obj = new \excel\Excel();
- $excel_data = array();
- //设置样式
- $excel_obj->setStyle(array(
- 'id' => 's_title', 'Font' => array('FontName' => '宋体', 'Size' => '12', 'Bold' => '1')
- ));
- //header
- $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('admin_log_man'));
- $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('admin_log_do'));
- $excel_data[0][] = array('styleid' => 's_title', 'data' => lang('admin_log_dotime'));
- $excel_data[0][] = array('styleid' => 's_title', 'data' => 'IP');
- foreach ((array)$data as $k => $v) {
- $tmp = array();
- $tmp[] = array('data' => $v['admin_name']);
- $tmp[] = array('data' => $v['content']);
- $tmp[] = array('data' => date('Y-m-d H:i:s', $v['createtime']));
- $tmp[] = array('data' => $v['ip']);
- $excel_data[] = $tmp;
- }
- $excel_data = $excel_obj->charset($excel_data, CHARSET);
- $excel_obj->addArray($excel_data);
- $excel_obj->addWorksheet($excel_obj->charset(lang('admin_log'), CHARSET));
- $excel_obj->generateXML($excel_obj->charset(lang('admin_log'), CHARSET) . input('param.curpage') . '-' . date('Y-m-d-H', time()));
- }
- protected function getAdminItemList()
- {
- $menu_array = array(
- array(
- 'name' => 'loglist',
- 'text' => lang('admin_log'),
- 'url' => url('adminlog/loglist')
- )
- );
- return $menu_array;
- }
- }
|