Hướng dẫn nâng cấp 1.6
Vui lòng sao lưu trước khi nâng cấp và thực thi các lệnh sau
composer config -g --unset repos.packagist
composer require -W workerman/webman-framework ^v1.6.11
webman-framework phiên bản 1.6.0
Tính năng mới
Yêu cầu PHP>=8.0
Hỗ trợ lấy dữ liệu đầu vào qua tham số controller
<?php
namespace app\controller;
use support\Response;
class UserController
{
public function create(string $name, int $age, float $balance, bool $vip, array $extension): Response
{
return json([
'name' => $name,
'age' => $age,
'balance' => $balance,
'vip' => $vip,
'extension' => $extension,
]);
}
}
Truy cập /user/create?name=tom&age=18&balance=100.5&vip=1&extension[foo]=bar để nhận kết quả
{
"name": "tom",
"age": 18,
"balance": 100.5,
"vip": true,
"extension": {
"foo": "bar"
}
}
Tham số cũng hỗ trợ binding với lớp bao gồm model
<?php
namespace app\controller;
use app\model\User;
class UserController
{
public function create(User $user): int
{
$user->save();
return $user->id;
}
}
Xem Binding tham số controller
Hỗ trợ middleware controller
<?php
namespace app\controller;
use app\middleware\MiddlewareA;
use app\middleware\MiddlewareB;
use support\Request;
class IndexController
{
protected $middleware = [
MiddlewareA::class,
MiddlewareB::class,
];
public function index(Request $request): string
{
return 'hello';
}
}
Hỗ trợ Route::fallback()->middleware(...) cho yêu cầu 4xx
Bình thường yêu cầu 404 không qua middleware nào. Từ phiên bản 1.6.0 có thể thiết lập middleware cho yêu cầu 4xx
Route::fallback(function(){
return json(['code' => 404, 'msg' => '404 not found']);
})->middleware([
app\middleware\MiddlewareA::class,
app\middleware\MiddlewareB::class,
]);
Hỗ trợ Route::disableDefaultRoute()
Route::disableDefaultRoute();
Route::disableDefaultRoute('', 'admin');
Route::disableDefaultRoute('foo');
Route::disableDefaultRoute('foo', 'admin');
Route::disableDefaultRoute([\app\controller\IndexController::class, 'index']);
Hỗ trợ $request->setGet() $request->setPost() $request->setHeader()
$request->get(); // Giả sử ['name' => 'tom', 'age' => 18]
$request->setGet(['name' => 'tom']);
$request->get(); // Kết quả cuối ['name' => 'tom']
$request->setPost();
$request->setHeaders();
view() hỗ trợ bỏ tham số template và đường dẫn tuyệt đối
<?php
namespace app\controller;
use support\Request;
class UserController
{
public function hello(Request $request)
{
return view(['name' => 'webman']);
}
}
Các thay đổi cấu hình khác
Cấu hình listen của config/server.php đã chuyển sang config/process.php. Chỉ ảnh hưởng dự án mới.
Thư mục process đã chuyển sang app/process. Chỉ ảnh hưởng dự án mới.
Ghi chú nâng cấp
Nếu mã nguồn trước đó không chuẩn, có thể phát sinh vấn đề tương thích:
Kiểm tra sử dụng view()
Kiểm tra xem view() có dùng tham số template bắt đầu bằng / không. Nếu có thì bỏ / ở đầu
return view('/user/index');
// Đổi thành
return view('user/index');
Kiểm tra tính nhất quán tham số route tùy chỉnh
Route::any('/user/{name}', function (Request $request, $myname) {
return response($myname);
});
// Đổi thành
Route::any('/user/{name}', function (Request $request, $name) {
return response($name);
});
Lưu ý: Thêm type hint Request trước tham số $request.
Tắt proxy Composer
Các mirror Composer như Aliyun có độ trễ. Thực thi trước khi nâng cấp:
composer config -g --unset repos.packagist