sql >> Base de Datos >  >> NoSQL >> Redis

Compartir sesiones entre php y nodo.

Para nodo (y Express 4.x):

Comience con el ejemplo de express-session, pero use connect-redis como su tienda de sesión en su lugar.

Código de ejemplo:

var express = require('express'),
    app = express(),
    cookieParser = require('cookie-parser'),
    session = require('express-session'),
    RedisStore = require('connect-redis')(session);

app.use(express.static(__dirname + '/public'));
app.use(function(req, res, next) {
  if (req.url.indexOf('favicon') > -1)
    return res.send(404);
  next();
});
app.use(cookieParser());
app.use(session({
  store: new RedisStore({
    // this is the default prefix used by redis-session-php
    prefix: 'session:php:'
  }),
  // use the default PHP session cookie name
  name: 'PHPSESSID',
  secret: 'node.js rules'
}));
app.use(function(req, res, next) {
  req.session.nodejs = 'Hello from node.js!';
  res.send(JSON.stringify(req.session, null, '  '));
});

app.listen(8080);

Para PHP:

Use un controlador de sesión redis como redis-session-php.

Código de ejemplo:

<?php

// from https://github.com/TheDeveloper/redis-session-php
require('redis-session-php/redis-session.php');
RedisSession::start();

$_SESSION["php"] = "Hello from PHP";

// `cookie` is needed by express-session to store information
// about the session cookie
if (!isset($_SESSION["cookie"]))
  $_SESSION["cookie"] = array();

var_dump($_SESSION);

?>

Nota:asegúrese de usar el mismo prefix (conectar-redis)/REDIS_SESSION_PREFIX (redis-session-php) (connect-redis usa 'sess:' y redis-session-php usa 'session:php:' por defecto) y ttl (conectar-redis)/session.gc_maxlifetime (PHP) (y la misma base de datos si está utilizando una base de datos redis que no sea la predeterminada) tanto para redis-session-php como para connect-redis.