277 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			277 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?php
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								namespace app\adminapi\controller;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								use app\adminapi\model\Admin as AdminModel;
							 | 
						|||
| 
								 | 
							
								use app\adminapi\model\AuthRule;
							 | 
						|||
| 
								 | 
							
								use app\common\controller\AdminApi;
							 | 
						|||
| 
								 | 
							
								use app\common\exception\UploadException;
							 | 
						|||
| 
								 | 
							
								use app\common\library\Upload;
							 | 
						|||
| 
								 | 
							
								use app\common\model\Area;
							 | 
						|||
| 
								 | 
							
								use app\common\model\Version;
							 | 
						|||
| 
								 | 
							
								use think\Config;
							 | 
						|||
| 
								 | 
							
								use think\Cookie;
							 | 
						|||
| 
								 | 
							
								use think\Hook;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								/**
							 | 
						|||
| 
								 | 
							
								 * 基础后台接口
							 | 
						|||
| 
								 | 
							
								 */
							 | 
						|||
| 
								 | 
							
								class Admin extends AdminApi
							 | 
						|||
| 
								 | 
							
								{
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    protected $model = null;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    protected $noNeedLogin = ['login',"init"];
							 | 
						|||
| 
								 | 
							
								    protected $noNeedRight = ["logout","menu","check_auth","have_auth"];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 初始化操作
							 | 
						|||
| 
								 | 
							
								     * @access protected
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function _initialize()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        $this->model = new AdminModel;
							 | 
						|||
| 
								 | 
							
								        parent::_initialize();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        $auth = $this->auth;
							 | 
						|||
| 
								 | 
							
								        //监听注册登录退出的事件
							 | 
						|||
| 
								 | 
							
								        Hook::add('admin_login_successed', function ($user) use ($auth) {
							 | 
						|||
| 
								 | 
							
								            $expire = input('post.keeplogin') ? 30 * 86400 : 0;
							 | 
						|||
| 
								 | 
							
								            Cookie::set('adminid', $user->id, $expire);
							 | 
						|||
| 
								 | 
							
								            Cookie::set('admintoken', $auth->getToken(), $expire);
							 | 
						|||
| 
								 | 
							
								        });
							 | 
						|||
| 
								 | 
							
								        Hook::add('admin_register_successed', function ($user) use ($auth) {
							 | 
						|||
| 
								 | 
							
								            Cookie::set('adminid', $user->id);
							 | 
						|||
| 
								 | 
							
								            Cookie::set('admintoken', $auth->getToken());
							 | 
						|||
| 
								 | 
							
								        });
							 | 
						|||
| 
								 | 
							
								        Hook::add('admin_delete_successed', function ($user) use ($auth) {
							 | 
						|||
| 
								 | 
							
								            Cookie::delete('adminid');
							 | 
						|||
| 
								 | 
							
								            Cookie::delete('admintoken');
							 | 
						|||
| 
								 | 
							
								        });
							 | 
						|||
| 
								 | 
							
								        Hook::add('admin_logout_successed', function ($user) use ($auth) {
							 | 
						|||
| 
								 | 
							
								            Cookie::delete('adminid');
							 | 
						|||
| 
								 | 
							
								            Cookie::delete('admintoken');
							 | 
						|||
| 
								 | 
							
								        });
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 管理员登录
							 | 
						|||
| 
								 | 
							
								     *
							 | 
						|||
| 
								 | 
							
								     * @ApiMethod (POST)
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="account", type="string", required=true, description="账号")
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="password", type="string", required=true, description="密码")
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function login()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        $account = $this->request->post('account');
							 | 
						|||
| 
								 | 
							
								        $password = $this->request->post('password');
							 | 
						|||
| 
								 | 
							
								        if (!$account || !$password) {
							 | 
						|||
| 
								 | 
							
								            $this->error(__('Invalid parameters'));
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        $ret = $this->auth->login($account, $password);
							 | 
						|||
| 
								 | 
							
								        if ($ret) {
							 | 
						|||
| 
								 | 
							
								            $data = ['userinfo' => $this->auth->getUserinfo()];
							 | 
						|||
| 
								 | 
							
								            $this->success(__('Logged in successful'), $data);
							 | 
						|||
| 
								 | 
							
								        } else {
							 | 
						|||
| 
								 | 
							
								            $this->error($this->auth->getError());
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 退出登录
							 | 
						|||
| 
								 | 
							
								     * @ApiMethod (POST)
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function logout()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								//        //设置contenttype不为表单格式防止触发宝塔防火墙
							 | 
						|||
| 
								 | 
							
								//        header('Content-Type:application/json; charset=utf-8');
							 | 
						|||
| 
								 | 
							
								        if (!$this->request->isPost()) {
							 | 
						|||
| 
								 | 
							
								            $this->error(__('Invalid parameters'));
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								//        $password = $this->request->post('datatime');
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        $this->auth->logout();
							 | 
						|||
| 
								 | 
							
								        $this->success(__('Logout successful'));
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 管理员菜单
							 | 
						|||
| 
								 | 
							
								     *
							 | 
						|||
| 
								 | 
							
								     * @ApiMethod (GET)
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="is_tree", type="string", required=true, description="是否是树形结构")
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function menu()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        $admin_id = $this->auth->id;
							 | 
						|||
| 
								 | 
							
								        $is_tree = $this->request->get('is_tree');
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        $menulist = (new AuthRule)->getMenulist($admin_id,["ismenu"=>1],$is_tree);
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        $this->success('查询成功', $menulist);
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 权限校验(接口校验版-用于前端自行显示隐藏)
							 | 
						|||
| 
								 | 
							
								     * 返回null为无权限
							 | 
						|||
| 
								 | 
							
								     * @ApiMethod (GET)
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="auth_name", type="string", required=true, description="请求路径或权限标识")
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function check_auth()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        $admin_id = $this->auth->id;
							 | 
						|||
| 
								 | 
							
								        $auth_name = $this->request->get('auth_name',"") ?: "***";
							 | 
						|||
| 
								 | 
							
								        $check = (new AuthRule)->authCheck($admin_id,$auth_name);
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        $this->success('权限校验结果返回', $check);
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 权限校验(直接返回拥有的所有权限,前端自行比对判断)
							 | 
						|||
| 
								 | 
							
								     *
							 | 
						|||
| 
								 | 
							
								     * @ApiMethod (GET)
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function have_auth()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        $admin_id = $this->auth->id;
							 | 
						|||
| 
								 | 
							
								        $check = (new AuthRule)->getAllRules($admin_id);
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        $this->success('权限列表返回', $check);
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 分离后台加载初始化
							 | 
						|||
| 
								 | 
							
								     *
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="lng", type="string", required=true, description="经度")
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="lat", type="string", required=true, description="纬度")
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function init()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								            $lng = $this->request->request('lng');
							 | 
						|||
| 
								 | 
							
								            $lat = $this->request->request('lat');
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								            //配置信息
							 | 
						|||
| 
								 | 
							
								            $upload = Config::get('upload');
							 | 
						|||
| 
								 | 
							
								            //如果非服务端中转模式需要修改为中转
							 | 
						|||
| 
								 | 
							
								            if ($upload['storage'] != 'local' && isset($upload['uploadmode']) && $upload['uploadmode'] != 'server') {
							 | 
						|||
| 
								 | 
							
								                //临时修改上传模式为服务端中转
							 | 
						|||
| 
								 | 
							
								                set_addon_config($upload['storage'], ["uploadmode" => "server"], false);
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                $upload = \app\common\model\Config::upload();
							 | 
						|||
| 
								 | 
							
								                // 上传信息配置后
							 | 
						|||
| 
								 | 
							
								                Hook::listen("upload_config_init", $upload);
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                $upload = Config::set('upload', array_merge(Config::get('upload'), $upload));
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								            $upload['cdnurl'] = $upload['cdnurl'] ? $upload['cdnurl'] : cdnurl('', true);
							 | 
						|||
| 
								 | 
							
								            $upload['uploadurl'] = preg_match("/^((?:[a-z]+:)?\/\/)(.*)/i", $upload['uploadurl']) ? $upload['uploadurl'] : url($upload['storage'] == 'local' ? '/adminapi/admin/upload' : $upload['uploadurl'], '', false, true);
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								            $content = [
							 | 
						|||
| 
								 | 
							
								                'citydata'    => Area::getCityFromLngLat($lng, $lat),
							 | 
						|||
| 
								 | 
							
								//                'versiondata' => Version::check($version),
							 | 
						|||
| 
								 | 
							
								                'uploaddata'  => $upload,
							 | 
						|||
| 
								 | 
							
								                'coverdata'   => Config::get("cover"),
							 | 
						|||
| 
								 | 
							
								            ];
							 | 
						|||
| 
								 | 
							
								            $this->success('', $content);
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    /**
							 | 
						|||
| 
								 | 
							
								     * 上传文件
							 | 
						|||
| 
								 | 
							
								     * @ApiMethod (POST)
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="file", type="File", required=true, description="文件流")
							 | 
						|||
| 
								 | 
							
								     * @ApiParams (name="category", type="string", required=true, description="分类标识:category1=非机密类1,category2=非机密类2,cert=证件机密类,code=二维码类,user=用户普通上传")
							 | 
						|||
| 
								 | 
							
								     */
							 | 
						|||
| 
								 | 
							
								    public function upload()
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        Config::set('default_return_type', 'json');
							 | 
						|||
| 
								 | 
							
								        //必须设定cdnurl为空,否则cdnurl函数计算错误
							 | 
						|||
| 
								 | 
							
								        Config::set('upload.cdnurl', '');
							 | 
						|||
| 
								 | 
							
								        $category = $this->request->post("category",'user');
							 | 
						|||
| 
								 | 
							
								//        var_dump($category);die;
							 | 
						|||
| 
								 | 
							
								        $chunkid = $this->request->post("chunkid");
							 | 
						|||
| 
								 | 
							
								        if ($chunkid) {
							 | 
						|||
| 
								 | 
							
								            if (!Config::get('upload.chunking')) {
							 | 
						|||
| 
								 | 
							
								                $this->error(__('Chunk file disabled'));
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								            $action = $this->request->post("action");
							 | 
						|||
| 
								 | 
							
								            $chunkindex = $this->request->post("chunkindex/d");
							 | 
						|||
| 
								 | 
							
								            $chunkcount = $this->request->post("chunkcount/d");
							 | 
						|||
| 
								 | 
							
								            $filename = $this->request->post("filename");
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								            $method = $this->request->method(true);
							 | 
						|||
| 
								 | 
							
								            if ($action == 'merge') {
							 | 
						|||
| 
								 | 
							
								                $attachment = null;
							 | 
						|||
| 
								 | 
							
								                //合并分片文件
							 | 
						|||
| 
								 | 
							
								                try {
							 | 
						|||
| 
								 | 
							
								                    $upload = new Upload();
							 | 
						|||
| 
								 | 
							
								                    $attachment = $upload->merge($chunkid, $chunkcount, $filename);
							 | 
						|||
| 
								 | 
							
								                } catch (UploadException $e) {
							 | 
						|||
| 
								 | 
							
								                    $this->error($e->getMessage());
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                $this->success(__('Uploaded successful'), ['url' => $attachment->url, 'fullurl' => cdnurl($attachment->url, true)]);
							 | 
						|||
| 
								 | 
							
								            } elseif ($method == 'clean') {
							 | 
						|||
| 
								 | 
							
								                //删除冗余的分片文件
							 | 
						|||
| 
								 | 
							
								                try {
							 | 
						|||
| 
								 | 
							
								                    $upload = new Upload();
							 | 
						|||
| 
								 | 
							
								                    $upload->clean($chunkid);
							 | 
						|||
| 
								 | 
							
								                } catch (UploadException $e) {
							 | 
						|||
| 
								 | 
							
								                    $this->error($e->getMessage());
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                $this->success();
							 | 
						|||
| 
								 | 
							
								            } else {
							 | 
						|||
| 
								 | 
							
								                //上传分片文件
							 | 
						|||
| 
								 | 
							
								                //默认普通上传文件
							 | 
						|||
| 
								 | 
							
								                $file = $this->request->file('file');
							 | 
						|||
| 
								 | 
							
								                try {
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                    $upload = new Upload($file);
							 | 
						|||
| 
								 | 
							
								                    $upload->chunk($chunkid, $chunkindex, $chunkcount);
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                } catch (UploadException $e) {
							 | 
						|||
| 
								 | 
							
								                    $this->error($e->getMessage());
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                $this->success();
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								        } else {
							 | 
						|||
| 
								 | 
							
								            $attachment = null;
							 | 
						|||
| 
								 | 
							
								            //默认普通上传文件
							 | 
						|||
| 
								 | 
							
								            $file = $this->request->file('file');
							 | 
						|||
| 
								 | 
							
								            try {
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                $upload = new Upload($file,$category);
							 | 
						|||
| 
								 | 
							
								                $attachment = $upload->upload();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								//                $attachment = $upload->upload();
							 | 
						|||
| 
								 | 
							
								            } catch (UploadException $e) {
							 | 
						|||
| 
								 | 
							
								                $this->error($e->getMessage().$e->getFile().$e->getLine());
							 | 
						|||
| 
								 | 
							
								            } catch (\Exception $e) {
							 | 
						|||
| 
								 | 
							
								                $this->error($e->getMessage().$e->getFile().$e->getLine());
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								            $this->success(__('Uploaded successful'), ['url' => $attachment->url, 'fullurl' => cdnurl($attachment->url, true)]);
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								}
							 |