123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- <?php
- namespace app\admin\controller;
- use think\facade\View;
- use think\facade\Db;
- use think\facade\Lang;
- /**
-
- *
-
- *
- * ----------------------------------------------------------------------------
- *
-
- * 控制器
- */
- class Adminlog extends AdminControl
- {
- const EXPORT_SIZE = 5000;
- public function initialize()
- {
- parent::initialize(); // TODO: Change the autogenerated stub
- Lang::load(base_path() . 'admin/lang/' . config('lang.default_lang') . '/adminlog.lang.php');
- }
- /**
- * 日志列表
- *
- */
- public function loglist()
- {
- $condition = array();
- $time1 = '';
- $time2 = '';
- if (!empty(input('param.admin_name'))) {
- $condition[] = array('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[] = array('adminlog_time', 'between', array($time1, $time2));
- } elseif ($time1) {
- $condition[] = array('adminlog_time', '>=', $time1);
- } elseif ($time2) {
- $condition[] = array('adminlog_time', '<=', $time2);
- }
- $adminlog_model = model('adminlog');
- $order = 'adminlog_id desc';
- $adminlog_list = $adminlog_model->getAdminlogList($condition, 10, $order);
- View::assign('adminlog_list', $adminlog_list);
- View::assign('show_page', $adminlog_model->page_info->render());
- View::assign('filtered', $condition ? 1 : 0); //是否有查询条件
- $this->setAdminCurItem('loglist');
- return View::fetch();
- }
- /**
- * 删除日志
- *
- */
- public function list_del()
- {
- $adminlog_id = input('param.adminlog_id');
- $adminlog_id_array = ds_delete_param($adminlog_id);
- if ($adminlog_id_array == FALSE) {
- ds_json_encode('10001', lang('param_error'));
- }
- $condition = array();
- $condition[] = array('adminlog_id', 'in', $adminlog_id_array);
- $adminlog_model = model('adminlog');
- if (!$adminlog_model->delAdminlog($condition)) {
- $this->log(lang('ds_del') . lang('admin_log'), 0);
- ds_json_encode('10001', lang('ds_common_del_fail'));
- } else {
- $this->log(lang('ds_del') . lang('admin_log'), 1);
- ds_json_encode('10000', lang('ds_common_del_succ'));
- }
- }
- /**
- * 导出第一步
- */
- public function export_step1()
- {
- $time1 = '';
- $time2 = '';
- $condition = array();
- if (!empty(input('param.admin_name'))) {
- $condition[] = array('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[] = array('createtime', 'between', array($time1, $time2));
- } elseif ($time1) {
- $condition[] = array('createtime', '>=', $time1);
- } elseif ($time2) {
- $condition[] = array('createtime', '<=', $time2);
- }
- if (!is_numeric(input('param.page'))) {
- $adminlog_model = model('adminlog');
- $count = $adminlog_model->getAdminlogCount($condition);
- $export_list = 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;
- $export_list[$i] = $limit1 . ' ~ ' . $limit2;
- }
- View::assign('export_list', $export_list);
- return View::fetch('/public/excel');
- } else { //如果数量小,直接下载
- $data = Db::name('adminlog')->where($condition)->order('adminlog_id desc')->limit(self::EXPORT_SIZE)->select()->toArray();
- $this->createExcel($data);
- }
- } else { //下载
- $limit1 = (input('param.page') - 1) * self::EXPORT_SIZE;
- $limit2 = self::EXPORT_SIZE;
- $data = Db::name('adminlog')->where($condition)->order('adminlog_id desc')->limit($limit1, $limit2)->select()->toArray();
- $this->createExcel($data);
- }
- }
- /**
- * 生成excel
- *
- * @param array $data
- */
- private function createExcel($data = array())
- {
- Lang::load(base_path() . 'admin/lang/' . config('lang.default_lang') . '/export.lang.php');
- $excel_obj = new \excel\Excel();
- $excel_data = array();
- //设置样式
- $excel_obj->setStyle(array(
- 'id' => 's_title', 'Font' => array('FontName' => lang('ds_song_typeface'), '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['adminlog_content']);
- $tmp[] = array('data' => date('Y-m-d H:i:s', $v['adminlog_time']));
- $tmp[] = array('data' => $v['adminlog_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.page') . '-' . date('Y-m-d-H', TIMESTAMP));
- }
- protected function getAdminItemList()
- {
- $menu_array = array(
- array(
- 'name' => 'loglist',
- 'text' => lang('admin_log'),
- 'url' => (string)url('Adminlog/loglist')
- )
- );
- return $menu_array;
- }
- }
|