PHP中service层怎么设计兼顾优雅和方便?

比如我的列表页,因为查询参数比较多,查询条件也多,排序方式也比较多。
之前是把http的request查询参数通过数组传到service 但是发现很多不方便,比如我上传 比如我列表搜索页。
直接在service里调用request,这样感觉方便的多。

比如之前这样的:

$userList = $this->userService->getList($request->input(), 10);

现在改成这样

$userList = $this->userService->getList(10);

阅读 11k
4 个回答

这两种其实都不好,因为不能直接从Service的接口(或函数签名)看出它需要的参数。

对于参数很多的方法,可以用对象表示参数,控制器根据Request封装得到对象(对象也可以提供一个fromRequest方法)再传给Service。

补充个例子,UserServicegetList可以这样定义:

public function getList(UserCriteria criteria, $limit = 10, $offset = 0) {
  ...
}

看函数签名就可以知道第一个参数是UserCriteria,后面的$limit$offset是分页用的,也可以再封装成一个类,但是没必要。

其中的UserCriteria就是查找和筛选用户的条件:

class UserCriteria
{
    public $name;
     
    public $age;
    
    // ... 很多其他参数
    
    
    public static function fromRequest(Request $req)
    {
        $instance = new static;
        $instance->name = $req->input('name');
        // ... 很多其他参数
        return $instance;
    }
}

在控制器调用:

public function index(Request $req)
{
    $criteria = UserCriteria::fromRequest($req);
    $userList = $this->userService->getList($criteria, 10);
    // ...
}

好处:

  1. 明确的类型(IDE还能自动补全)

  2. 隔离HTTP请求

但是耦合度会不会比较高呢?

不要紧的,你看laravel的分页不也是直接从Request获取参数吗。并不会有问题啊。 :)

用queryscope
结合模板方法

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题