一直都是用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