php - Laravel 5 : ErrorException in LengthAwarePaginator. php:除以零

标签 php jquery laravel laravel-5 laravel-5.1

我有一个带有 per_page 输入字段的评论列表,允许用户通过 ajax 在页面上显示更多评论。默认情况下,它设置为 50

但是当我尝试更改它时,例如更改为 25,我在开发人员控制台中收到此错误

POST http://localhost/r2/public/posts/per_page 500 (Internal Server Error)

网络选项卡中,我可以看到此错误

ErrorException in LengthAwarePaginator.php line 48:

Division by zero

in LengthAwarePaginator.php line 48

at HandleExceptions->handleError('2', 'Division by zero', 'C:\xampp\htdocs\r2\vendor\laravel\framework\src\Illuminate\Pagination\LengthAwarePaginator.php', '48', array('items' => array(), 'total' => '0', 'perPage' => null, 'currentPage' => '1', 'options' => array('path' => 'http://localhost/r2/public/posts/per_page', 'query' => array()), 'key' => 'query', 'value' => array())) in LengthAwarePaginator.php line 48

at LengthAwarePaginator->__construct(array(), '0', null, '1', array('path' => 'http://localhost/r2/public/posts/per_page', 'query' => array())) in CommentController.php line 51

at CommentController->paginate(array(), null, object(Request), object(Post)) in CommentController.php line 57

at CommentController->comment_list(null, object(Request), object(Post)) in CommentController.php line 153

at CommentController->show_comment_list(object(Request), object(Post)) in CommentController.php line 164

at CommentController->per_page(object(Request), object(Post), 'posts')

在我更改其路线以将其与帖子页面集成之前,它工作正常。

我的路线

Route::get('{post}/comment', ['as' => 'comment', 'uses' => 'CommentController@index']);
Route::post('{post}/post_this_comment', 'CommentController@post_this_comment');
Route::get('{post}/recaptcha', 'CommentController@recaptcha');
Route::get('{post}/reply_comment', 'CommentController@reply_comment');

// this is the per_page route
Route::post('{post}/per_page', ['as' => 'per_page', 'uses' => 'CommentController@per_page']);

Route::post('{post}/comment/update', ['as' => 'comment/update', 'uses' => 'CommentController@update']);

这是CommentController

private function paginate($items, $perPage, Request $request) {
    $page = Input::get('page', 1); // get current page or default to 1
    $offset = ($page * $perPage) - $perPage;
    return new LengthAwarePaginator(
        array_slice($items, $offset, $perPage, false),
        count($items),
        $perPage,
        $page,
        ['path' => $request->url(), 'query' => $request->query()]);
}

protected function comment_list($per_page, Request $request, Post $post) {
    $root_comments = Comment::root_comments($post->id);
    $root_with_replies = $this->include_replies_for($root_comments);
    $paginated_comments = $this->paginate($root_with_replies, $per_page, $request, $post);
    return $paginated_comments;
}

protected function show_comment_list(Request $request, Post $post) {
    $per_page = Input::get('per_page');
    session(['per_page' => $per_page]);
    $comment_list = view('eastgate.comment.comment_list')
                        ->with('comments', $this->comment_list($per_page, $request, $post))
                        ->with('total_comments', $this->total_comments())
                        ->with('per_page', $per_page)
                        ->render();
    return $comment_list;       
}

public function per_page(Request $request, Post $post){
    $response = array(
        'status' => 'success',
        'msg'   => 'reply comment',
        'comment_list' => $this->show_comment_list($request, $post)
    );
    return Response::json($response);       
}

这是 JS 和 HTML

$(document).on('change', 'input.comments_per_page', function(){
    var formData = new FormData();
    formData.append('per_page', $('.comments_per_page').val());
    var request = $.ajax({ // push question data to server
        type        : 'POST', // define the type of HTTP verb we want to use (POST for our form)
        url         : 'per_page', // the url where we want to POST
        data        : formData, 
        dataType    : 'json',
        processData : false,
        contentType : false
    });
    request.done(per_page_done_handler);
    request.fail(per_page_fail_handler); // fail promise callback   
});

<div class="col-xs-12">
    Show <input type="text" name="comments_per_page" class="comments_per_page" value="{!! $per_page !!}" size="2" title="Number of comments per page"> comments per page
</div>

更新

我应该提到的是,我还可以看到 laravel 的默认分页 div,当我单击 URL 为 http://localhost/r2/public/posts/2/?page 的第二页时=2 页面重定向到 http://localhost/posts/2?page=2 并且我收到此错误

ERROR 404 Object not found!

但是如果我手动转到此 URL http://localhost/r2/public/posts/2?page=2

带有评论的第二页加载得很好。

更新2

我只是在 comment_list() 方法中的 $pagination_commentssetPath ,现在下一页可以正常打开。但当我尝试更改显示的评论数量时,仍然出现除以零错误。

$paginated_comments = $this->paginate($root_with_replies, $per_page, $request, $post);
$paginated_comments->setPath('');

最佳答案

每页数(50 或 25)并不重要。如果您查看 \vendor\laravel\framework\src\Illuminate\Pagination\LengthAwarePaginator.php,您可以看到您的问题行(它会抛出异常除以零):

$this->lastPage = (int) ceil($total / $perPage); // <= problem

这仅意味着一件事 - $perPage 为 0 或 null => 您没有将 per_page (25) 的预期值传递给 LengthAwarePaginator 构造函数。您需要在顺序方法中检查 var per_page 语句 per_page() => show_comment_list() => comment_list() => 分页()

附注恕我直言,它应该是一个分页操作。您拥有制作它所需的所有信息,但是,您将其分为四个“部分”。

关于php - Laravel 5 : ErrorException in LengthAwarePaginator. php:除以零,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33324774/

相关文章:

laravel - 检索多态关系 laravel 的所有者

php - PHP : Error handling without throwing an exception

php - 有效函数显示无效

php - 如何每 30 秒从服务器执行一次脚本 - apache

jquery - 来自 jquery ajax 的 d3js 饼图 - 关联图表上的 json 键和值

php - laravel 5 Controller 中的 CSV 导出

php - 如何在 Laravel 中基于 application/json header 加载路由

php - 在 Jquery 中设置 Codeigniter session

jquery - 在等待 getJSON 时显示加载 gif

laravel - "The page does not redirect correctly"拉维