一直都是用laravel 7 左右的,现在要求将项目升级到laravel 11 和使用PHP8,随手记录一些小问题,laravel 11的包是领导给的,没有使用composer 安装,所以我也不确定和官方的是否一致
遇到这问题

可以这样

env 中默认的数据库驱动是 SESSION_DRIVER=sqlite 的,根据情况,我修改成mysql
session 的驱动 默认是 database 的,需要在数据库中,创建一个sessions 的表,如果想使用 数据库来保存session,而又没有这个表的,可以这样:
php artisan session:table
php artisan migrate如果想使用传统的,使用file 来保存session 的话,可以修改
\config\session.php,
'driver' => env('SESSION_DRIVER', 'file'),mysql 的 默认字符编码是 utf8mb4_0900_ai_ci,如果使用低版本的 mysql ,会提示错误的,修改方法
config\database.php
        'mysql' => [
            'driver' => 'mysql',
            'url' => env('DB_URL'),
            'host' => env('DB_HOST', '127.0.0.1'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'laravel'),
            'username' => env('DB_USERNAME', 'root'),
            'password' => env('DB_PASSWORD', ''),
            'unix_socket' => env('DB_SOCKET', ''),
            'charset' => env('DB_CHARSET', 'utf8mb4'),
            'collation' => env('DB_COLLATION', 'utf8mb4_unicode_ci'),//修改此字符编码
            'prefix' => '',
            'prefix_indexes' => true,
            'strict' => true,
            'engine' => null,
            'options' => extension_loaded('pdo_mysql') ? array_filter([
                PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'),
            ]) : [],
        ],使用自定义的方法
./composer.json
    "autoload": {
        "psr-4": {
            "App\\": "app/",
            "Database\\Factories\\": "database/factories/",
            "Database\\Seeders\\": "database/seeders/"
        },
        //新增代码段
        "files": [
            "app/Common/function.php"
        ]
    },执行这命令
composer dump-autoload初始没有api.php,需要执行
php artisan install:api


















