thinkphp5에서 지정된 IP 액세스 모듈 구성 허용을 추가하는 방법

藏色散人
풀어 주다: 2021-03-22 08:58:17
앞으로
2457명이 탐색했습니다.

다음 튜토리얼 칼럼인 thinkphp에서는 특정 IP 액세스를 허용하는 모듈을 추가하기 위해 thinkphp5를 구성하는 방법을 소개합니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!

thinkphp5에서 지정된 IP 액세스 모듈 구성 허용을 추가하는 방법

thinkphp5는 특정 IP가 모듈 구성에 액세스하도록 허용하는 기능을 추가합니다.

Add

'allow_module_ip' => ['admin' => '*'], // 구성에서 특정 IP를 설정합니다. php 지정된 모듈에 접근 가능

['admin' => '*'] 모든 IP는 관리 모듈에 접근 가능
['admin' => ['127.0.0.1','192.168.1.100']] 이 두 가지만 가능 IP는 관리자 모듈에 접근할 수 있습니다

이 위치에 추가하는 것이 가장 좋습니다

// 禁止访问模块
'deny_module_list'       => ['common'],
// 设置某些ip可以访问指定模块
'allow_module_ip'        => ['admin' => '*'],
// 默认控制器名
'default_controller'     => 'Index',
로그인 후 복사

프레임워크 코드를 수정해야 합니다
thinkphp/library/think/App.php

코드 위치는 다음과 같습니다

public static function module($result, $config, $convert = null) {
        if (is_string($result)) {
            $result = explode('/', $result);
        }
        $request = Request::instance();
        if ($config['app_multi_module']) {
            // 多模块部署
            $module    = strip_tags(strtolower($result[0] ?: $config['default_module']));
            $bind      = Route::getBind('module');
            $available = false;
            if ($bind) {
                // 绑定模块
                list($bindModule) = explode('/', $bind);
                if (empty($result[0])) {
                    $module    = $bindModule;
                    $available = true;
                } elseif ($module == $bindModule) {
                    $available = true;
                }
            } elseif (!in_array($module, $config['deny_module_list']) && is_dir(APP_PATH . $module)) {
                $available = true;
            }
            
            //region 设置了限制ip访问模块, 如:'allow_module_ip' => ['admin'=>['127.0.0.1']]
            if (isset($config['allow_module_ip']) && isset($config['allow_module_ip'][$module])) {
                $allowIps = $config['allow_module_ip'][$module];
                if (!in_array($_SERVER['REMOTE_ADDR'], $allowIps) && $allowIps != '*') {
                    $available = false;
                }

            }
            //end region

            // 模块初始化
            if ($module && $available) {
                // 初始化模块
                $request->module($module);
                $config = self::init($module);
                // 模块请求缓存检查
                $request->cache($config['request_cache'], $config['request_cache_expire'], $config['request_cache_except']);
            } else {
                throw new HttpException(404, 'module not exists:' . $module);
            }
        } else {
            // 单一模块部署
            $module = '';
            $request->module($module);
        }
        
        // ......
}
로그인 후 복사

관련 추천:최신 10 thinkphp 비디오 튜토리얼

위 내용은 thinkphp5에서 지정된 IP 액세스 모듈 구성 허용을 추가하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
php
원천:segmentfault.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿