| | <?php |
| | namespace app\admin\controller; |
| | use think\Db; |
| |
|
| | class Safety extends Base |
| | { |
| |
|
| | var $_files; |
| | public function __construct() |
| | { |
| | parent::__construct(); |
| | } |
| |
|
| | public function index() |
| | { |
| |
|
| | } |
| |
|
| | protected function listDir($dir){ |
| | if(is_dir($dir)){ |
| | if ($dh = opendir($dir)) { |
| | while (($file= readdir($dh)) !== false){ |
| | $tmp = str_replace('//','/',mac_convert_encoding($dir.$file, "UTF-8", "GB2312")); |
| | if((is_dir($dir."/".$file)) && $file!="." && $file!=".."){ |
| | $this->listDir($dir."/".$file."/"); |
| | } else{ |
| | if($file!="." && $file!=".."){ |
| | $this->_files[$tmp] = ['md5'=>md5_file($dir.$file)]; |
| | } |
| | } |
| | } |
| | closedir($dh); |
| | } |
| | } |
| | } |
| |
|
| | public function file() |
| | { |
| | $param = input(); |
| | if($param['ck']){ |
| | $ft = $param['ft']; |
| | if(empty($ft)){ |
| | $ft = ['1','2']; |
| | } |
| | mac_echo('<style type="text/css">body{font-size:12px;color: #333333;line-height:21px;}span{font-weight:bold;color:#FF0000}</style>'); |
| | $url = base64_decode("aHR0cDovL3VwZGF0ZS5tYWNjbXMubGEv") . "v10/mac_files_".config('version')['code'].'.html'; |
| | $html = mac_curl_get($url); |
| | $json = json_decode($html,true); |
| | if(!$json){ |
| | return $this->error(lang('admin/safety/file_msg1')); |
| | } |
| |
|
| | $this->listDir('./'); |
| | if(!is_array($this->_files)){ |
| | return $this->error(lang('admin/safety/file_msg2')); |
| | } |
| |
|
| | foreach($this->_files as $k=>$v){ |
| | $color = ''; |
| | $msg = 'ok'; |
| | if(empty($json[$k]) && in_array('1',$ft)){ |
| | $color = 'BlueViolet'; |
| | $msg = lang('admin/safety/file_msg3'); |
| | } |
| | elseif(!empty($json[$k]) && $v['md5'] != $json[$k]['md5'] && in_array('2',$ft)){ |
| | $color = 'red'; |
| | $msg = lang('admin/safety/file_msg4'); |
| | } |
| | if($color!='') { |
| | |
| | mac_echo($k . '---' . "<font color=$color>" . $msg . '</font>'); |
| | } |
| | } |
| | exit; |
| | } |
| | return $this->fetch('admin@safety/file'); |
| | } |
| |
|
| | public function data() |
| | { |
| | $param = input(); |
| | if ($param['ck']) { |
| | $pre = config('database.prefix'); |
| | $schema = Db::query('select * from information_schema.columns where table_schema = ?', [config('database.database')]); |
| | $col_list = []; |
| | $sql = ''; |
| | foreach ($schema as $k => $v) { |
| | $col_list[$v['TABLE_NAME']][$v['COLUMN_NAME']] = $v; |
| | } |
| | $tables = ['actor', 'art', 'gbook', 'link', 'topic', 'type', 'vod']; |
| | $param['tbi'] = intval($param['tbi']); |
| | if ($param['tbi'] >= count($tables)) { |
| | mac_echo(lang('admin/safety/data_clear_ok')); |
| | die; |
| | } |
| |
|
| | $check_arr = ["<script","<iframe","{php}","{:"]; |
| | $rel_val = [ |
| | [ |
| | "/<script[\s\S]*?<\/(.*)>/is", |
| | "/<script[\s\S]*?>/is", |
| | ], |
| | [ |
| | "/<iframe[\s\S]*?<\/(.*)>/is", |
| | "/<iframe[\s\S]*?>/is", |
| | ], |
| | [ |
| | "/{php}[\s\S]*?{\/php}/is", |
| | ], |
| | [ |
| | "/{:[\s\S]*?}/is", |
| | ] |
| | ]; |
| | mac_echo('<style type="text/css">body{font-size:12px;color: #333333;line-height:21px;}span{font-weight:bold;color:#FF0000}</style>'); |
| |
|
| |
|
| | foreach ($col_list as $k1 => $v1) { |
| | $pre_tb = str_replace($pre, '', $k1); |
| | $si = array_search($pre_tb, $tables); |
| | if ($pre_tb !== $tables[$param['tbi']]) { |
| | continue; |
| | } |
| | mac_echo(lang('admin/safety/data_check_tip1',[$k1])); |
| | $where = []; |
| | foreach ($v1 as $k2 => $v2) { |
| | if (strpos($v2['DATA_TYPE'], 'int') === false) { |
| | $where[$k2] = ['like', mac_like_arr(join(',', $check_arr)), 'OR']; |
| | } |
| | } |
| | if (!empty($where)) { |
| | $field = array_keys($where); |
| | $field[] = $tables[$si] . '_id'; |
| | $list = Db::name($pre_tb)->field($field)->whereOr($where)->fetchSql(false)->select(); |
| |
|
| | mac_echo(lang('admin/safety/data_check_tip2',[count($list)])); |
| | foreach ($list as $k3 => $v3) { |
| | $update = []; |
| | $col_id = $tables[$si] . '_id'; |
| | $col_name = $tables[$si] . '_name'; |
| | $val_id = $v3[$col_id];; |
| | $val_name = strip_tags($v3[$col_name]); |
| | $ck = false; |
| | $where2 = []; |
| | $where2[$col_id] = $val_id; |
| | foreach ($v3 as $k4 => $v4) { |
| | if ($k4 != $col_id) { |
| | $val = $v4; |
| | foreach ($check_arr as $kk => $vv) { |
| | foreach($rel_val[$kk] as $k5=>$v5){ |
| | $val = preg_replace($v5, "", $val); |
| | } |
| | } |
| | if ($val !== $v4) { |
| | $update[$k4] = $val; |
| | $ck = true; |
| | } |
| | } |
| | } |
| |
|
| | if ($ck) { |
| | $r = Db::name($pre_tb)->where($where2)->update($update); |
| | mac_echo($val_id . '、' . $val_name . ' ok'); |
| | } |
| | } |
| | } |
| | } |
| |
|
| | $param['tbi']++; |
| | $url = url('safety/data') . '?' . http_build_query($param); |
| | mac_jump($url, 3); |
| | exit; |
| | } |
| | return $this->fetch('admin@safety/data'); |
| | } |
| | } |
| |
|