세션에 redis를 추가하는 구현에 대해

不言
풀어 주다: 2023-04-02 08:54:01
원래의
1441명이 탐색했습니다.

이 글은 주로 redis에 세션을 추가하는 사례를 소개하고, 세션을 자세히 소개하며, 코드 예시도 함께 제공하고 있으니 필요하신 분들은 참고하시면 됩니다.

redis에 대한 세션 정보

세션 소개

session, 중국어 자주 대화로 번역하면 원래 의미는 시작과 끝이 있는 일련의 동작/메시지를 의미합니다. 예를 들어 전화를 걸 때 전화를 받고 전화를 걸고 끊는 일련의 과정을 의미합니다. 세션을 불렀습니다. 가끔 "브라우저 세션 중..."과 같은 단어를 볼 수 있습니다. 여기서 세션이라는 단어는 원래 의미로 사용되며, 브라우저 창을 열 때부터 닫힐 때까지의 기간을 나타냅니다①. 가장 헷갈리는 것은 "세션 중 사용자(클라이언트)"라는 문장으로, 이는 사용자의 일련의 행위(일반적으로 로그인부터 상품 구매까지 특정 목적과 관련된 일련의 행위)를 의미할 수 있습니다. .결제부터 로그아웃까지의 온라인 쇼핑 과정을 트랜잭션이라고 부르기도 합니다. 그러나 때로는 단순히 연결을 의미할 수도 있고, ①의 의미를 의미할 수도 있습니다.

이 기사에서는 중국어 "브라우저 세션 기간"을 사용하여 ①의 의미를 표현하고, "세션 메커니즘"을 사용하여 ④의 의미를 표현하고, "세션"을 사용하여 ⑤의 의미를 표현하며, 구체적인 6


SESSION을 캐시에 저장해야 하는 이유

PHP의 경우 언어 자체에서 지원하는 세션은 HttpSession이라는 의미를 디스크 파일에 저장하는 형태로 저장됩니다. 파일로 저장되며 지정된 폴더에 저장됩니다. 설정 파일에 저장하거나 프로그램에서 session_save_path() 함수를 사용하여 설정할 수 있지만, 먼저 파일 시스템에 저장해야 한다는 단점이 있습니다. 이는 비효율적입니다. 세션을 사용하는 한 지정된 sessionid가 여러 파일에서 검색되므로 매우 효율적입니다.

두 번째는 여러 서버를 사용할 경우 세션이 손실되는 문제가 발생할 수 있다는 점입니다(실제로는 다른 서버에 저장되어 있습니다).
물론 캐시에 저장하면 위의 문제를 해결할 수 있습니다. PHP 자체 세션 함수를 사용하는 경우 session_set_save_handler() 함수를 사용하면 세션 처리 프로세스를 쉽게 다시 제어할 수 있습니다. PHP의 세션 시리즈 함수를 사용하지 않는다면 비슷한 세션 함수를 직접 작성하는 것도 가능합니다. 이것은 제가 지금 작업하고 있는 프로젝트입니다. 로그인할 때마다 sessionId를 추가해야 합법적입니다(처음 로그인할 때는 필요하지 않으며 이때 sessionId가 생성되어 클라이언트에 반환됩니다). , 간결하고 효율적입니다. 물론, 내가 이 글에서 주로 이야기하고 있는 것은 PHP 자체 SESSION에서의 "사물 조작"이다.


SESSION은 캐시에 저장됩니다


php는 캐시를 redis에 저장합니다. 구성 파일을 사용하여 세션 처리 및 저장을 수정할 수 있습니다. 물론 ini_set() 함수를 사용할 수도 있습니다. 물론, 프로덕션 환경이라면 구성 파일을 사용하는 것이 좋습니다.

단순히 Redis에서 세션을 운영하고 싶다면 다음 코드를 실행하면 됩니다

<?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[&#39;view&#39;])){ 
 
  $_SESSION[&#39;view&#39;] = $_SESSION[&#39;view&#39;] + 1; 
 
}else{ 
 
  $_SESSION[&#39;view&#39;] = 1; 
 
} 
 
echo "【view】{$_SESSION[&#39;view&#39;]}"; 
 
//这里设置session.save_handler方式为redis,session.save_path为redis的地址和端口,设置之后刷新,再回头查看redis,会发现redis中的生成了sessionId,sessionId和浏览器请求的是一样的, 
 
  
 
//也可以使用 
 
Session_set_save_handler(‘open&#39;,&#39;close&#39;,&#39; read&#39;,&#39; write&#39;,&#39; destory&#39;,&#39; gc&#39;); 
 
//用法如下自定义一个Redis_session类 
 
<?php 
 
class RedisSession{ 
 
  private $_redis = array( 
 
    &#39;handler&#39; => null, //数据库连接句柄 
 
    &#39;host&#39; => null,  //redis端口号 
 
    &#39;port&#39; => null, 
 
  ); 
 
  public function __construct($array = array()){ 
 
    isset($array[&#39;host&#39;])?$array[&#39;host&#39;]:"false"; 
 
    isset($array[&#39;port&#39;])?$array[&#39;host&#39;]:"false"; 
 
    $this->_redis = array_merge($this->_redis, $array); 
 
  } 
 
  public function begin(){ 
 
    //设置session处理函数 
 
    session_set_save_handler( 
 
      array($this, &#39;open&#39;), 
 
      array($this, &#39;close&#39;), 
 
      array($this, &#39;read&#39;), 
 
      array($this, &#39;write&#39;), 
 
      array($this, &#39;destory&#39;), 
 
      array($this, &#39;gc&#39;) 
 
    ); 
 
  } 
 
  public function open(){ 
 
    $redis = new Redis(); 
 
    $redis->connect($this->_redis[&#39;host&#39;], $this->_redis[&#39;port&#39;]); 
 
    if(!$redis){ 
 
      return false; 
 
    } 
 
  
 
    $this->_redis[&#39;handler&#39;] = $redis; 
 
    $this->gc(null); 
 
    return true; 
 
  } 
 
  //关 
 
  public function close(){ 
 
    return $this->_redis[&#39;handler&#39;]->close(); 
 
  } 
 
  //读 
 
  public function read($session_id){ 
 
    return $this->_redis[&#39;handler&#39;]->get($session_id); 
 
  } 
 
  //写 
 
  public function write($sessionId, $sessionData){ 
 
    return $this->_redis[&#39;handler&#39;]->set($sessionId, $sessionData); 
 
  } 
 
  public function destory($sessionId){ 
 
    return $this->_redis[&#39;handler&#39;]->delete($sessionId) >= 1 ? true : false; 
 
  } 
 
  public function gc(){ 
 
    //获取所有sessionid,让过期的释放掉 
 
    $this->_redis[&#39;handler&#39;]->keys("*"); 
 
    return true; 
 
  } 
 
} 
 
$ses = new RedisSession(array(&#39;host&#39;=>&#39;127.0.0.1&#39;,&#39;port&#39;=>&#39;6379&#39;)); 
 
$ses->begin(); 
 
session_start(); 
 
$_SESSION[&#39;name&#39;]=&#39;zhangsan&#39;; 
 
echo $_SESSION[&#39;name&#39;];
로그인 후 복사

이렇게 Redis 코드 실행 시 redis 등의 세션 데이터가 설치되어 있어야 합니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 권장 사항:

php htmlentities() 함수의 정의 및 사용법에 대하여


PHP7.1에서 mcrypt를 대체하기 위해 openssl을 사용하는 방법 소개


위 내용은 세션에 redis를 추가하는 구현에 대해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿