Cet article présente principalement l'instance d'ajout de session à Redis, présente la session en détail et fournit des exemples de code. Les amis dans le besoin peuvent se référer aux
Informations de session dans Redis
Introduction à la session
session, souvent traduite par conversation en chinois, sa signification originale fait référence à une série d'actions/messages qui ont un début et une fin, comme décrocher le téléphone lors d'un appel téléphonique La série de processus allant de la numérotation jusqu'au raccrochement peut être appelée une session. Parfois, nous pouvons voir des mots comme "Pendant une session de navigateur,..." Le mot session est ici utilisé dans son sens original, qui fait référence à la période allant de l'ouverture à la fermeture d'une fenêtre de navigateur①. La chose la plus déroutante est la phrase "l'utilisateur (client) pendant une session", qui peut faire référence à une série d'actions de l'utilisateur (généralement une série d'actions liées à un objectif spécifique, comme la connexion à l'achat de biens). . Le processus d'achat en ligne, du paiement à la déconnexion, est parfois appelé une transaction). Cependant, il peut parfois simplement faire référence à une connexion, ou à une signification ①. La différence ne peut être déduite que du contexte ②.
Pourquoi SESSION devrait-elle être enregistrée dans le cache
Le premier est de sauvegarder dans un fichier, l'efficacité est faible tant que la session est utilisée, l'ID de session spécifié sera recherché dans plusieurs fichiers. ce qui est très inefficace.
La seconde est que lorsque plusieurs serveurs sont utilisés, le problème de perte de session peut survenir (en fait elle est enregistrée sur d'autres serveurs).
Bien sûr, l'enregistrement dans le cache peut résoudre le problème ci-dessus. Si vous utilisez la propre fonction de session de PHP, vous pouvez utiliser la fonction session_set_save_handler() pour recontrôler facilement le processus de traitement de session. Si vous n'utilisez pas les fonctions de série de sessions de PHP, vous pouvez écrire vous-même une fonction de session similaire, ce qui est également possible. C'est le projet sur lequel je travaille actuellement. Il calculera le hachage en tant que sessionId en fonction du milieu et de l'utilisateur. heure de connexion. Chaque fois qu'il est demandé, le sessionId doit être ajouté pour être légal (il n'est pas nécessaire lors de la première connexion, le sessionId sera créé à ce moment-là et renvoyé au client). , concis et efficace. Bien sûr, ce dont je parle principalement dans cet article, c'est de « manipuler des choses » dans la propre SESSION de PHP.
SESSION est enregistrée dans le cache
<?php ini_set("session.save_handler", "redis"); ini_set("session.save_path", "tcp://localhost:6379"); session_start(); header("Content-type:text/html;charset=utf-8"); if(isset($_SESSION['view'])){ $_SESSION['view'] = $_SESSION['view'] + 1; }else{ $_SESSION['view'] = 1; } echo "【view】{$_SESSION['view']}"; //这里设置session.save_handler方式为redis,session.save_path为redis的地址和端口,设置之后刷新,再回头查看redis,会发现redis中的生成了sessionId,sessionId和浏览器请求的是一样的, //也可以使用 Session_set_save_handler(‘open','close',' read',' write',' destory',' gc'); //用法如下自定义一个Redis_session类 <?php class RedisSession{ private $_redis = array( 'handler' => null, //数据库连接句柄 'host' => null, //redis端口号 'port' => null, ); public function __construct($array = array()){ isset($array['host'])?$array['host']:"false"; isset($array['port'])?$array['host']:"false"; $this->_redis = array_merge($this->_redis, $array); } public function begin(){ //设置session处理函数 session_set_save_handler( array($this, 'open'), array($this, 'close'), array($this, 'read'), array($this, 'write'), array($this, 'destory'), array($this, 'gc') ); } public function open(){ $redis = new Redis(); $redis->connect($this->_redis['host'], $this->_redis['port']); if(!$redis){ return false; } $this->_redis['handler'] = $redis; $this->gc(null); return true; } //关 public function close(){ return $this->_redis['handler']->close(); } //读 public function read($session_id){ return $this->_redis['handler']->get($session_id); } //写 public function write($sessionId, $sessionData){ return $this->_redis['handler']->set($sessionId, $sessionData); } public function destory($sessionId){ return $this->_redis['handler']->delete($sessionId) >= 1 ? true : false; } public function gc(){ //获取所有sessionid,让过期的释放掉 $this->_redis['handler']->keys("*"); return true; } } $ses = new RedisSession(array('host'=>'127.0.0.1','port'=>'6379')); $ses->begin(); session_start(); $_SESSION['name']='zhangsan'; echo $_SESSION['name'];
À propos de la définition et de l'utilisation de la fonction php htmlentities()
À propos de l'utilisation d'openssl en PHP7. 1 Introduction au remplacement de mcrypt
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!