您不能序列化或反序列化 PDO 实例 CakePHP



我的 cakephp 有问题,我不知道如何解决,我试图更新供应商,但错误仍然存在。

错误.log

错误: [PDOException] 无法序列化或反序列化 PDO 实例 请求网址:/堆栈跟踪: #0 [内部函数]: PDO->__sleep() #1 vendor/cakephp/cakephp/src/Cache/Engine/FileEngine.php(148): serialize(Object(Cake\ORM\Query)) #2 vendor/cakephp/cakephp/src/Cache/Cache.php(239): Cake\Cache\Engine\FileEngine->write('cake_views_post...', Object(Cake\ORM\Query)) #3 src/Controller/PostsController.php(494): Cake\Cache\Cache::write('ViewsPosts', Object(Cake\ORM\Query)) #4 src/Controller/PostsController.php(57): App\Controller\PostsController->getPostsSidebar() #5 vendor/cakephp/cakephp/src/Controller/Controller.php(262): App\Controller\PostsController->initialize() #6 [内部函数]:蛋糕\控制器\控制器->__construct(对象(蛋糕\网络\请求),对象(蛋糕\网络\响应),"帖子") #7 vendor/cakephp/cakephp/src/Http/ControllerFactory.php(79): ReflectionClass->newInstance(Object(Cake\Network\Request), Object(Cake\Network\Response), 'Posts') #8 vendor/cakephp/cakephp/src/Http/ActionDispatcher.php(93): Cake\Http\ControllerFactory->create(Object(Cake\Network\Request), Object(Cake\Network\Response)) #9 vendor/cakephp/cakephp/src/Http/BaseApplication.php(83): Cake\Http\ActionDispatcher->dispatch(Object(Cake\Network\Request), Object(Cake\Network\Response)) #10 vendor/cakephp/cakephp/src/Http/Runner.php(65): Cake\Http\BaseApplication->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response), Object(Cake\Http\Runner)) #11 vendor/cakephp/cakephp/src/Routing/Middleware/RoutingMiddleware.php(62): Cake\Http\Runner->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response)) #12 vendor/cakephp/cakephp/src/Http/Runner.php(65): Cake\Routing\Middleware\RoutingMiddleware->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response), Object(Cake\Http\Runner)) #13 vendor/cakephp/cakephp/src/Routing/Middleware/AssetMiddleware.php(88): Cake\Http\Runner->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response)) #14 vendor/cakephp/cakephp/src/Http/Runner.php(65): Cake\Routing\Middleware\AssetMiddleware->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response), Object(Cake\Http\Runner)) #15 vendor/cakephp/cakephp/src/Error/Middleware/ErrorHandlerMiddleware.php(81): Cake\Http\Runner->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response)) #16 vendor/cakephp/cakephp/src/Http/Runner.php(65): Cake\Error\Middleware\ErrorHandlerMiddleware->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response), Object(Cake\Http\Runner)) #17 vendor/cakephp/cakephp/src/Http/Runner.php(51): Cake\Http\Runner->__invoke(Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response)) #18 vendor/cakephp/cakephp/src/Http/Server.php(92): Cake\Http\Runner->run(Object(Cake\Http\MiddlewareQueue), Object(Zend\Diactoros\ServerRequest), Object(Zend\Diactoros\Response)) #19 webroot/index.php(37): Cake\Http\Server->run() #20 {主要}

作曲家表演

$ 作曲家表演 光环/安装程序默认 1.0.0 光环/国际 1.1.1 蛋糕/烘焙 1.2.8 Cakephp/Cakephp 3.3.7 蛋糕/克罗诺斯 1.0.0 蛋糕/debug_kit 3.3.7 Cakephp/migrations 1.6.3 Cakephp/plugin-installer 0.0.15 DNOEGEL/PHP-xdg-base-dir 0.1 Jakub-onderka/php-console-color 0.1    Jakub-onderka/php-console-highlight v0.3.2 jdorn/sql-formatter v1.2.17 移动侦测/移动侦测库 2.8.22 用户代理链... nikic/php-parser v2.1.1 PSR/http-message 1.0.1 PSR/日志 1.0.0 PSY/PSYSH v0.7.2 罗摩根/芬克斯 v0.5.3 symfony/config v3.1.6 symfony/console v3.1.6 symfony/debug v3.1.6 symfony/filesystem v3.1.6 symfony/polyfill-mbstring v1.2.0 symfony/var-dumper v3.1.6 Symfony/yaml v3.1.6 zendframework/zend-diactoros 1.3.7

EDIT

src/Controller/PostsController.php

if (($ViewsPosts = Cache::read('ViewsPosts')) === false) {
$ViewsPosts = TableRegistry::get('ViewsPosts')->find('all')
->select([
'count' => 'COUNT(*)',
'Posts.created',
'Posts.id',
])
->contain([
'Posts'
])
->where([
'Posts.status'        => 'published',
'Posts.created >=' => new DateTime('-7 days')
])
->group(['posts_id'])
->order(['count' => 'desc'])
->limit(5);
Cache::write('ViewsPosts', $ViewsPosts); /// line 494
}

固定电话

- Cache::write('ViewsPosts', $ViewsPosts);
+ Cache::write('ViewsPosts', $ViewsPosts->toArray());

您的错误是由以下文件引起的:

src/Controller/PostsController.php494号线

您正在调用CakeCacheCache::write('ViewsPosts', Object(CakeORMQuery))但它不喜欢这样,因为您无法序列化 Cake\ORM\Query(这可能称为$results或其他什么,所以您需要这样做而不是这样做。

$results->cache('ViewPosts');将为您缓存结果。您可以从 CakePHP 网站获取有关此内容的更多信息

缓存加载的结果 - 下面也包含的内容。

缓存加载的结果

获取不经常更改的实体时,您可能需要缓存结果。Query 类使这变得简单:

$query->cache('recent_articles');

将对查询的结果集启用缓存。如果只向 cache() 提供一个参数,则将使用"默认"缓存配置。您可以控制将哪个缓存配置与第二个参数一起使用:

// String config name.
$query->cache('recent_articles', 'dbResults');
// Instance of CacheEngine
$query->cache('recent_articles', $memcache);

除了支持静态键之外,cache() 方法还接受一个函数来生成键。您为其提供的函数将接收查询作为参数。然后,您可以读取查询的各个方面以动态生成缓存键:

// Generate a key based on a simple checksum
// of the query's where clause
$query->cache(function ($q) {
return 'articles-' . md5(serialize($q->clause('where')));
});

缓存方法使将缓存结果添加到自定义查找器或通过事件侦听器添加变得简单。

提取缓存查询的结果时,将发生以下情况:

  1. 将触发 Model.beforeFind 事件。
  2. 如果查询设置了结果,则将返回这些结果。
  3. 将解析缓存键并读取缓存数据。如果缓存数据不为空,则将返回这些结果。
  4. 如果缓存未命中,将执行查询并创建新的结果集。此结果集将写入缓存并返回。

无法缓存流式处理查询结果。

最新更新