Codeigniter

Como salvar a sessão no Banco de Dados – Codeigniter

Como alterar as configurações do framework Codeigniter para salvar as sessões no Banco de Dados.

Criando as tabelas.

Se você deseja salvar as sessões no Banco de Dados geradas pelo Codeigniter , o primeiro passo deverá ser de criar a tabela.

Para cada versão do framework, existe uma estrutura especifica.

Para Codeigniter 3.X

Utilize esta estrutura:

 CREATE TABLE IF NOT EXISTS `ci_sessions` (
    `id` varchar(40) NOT NULL,
    `ip_address` varchar(45) NOT NULL,
    `timestamp` int(10) unsigned DEFAULT 0 NOT NULL,
    `data` blob NOT NULL,
    PRIMARY KEY (id),
    KEY `ci_sessions_timestamp` (`timestamp`)
);

Para a versão 2.X

CREATE TABLE IF NOT EXISTS  `ci_sessions` (
 session_id varchar(40) DEFAULT '0' NOT NULL,
 ip_address varchar(45) DEFAULT '0' NOT NULL,
 user_agent varchar(120) NOT NULL,
 last_activity int(10) unsigned DEFAULT 0 NOT NULL,
 user_data text NOT NULL,
 PRIMARY KEY (session_id),
 KEY `last_activity_idx` (`last_activity`)
);

Observação: Repare que as tabelas são diferentes para cada versão do Codeigniter.

Crie a tabela de acordo com a versão que você está utilizando.

Alterando as configurações

Agora vamos alterar as configurações do framework para ele passar a salvar os dados no banco.

Edite o  seguinte arquivo: application/config/config.php

Altere as configurações de sessão substituindo por este valores.

$config['sess_driver'] = 'database';
$config['sess_cookie_name'] = 'ci_sessions';
$config['sess_expiration'] = 7200;
$config['sess_save_path'] = 'ci_sessions';
$config['sess_match_ip'] = FALSE;
$config['sess_time_to_update'] = 300;

Repare no “$config[‘sess_driver’]” aonde estou informando que o “driver” utilizado será o banco de dados “database”.

Já no “$config[‘sess_save_path’]” está o nome da tabela que criamos.

Não se esqueça de configurar também o arquivo “application/config/autoload.php” para carregar a biblioteca da sessão:

$this->load->library('session');

 

Resumo
Nome do Artigo
Como salvar as sessões no Codeigniter diretamente no banco de dados
Descrição
Como alterar as configurações do Codeinigter para ele passar a salvar as sessões no banco de dados em uma tabela especifica
Autor
Editor
Roger Mauricio Takemiya
Logo do Editor

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás