쿠키가 비활성화되어 있는데 세션을 계속 사용할 수 있나요?

WBOY
풀어 주다: 2016-07-28 08:28:21
원래의
1035명이 탐색했습니다.
쿠키와 세션은 일반적으로 두 가지 독립적인 것으로 간주됩니다. 세션은 서버 측에서 상태를 유지하는 솔루션을 사용하는 반면 쿠키는 클라이언트 측에서 상태를 유지하는 솔루션을 사용합니다. 그런데 쿠키를 비활성화하면 왜 세션을 얻을 수 없나요? 세션은 세션 ID를 사용하여 현재 대화에 해당하는 서버 세션을 결정하고 세션 ID는 쿠키를 통해 전달되므로 쿠키를 비활성화하는 것은 세션 ID를 잃는 것과 동일하며 세션을 얻을 수 없습니다.
쿠키를 비활성화하면 당연히 세션을 사용할 수 없다는 뜻인가요?
1. ASP
ASP에서 세션은 쿠키에 의존해야 사용할 수 있습니다. 세션은 서버 측에 저장되는 반면 쿠키는 클라이언트 측에 저장됩니다. 상대적으로 세션은 쿠키보다 더 안전하고 안정적입니다. .
2. PHP
PHP에서는 관련 설정을 통해 Cookie에 의존하지 않고 Session이 존재할 수 있습니다.
세션은 서버 측에 저장됩니다(세션은 기본적으로 파일로 저장됩니다). 클라이언트가 제공한 세션 ID에 따라 사용자의 파일을 가져오고 변수의 값을 가져옵니다. Session ID는 클라이언트의 Cookie를 이용하거나, Http1.1 프로토콜의 Query_String(즉, 접근한 URL의 "?" 뒤의 부분)을 서버로 보낸 후, 서버가 Session 디렉터리를 읽어 들이게 되는데... 즉, 세션 ID는 서비스에 저장된 세션 변수를 얻기 위한 ID 카드입니다. session_start(); 코드가 실행되면 서버에 세션 파일이 생성되고 이에 고유하게 대응하는 세션도 생성됩니다. ID는 방금 생성된 세션 파일에 특정 형식으로 저장될 세션 변수를 정의합니다. 세션 ID를 통해 정의된 변수를 검색할 수 있습니다. 페이지를 넘은 후 세션을 사용하려면 다시 session_start()를 실행해야 합니다. 다른 세션 파일이 생성되고 이에 따라 해당 세션 ID가 생성됩니다. 이 세션 ID를 사용하면 언급된 첫 번째 세션 파일을 검색할 수 없습니다. 이 세션 ID는 세션을 여는 "키"가 아니기 때문입니다.session_start(); 앞에 session_id($session id); 코드를 추가하면 새로운 세션 파일이 생성되지 않고, 이 id에 해당하는 세션 파일을 직접 읽어옵니다.
PHP의 세션은 기본적으로 클라이언트의 쿠키를 사용하여 세션 ID를 저장하므로 클라이언트의 쿠키에 문제가 있을 경우 세션에 영향을 미치게 됩니다. 세션이 반드시 쿠키에 의존할 필요는 없다는 점은 쿠키에 비해 세션의 장점이기도 합니다. 클라이언트의 쿠키가 비활성화되거나 문제가 있는 경우 PHP는 자동으로 세션 ID를 URL에 첨부하여 세션 변수가 세션 ID를 통해 여러 페이지에서 사용될 수 있도록 합니다. 하지만 이 첨부 파일에는 "php.ini의 session.use_trans_sid"라는 특정 조건도 있습니다. = 1", 또는 컴파일 시 "--enable-trans-sid" 옵션이 켜져 있습니다.
포럼을 사용해 본 친구들은 포럼에 들어갈 때 쿠키가 켜져 있는지 확인하라는 메시지가 자주 표시된다는 것을 알고 있습니다. 이는 대부분의 포럼이 사용 편의성을 위해 사용자 이름 및 비밀번호와 같은 사용자 정보를 저장하는 데 사용되는 쿠키를 기반으로 하기 때문입니다. 또한 많은 친구들은 쿠키가 안전하지 않다고 생각하여(사실이 아님) 쿠키를 비활성화하는 경우가 많습니다. PHP 프로그램에서는 쿠키 대신 세션을 사용할 수 있습니다.
따라서 쿠키 외에 세션, 즉 사용자가 쿠키를 끄는 경우를 가정하여 사용할 수 있습니다. :
1. php.ini 구성 파일에서 "session.use_trans_sid = 1"을 설정하거나, 컴파일 시 "--enable-trans-sid" 옵션을 켜서 PHP가 자동으로 실행되도록 합니다. 페이지 간에 세션 ID를 전달합니다.
2. URL 및 숨겨진 형식을 통해 세션 ID를 수동으로 전달합니다.
3. 세션 ID를 파일, 데이터베이스 등에 저장하고 페이지 간 수동으로 호출합니다. 프로세스. 접근 방식 1의 예:
- -------------------------- ----------- -------------------------- ----------- ---------------
                                                                                                                                                        ​공화국";
$url="다음 페이지"; Echo $ url
------ ------------------------------------- ------------------------------------- ------------------------------------- ---------------------------------- ---------------- ---------------------------------- ---------------- -----
----- ----------- -------------------------- ----------- -----------------------------
                                                                                      > ----------------------------- -------- ----------------------------- -------- ----------
위의 코드를 실행하면 클라이언트 쿠키가 정상이면 "중화인민공화국"이라는 결과를 얻을 수 있습니다.
이제 클라이언트에서 쿠키를 수동으로 닫았다가 다시 실행하면 결과를 얻지 못할 수도 있습니다. 결과를 얻을 수 없는 경우 php.ini 파일에 "session.use_trans_sid = 1"을 설정하거나, 컴파일 시 "--enable-trans-sid 옵션"을 켜면 "중화인민공화국"이라는 결과를 얻게 됩니다. ".
경로 2 예:
-------------------------- - ------------------------------------------------- - -------------------------
                                                                                                                                                     > $_SESSION['var1']="중화인민공화국";
$sn = session_id();
$url="다음 페이지";
                                                                                                                                                          ----------------------------------------- ---------- -------------- ---------- ----------
-------------- ------------- ----------- ------------- ------
                                                                              
session_start();
echo "전달된 세션 변수 var1의 값은 다음과 같습니다: ".$_SESSION['var1'];
?> ------------------------------------------------ -- ------------------------------------------------ -- ---
경로 3의 예:
--------------------- -- ------------------------------------------------ -- -------------------
login.html

                                                                      =" 콘텐츠 유형" c/html ; charset=gb2312">
                                                            " action="mylogin1.php"> :

비밀번호:
-- -------------------- ---- -------------------- ---- --------------
--------------- ----- -------------------------------- ----- ----------------------
mylogin1.php
$name=$_POST['name'];
$pass=$_POST['pass'];
if(!$name || !$pass) {
echo "사용자 이름 또는 비밀번호 비어 있습니다.다시 로그인";
                                                                                                                                        > } }
if (! ($name=="laigw" && $pass=="1234") {
                                                                                             사용    .blog.163.com/blog/login.html">다시 로그인";
            사망 ();
    }
//등록된 사용자
ob_start();
session_start();
$_SESSION['user']= $name;
$psid=session_id();
$ fp =fopen("D:tmpphpsid.txt","w+");
fwrite($fp,$psid);
fclose($fp);
//인증 성공, 관련 작업 수행
echo "로그인했습니다
";
echo "다음 페이지 ?>
--------------------------- -- ------------------------------------------------ -- -----------
---------- --- ---------------------------------- --- ---------------------------------- -
mylogin2.php
                                                                                  ~                           $fp=f );
session_id($sid);
session_start();
if(isset($_SESSION['user']) && $_SESSION ['user']="laigw" {
echo "로그인되었습니다!"; } Else {
// 관련 작업을 수행하기 위해 성공적으로 로그인했습니다
Echo "해제되었습니다. 액세스할 수 있는 권한";
echo ", & lt; a href =" http:/ /laiguowei2004.blog.163.com/blog/login.html">로그인
찾아보기";
           die() -------------------------------- ----- ------------------- ----- ------------
쿠키 ​​테스트도 꺼주세요. 사용자 이름: laigw 비밀번호: 1234 파일을 통해 세션 ID를 저장합니다. : D:/tmp/phpsid.txt , 시스템에 따라 파일 이름이나 경로를 결정하십시오.
정리하자면, 위의 방법들은 한 가지 공통점이 있는데, 이전 페이지에서 Session ID를 가져온 후 다음 페이지로 전달하는 방법을 찾고, Session ID 코드를 추가(전달)한다는 것입니다. 다음 페이지 세션 ID의 session_start() 코드 앞).

위에서는 쿠키를 비활성화해도 세션을 계속 사용할 수 있다고 소개했습니다. , 관련 내용을 포함하여 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.


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