2

我有以下事件控制器:

public $paginate = [
    'sortWhitelist' => ['title', 'id', 'price', 'date', 'Categories.description'],
    'order'         => ['date' => 'desc']
];

和一个索引方法:

$events = $this->Events->find()->contain(['Categories']);
$this->set('events', $this->paginate($events));

在我的视图文件中,我有一张桌子echo $this->Paginator->sort('id', 'code')和一个

echo $this->Paginator->numbers([
    'separator' => '',
    'currentTag' => 'a',
    'modulus' => 25,
    'currentClass' => 'active',
    'tag' => 'li',
    'first' => 1
]);

如果我转到页面/events,我会得到预期的结果。如果我按 id 排序并单击第 2 页,则会显示 url events?page=2&sort=Events.id&direction=asc,结果不正确。

我看到 sql 日志并没有出现 order by 子句。如果我在没有模型的情况下手动编辑 url:events?page=2&sort=id&direction=asc结果是正确的。

我做错了什么还是一个错误?

谢谢

4

1 回答 1

1

排序字段不在您的白名单中。

一旦您配置了sortWhitelist分页器组件,就会拒绝所有其他排序参数。

分页器组件理解sort=id查询参数,并假设您指的是分页的默认模型,但助手遵循排序参数的命名约定。其中包括型号名称。该sort=id参数有效,因为id它在您的白名单中。

所以你必须包括EventssortWhitelist

public $paginate = [
    'sortWhitelist' => ['Events.title', 'Events.id', 'Events.price', 'Events.date', 'Categories.description'],
    'order' => ['Events.date' => 'desc']
];
于 2017-12-18T22:54:42.373 回答