>  기사  >  백엔드 개발  >  PHP의 Session ID 구현 원리 분석

PHP의 Session ID 구현 원리 분석

王林
王林원래의
2019-11-08 10:56:563102검색

PHP의 Session ID 구현 원리 분석

세션 작동 메커니즘:

각 방문자에 대해 고유한 만들기 id(UID)를 생성하고 이 UID를 기반으로 변수를 저장합니다. UID는 쿠키에 저장되거나 URL을 통해 전달됩니다.

PHPSESSIONID 제작 알고리즘 원리:

1, hash_func = md5 / sha1 #php.ini로 구성 가능

#🎜 🎜 #2. PHPSESSIONID = hash_func (클라이언트 IP + 현재 시간(초) + 현재 시간(마이크로초) + PHP 자체 난수 생성기)

위의 hash_func(*) 데이터에서 샘플링 값 내용 분석 동일한 서버에서 여러 사용자가 생성한 PHPSESSIONID가 중복될 확률은 극히 낮다는 것을 보여줍니다.

또한 해커가 사용자의 PHPSESSIONID를 추측하려면 "클라이언트 IP, 현재 시간(초, 마이크로초), 난수" 및 기타 데이터도 알아야 시뮬레이션할 수 있습니다.

php.ini 구성은 다음과 같습니다:

; Select a hash function for use in generating session ids.
; Possible Values
;  0 (MD5 128 bits)
;  1 (SHA-1 160 bits)
; This option may also be set to the name of any hash function supported by
; the hash extension. A list of available hashes is returned by the hash_algos()
; function.
; http://php.net/session.hash-function
session.hash_function=0

PHP 세션 작동 원리# 🎜🎜 # 다음은 쿠키를 사용하여 PHPSESSID 설명을 전송합니다.

1 클라이언트가 PHP 서버 주소를 요청합니다.

2. 이번에는 PHP 스크립트에 session_start()가 포함되어 있습니다.

3. 서버가 PHPSESSID를 생성합니다. (기본 세션 저장 방식은 session.save_handler=files로 파일 형태로 저장됩니다. 생성된 세션 파일 이름 규칙은 sess_PHPSESSID이며 세션 파일이 존재합니다. session.save_path )<code>session_start()

3、服务端会生成一个PHPSESSID。(默认session存储方式为session.save_handler=files,文件形式存储。生成的session文件名规则即为sess_PHPSESSID,session文件存在session.save_path中。)

4、服务端响应首部Response Headers:Set-Cookie:PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50; path=/。在客户端生成一个cookie保存此PHPSESSID

5、此时,客户端的cookie里面包含了PHPSESSID,之后客户端的每次请求首部Request HeadersCookie:PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50。服务端之后每次接收到客户端的请求就都能根据这个PHPSESSID来找到服务端的session文件,通过对这个session文件的读写操作即实现了session的超全局变量属性。

如果客户端禁用了cookie,由于无法使用cookie传递PHPSESSID,那么客户端每次请求,服务端都会重新建立一个session文件,而无法通过通过PHPSESSID来重用session文件,所以session也就失效了。

这种情况可以设置session.use_trans_sid来传输PHPSESSID,具体实现方式与cookie的区别就是将PHPSESSID通过HTTP的GET传输。每次请求的地址里面都会补全PHPSESSID参数”url?PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50

4. 서버 응답 헤더: Set-Cookie:PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50; 이 PHPSESSID를 저장하려면 클라이언트에서 쿠키를 생성하세요.

5 현재 클라이언트의 쿠키에는 PHPSESSID가 포함되어 있으며 클라이언트의 모든 후속 요청에는 요청 헤더가 포함됩니다. 쿠키 : PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50. 서버는 클라이언트로부터 요청을 받을 때마다 이 PHPSESSID를 기반으로 서버의 세션 파일을 찾을 수 있습니다. 이 세션 파일을 읽고 쓰면 세션의 슈퍼 전역 변수 속성이 구현됩니다. .

클라이언트가 쿠키를 비활성화하면 PHPSESSID를 전달하는 데 쿠키를 사용할 수 없기 때문에 서버는 클라이언트가 요청할 때마다 세션 파일을 다시 설정합니다. 세션 파일을 재사용하기 위해 PHPSESSID를 전달할 수 없으므로 세션이 유효하지 않게 됩니다.

이 경우 session.use_trans_sid를 설정하여 PHPSESSID를 전송할 수 있으며, 구체적인 구현 방법과 쿠키의 차이점은 를 사용한다는 것입니다. >PHPSESSIDHTTP의 GET을 통해 전송됩니다. PHPSESSID 매개변수 "url?PHPSESSID=37vjjasgjdv2ouk1uomhgqkv50"는 요청된 각 주소에서 완료됩니다.

PHPcli 모드는 session_id()를 사용하여 세션을 사용합니다

이를 사용하여 현재 세션의 PHPSESSID를 얻을 수 있으며, 또한 다음을 수행할 수도 있습니다. 이를 사용하여 현재 세션 세션 PHPSESSID를 설정합니다.

PHPcli 모드에서 설정하여 세션 사용 목적을 달성할 수 있어 매우 편리합니다.

예:

<?php
// session_id(&#39;vingbrv8m64asth0nhplu9gmb7&#39;);
session_start();
$_SESSION[md5(rand(100,999))] = rand(100,999);
var_dump($_SESSION);
권장 튜토리얼: PHP 비디오 튜토리얼

#🎜🎜##🎜🎜# php 중국어 웹사이트 학습 주제 #🎜🎜#: #🎜🎜#php 세션#🎜🎜# (사진, 텍스트, 비디오, 사례 포함) #🎜🎜##🎜🎜#

위 내용은 PHP의 Session ID 구현 원리 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.