路由分别对应(增删改查路由例子)
- 以
psr-2基础命名规则外,下面为实践中相关命名规则。 - 以
user为例, 路由和路由名称为小写复数按功能以.分开。 - 控制器按功能,列表为复数,其它单条担任可为单数驼峰命名。
- 序列化模型名为单数驼峰命名。
- 数据库模型以单数驼峰命名。
- 表名以复数命名。
下面为具体增删改查路由例子:
$route->get(\'/users\', \'users.index\', ListUsersController::class);
$route->get(\'/users/{id}\', \'users.resource\', ResourceUserController::class);
$route->post(\'/users\', \'users.create\', CreateUserController::class);
$route->patch(\'/users/{id}\', \'users.update\', UpdateUserController::class);
$route->delete(\'/users/{id}\', \'users.delete\', DeleteUserController::class);列表数据展示
继承 Discuz\\Api\\Controller\\AbstractListController 需要指定 $serializer 要用于序列化模型的 data 方法,并实现返回模型集合的方法。该 data 方法接收 Request 对象和 tobscure/json-api Document。
class ListUsersController extends AbstractListController
{
public $serializer = UserSerializer::class;
public function data(ServerRequestInterface $request, Document $document)
{
return User::all();
}
}单条数据展示
同列表数据一样继承 Discuz\\Api\\Controller\\AbstractResourceController 并实现相关属性和方法,接收参数一样。
class ResourceUserController extends AbstractResourceController
{
public $serializer = UserSerializer::class;
public function data(ServerRequestInterface $request, Document $document)
{
$body = $request->getQueryParams();
$id = $body->get(\'id\');
return User::findOrFail($id);
}
}创建数据(增加数据,新增数据)
继承 Discuz\\Api\\Controller\\AbstractCreateController。这与单条数据相同,但响应状态代码将自动设置为 201 Created。您可以通过以下方式访问传入的 JSON:API POST传过来的数据可通过 $request->getParsedBody() 来取到 json 数组,并通过 Laravel Arr 类来获取数组相关信息。
class CreateUserController extends AbstractCreateController
{
public $serializer = UserSerializer::class;
public function data(ServerRequestInterface $request, Document $document)
{
$attributes = Arr::get($request->getParsedBody(), \'data.attributes\');
return User::create([
\'name\' => Arr::get($attributes, \'name\')
]);
}
}更新数据
继承 Discuz\\Api\\Controller\\AbstractResourceController 同单条数据一样,现相关属性和方法,接收参数一样,返回相关数据,获取同创建数据一样。
class UpdateUserController extends AbstractCreateController
{
public $serializer = UserSerializer::class;
public function data(ServerRequestInterface $request, Document $document)
{
$attributes = Arr::get($request->getParsedBody(), \'data.attributes\', []);
$body = $request->getQueryParams();
$attributes = $body->get(\'id\');
$user = User::findOrFail($id);
$user->name = $attributes[\'name\'];
$user->save();
return $user;
}
}删除数据
继承 Discuz\\Api\\Controller\\AbstractDeleteController 实现 delete 方法,该方法接收 Request,默认返回空 204 No Content 响应。
class DeleteUserController extends AbstractDeleteController
public function delete(ServerRequestInterface $request)
{
$id = Arr::get($request->getQueryParams(), \'id\');
User::findOrFail($id)->delete();
}
}序列化模型说明
继承 Discuz\\Api\\Serializer\\AbstractSerializer 实现 getDefaultAttributes 方法,该方法接收数据库模型,写好 type 属性
class UserSerializer extends AbstractSerializer
{
protected $type = \'user\';
public function getDefaultAttributes($model)
{
return [
\'id\' => $model->id,
\'username\' => $model->username,
\'email\' => $model->email
];
}
}自定义返回类型
实现接口 Psr\\Http\\Server\\RequestHandlerInterface
<?php
namespace Discuz\\Api\\Controller;
use Psr\\Http\\Server\\RequestHandlerInterface;
class AbstractSerializeController implements RequestHandlerInterface
{
public function handle(ServerRequestInterface $request): ResponseInterface
{
return new HtmlResponse();
}
}本站除原创内容,其余内容均收集自互联网,仅限用于学习和研究目的,本站不对其内容的合法性、可用性承担任何责任。本站禁止以任何形式发布或转载任何违法相关信息,若您发现请立即向站长举报;用户投稿一切资源内容不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
如有版权内容,其版权均归原作者所有,本站虽力求保存原有版权信息,但因众多资源经多次转载,已无法确定其真实来源,故敬请原作者谅解!为尊重作者劳动成果,请购买正版支持作者,谢谢!若您对「HULIKU.COM」所载资源作品版权归属存有异议,请发送邮箱:ihuliku@qq.com 进行处理。
本站资源文件大多存储至云盘,如您发现图片或链接失效,请联系站长或作者,我们将及时进行更新。资源都是经过站长或作者收集测试优化后进行发布分享。如若转载请在贵站文内以超链形式注明狐狸库文章出处,谢谢合作!













![WordPress子比主题美化教程合集[2023/04/17]-狐狸库](https://huliku.com/pic/2023032607024935.png)
![狐狸库自定义子比主题底部footer页脚美化(自适应)[06.26]更新-狐狸库](https://huliku.com/pic/2023062610013835.png)




















请登录后查看评论内容