markdown 语法

thinkphp学习

配置设置

优先级:动态配置>模块配置>扩展配置>应用配置>惯例配置
知识拓展以下仅供了解:
1惯例配置的作用域是全局,作用域越大,优先级越低;
2场景配置是用来切换开发场景的
3模块配置里也可细分扩展配置,很少用到,除非项目很庞大

模块设计

localhost/index/index/index报错

把. htaccess中 RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]

改成RewriteRule ^(.*)$ index.php [L,E=PATH_INFO:$1]

在其他目录使用common下的类

use app\common\controller\类名(index) as xxx;

之后2种

  1. class xx extends xxx return $this-> 方法名

  2. $xx=new xxx return $xx->方法名

惯例配置

thinkphp\convention.php

应用配置

扩展配置

config 中 改变 框架配置

  1. config.php 用来改变个别配置
  2. 新建extra目录 在其中放入 一类配置 如email,database 之后在这个配置文件中修改
  3. 拉出来的配置文件级别高与config.php 会进行 array merge

场景配置

修改app_status的值

设置"app_status" => "value",会指向value.php,所以能联系上home.php 和 office.php

value.php 要在config.php的同级目录下

模块配置

config目录下 新建与 配置模块 相同名字的 文件夹
之后便可在该文件夹中 进行 扩展配置&场景配置一类操作

动态配置

主要用于对当前控制器或某个方法里面进行动态的配置改变或动态的配置设置

  1. function __construct(){} 其中—construct类 会在同一文件中 其它方法之前运行 该代码段中不能用Config::get。

  2. 在方法中进行动态配置

    该动态配置只在该方法中生效

​ 1.config(name:' * ',value:' * ')

​ 2.Config::set

config类和助手函数config

Config 地址 thinkphp/library/think/Config.php

config 地址 thinkphp/helper.php

仔细观察 有些方法中 的值未赋 用 ' ' 跳过赋下一个值

// 导入my_config.php中的配置参数,并纳入user作用域
Config::load('my_config.php','','user'); 

// 解析并导入my_config.ini 中的配置参数,读入test作用域
Config::parse('my_config.ini','ini','test'); 

// 设置user_type参数,并纳入user作用域
Config::set('user_type',1,'user'); 

// 批量设置配置参数,并纳入test作用域
Config::set($config,'test'); 

// 读取user作用域的user_type配置参数
echo Config::get('user_type','user');

// 读取user作用域下面的所有配置参数
dump(Config::get('','user')); 
dump(config('',null,'user')); // 同上

// 判断在test作用域下面是否存在user_type参数
Config::has('user_type','test'); 
config('?user_type','test');

config()的实质是 先调用Config::xxx 再运行

config('?name','range')-->

return 0 === strpos($name, '?') ? Config::has(substr($name, 1), $range) : Config::get($name, $range);

strpos ( string $haystack , mixed $needle):返回needle在haystack中首次出现的数字位置 注意字符串位置是从0开始,而不是从1开始的。如果没找到 needle,将返回 FALSE

环境变量配置和使用


问题1:$_ENV无法获取 环境变量

打开php.ini,找到这样几行代码:
; variables_order
;Default Value: "EGPCS"
; Development Value: "GPCS"
; Production Value: "GPCS"
然后,将;Default Value: "EGPCS"前面的分号去掉,整个配置变成:
; variables_order
Default Value: "EGPCS"
; Development Value: "GPCS"
; Production Value: "GPCS"
然后重启Apache就可以了。


问题2:.env无法使用

修改thinkphp框架下的 base.php
在 putenv("$name=$val"); 代码下边
加上
$_ENV[$name] = $val;
$_SERVER[$name] = $val;


环境变量配置的参数会全部转换为大写,值为 nullnofalse 等效于 "",值为 yestrue 等效于 "1"

分组配置

[database]              |等价
hostname=localhost      |database_hostname=localhost  username=root           |database_username=root 
password=root           |database_password=root 

获取环境变量的值

Env::get('database.username');
Env::get('database.password');
// 同时下面的方式也可以获取
Env::get('database_username');
Env::get('database_password');

// 获取环境变量 如果不存在则使用默认值root
Env::get('database.username','root');

可以直接在应用配置中使用环境变量,例如:

return [
    'hostname'  =>  Env::get('hostname','127.0.0.1'),
];

可在.env中创建app_status 表示开发环境 并中config目录下 建相应开发环境的 PHP文件 并编写

从而使用不同的环境变量

URL和路由

入口文件

  • thinkphp 为单入口文件 应用程序的所有http请求都由某一个文件接受并转发到功能代码中
  • 单入口优势
    - 安全检测
    - 请求过滤

地址public\index.php
必须引入框架引导文件 start.php

隐藏入口文件

即把localhost/index.php/index/index/index变

成localhost/index/index/index

视频链接 亦可参考 模块设计

入口文件的绑定

define(BIND_MODULE)的定义

define(BIND_MODULE)的定义

  1. BIND_MODULE绑定模块 只能访问绑定模块下的相关内容,若模块不存在 报错

  1. 'auto_bind_module'     => true
    开启之后  通过文件入口进入则默认  名字相同的模块
    

    注意3pictures的url

通过绑定让某个人/服务器 只能访问部分功能

路由

  • 'url_route_on'         => true,//开启路由
    ----------
    return[
            //将id变量传递给info方法
            'news/:id'  => 'index/index/info'];         //设置路由
    如此开启路由后 只可localhost/news/xxx(.html)来访问
    不可localhost/index/index/info/id/xxx.(html)访问
    当要求echo url('index/index/info',['id'=>xxx]) 时
    打印出来的是  /news/xxx.html
    
    
  • 'url_route_must'       => false//只有路由才可访问
    //启用后若未设置 则index/index/demo等失效
    	
    

请求和响应

请求对象获取 request

//3种获取request方式
public function index(Request $request)//方式1
{
    $request=request();   //方式2
    $request=Request::instance();   //方式3
    dump($request);
}

请求对象参数获取

request源文件地址:thinkphp\think\Request.php

变量类型方法包括:

方法 描述
param 获取当前请求的变量
get 获取 $_GET 变量
post 获取 $_POST 变量
put 获取 PUT 变量
delete 获取 DELETE 变量
session 获取 $_SESSION 变量
cookie 获取 $_COOKIE 变量
request 获取 $_REQUEST 变量
server 获取 $_SERVER 变量
env 获取 $_ENV 变量
route 获取 路由(包括PATHINFO) 变量
file 获取 $_FILES 变量

Request详细信息

//先定义一个对象,通过其调用方法
$request = Request::instance();
#获取浏览器输入框的值
dump($request->domain());
dump($request->pathinfo());
dump($request->path());


//路由信息
dump($request->route());
//调度信息
dump($request->dispatch());

#请求类型
dump($request->method());
dump($request->isGet());
dump($request->isPost());
dump($request->isAjax());

#请求的参数
dump($request->get());
dump($request->param());
dump($request->post());
dump($request->session());
dump($request->cookie());

dump($request->para('type'));
dump($request->cookie('mail'));

#模块   控制器   方法
dump($request->module());
dump($request->controller());
dump($request->action());

input助手函数

input 地址 thinkphp/helper.php

if (!function_exists('input')) {
    /**
     * 获取输入数据 支持默认值和过滤
     * @param string    $key 获取的变量名
     * @param mixed     $default 默认值
     * @param string    $filter 过滤方法
     * @return mixed
     */
    function input($key = '', $default = null, $filter = '')//通过接口传值
    {
        if (0 === strpos($key, '?')) {
            $key = substr($key, 1);
            $has = true;
        }
        if ($pos = strpos($key, '.')) {
            // 指定参数来源
            list($method, $key) = explode('.', $key, 2);//把$key分割为$method & $key $method为‘,’前
            if (!in_array($method, ['get', 'post', 'put', 'patch', 'delete', 'route', 'param', 'request', 'session', 'cookie', 'server', 'env', 'path', 'file'])) {
                $key    = $method . '.' . $key;
                $method = 'param';
            }
        } else {
            // 默认为自动判断
            $method = 'param';
        }
        
        if (isset($has)) {
            return request()->has($key, $method, $default);//有?执行has
        } else {
            return request()->$method($key, $default, $filter);//无?执行method
        }
    }
}

响应对象 Response

$data=[
    'code'   =>200,
    'result' =>[
        'userName' => 'wys',
        'userMail' => '3223905473@qq.com'
    ]
];
return dump($data);
//return $data  报错  不能直接return数组
return的默认输出格式为html
若要 return $data 的输出 需用Config::set('default_return_tpye','json')
把输出格式变成json、xml等


!!不推荐 可以建立相关文件的config 在里面修改输出格式

!!!推荐 如下代码方式

public function test($type='json')//该处可从url输入框内进行get取值
{
    if(!in_array($type,['json','xml','jsonp'])){$type='json';}  //判断文件类型合法性
    Config::set('default_return_type',$type);
    //改变文件输出格式

    $data=[
        'code'   =>200,
        'result' =>[
            'userName' => 'wys',
            'userMail' => '3223905473@qq.com'
        ]
    ];
    return $data;
}

 posted on 2021-01-26 19:07  夜深楼鼓  阅读(94)  评论(0编辑  收藏  举报