dovgqc2648 2019-06-26 16:19
浏览 299
已采纳

unserialize():偏移量为1072个字节的错误

I'm building a codeigniter app with sql server.

I started the app with MySQL and it worked fine but then when I merged my table to sql server I got this error :

Message: unserialize(): Error at offset 10 of 672 bytes

Filename: core/MY_Controller.php

Line Number: 3

Here's my controller.php

 public function __construct() 
{
    parent::__construct();

    $group_data = array();
    if(empty($this->session->userdata('logged_in'))) {
        $session_data = array('logged_in' => FALSE);
        $this->session->set_userdata($session_data);
    }
    else {
        $user_id = $this->session->userdata('id');
        $this->load->model('model_groups');
        $group_data = $this->model_groups->getUserGroupByUserId($user_id);

        $this->data['user_permission'] = unserialize($group_data['permission']);

        $this->permission = unserialize($group_data['permission']);
    }
}
  • 写回答

1条回答 默认 最新

  • doupinge9055 2019-06-27 11:30
    关注

    I just used the preg_replace_callback function and it worked fine for me :

       $group_data['permission']=preg_replace_callback('!s:(\d+):"(.*?)";!', 
                function($match) {
                 return ($match[1] == strlen($match[2])) ? $match[0] : 's:' . strlen($match[2]) . ':"' . $match[2] . '";';},
                 $error_serialized_data);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?