>  기사  >  백엔드 개발  >  PHP Session에서 자주 사용되는 함수에 대한 자세한 설명

PHP Session에서 자주 사용되는 함수에 대한 자세한 설명

小云云
小云云원래의
2018-03-27 14:22:302374검색

session_start()는 새 세션을 생성하거나 기존 세션을 재사용합니다. 세션 ID가 GET, POST 또는 쿠키를 사용하여 제출되면 기존 세션이 재사용됩니다.

session_start()를 통해 세션이 자동 또는 수동으로 시작되면 PHP는 내부적으로 세션 관리자의 열기 및 읽기 콜백 함수를 호출합니다. 세션 관리자는 PHP 기본값이거나 확장(SQLite 또는 Memcached 확장)에서 제공되거나 session_set_save_handler()를 통해 설정된 사용자 정의 세션 관리자일 수 있습니다. 읽기 콜백 함수에서 기존 세션 데이터(특수 직렬화 형식을 사용하여 저장된)를 반환함으로써 PHP는 자동으로 데이터를 역직렬화하고 $_SESSION 슈퍼 전역 변수를 채웁니다. session_start() 手动开始的时候, PHP 内部会调用会话管理器的 open 和 read 回调函数。 会话管理器可能是 PHP 默认的, 也可能是扩展提供的(SQLite 或者 Memcached 扩展), 也可能是通过 session_set_save_handler() 设定的用户自定义会话管理器。 通过 read 回调函数返回的现有会话数据(使用特殊的序列化格式存储), PHP 会自动反序列化数据并且填充 $_SESSION 超级全局变量。

要想使用命名会话,请在调用 session_start() 函数 之前调用 session_name() 函数。  
如果启用了 session.use_trans_sid 选项, session_start() 函数会注册一个内部输出管理器, 该输出管理器完成 URL 重写的工作。

注意:要使用基于 cookie 的会话, 必须在输出开始之前调用 session_start() 函数。

session_unset()

销毁当前会话数据。或者$_SESSION = array(); 如果要销毁个别会话数据,可以unset ($_SESSION['varname']);.

session_destroy()

session_unset()销毁所有会话数据不同,session_destroy()销毁的是会话本身,此函数一出,当前session就变成垃圾了,等待gc机制去回收它。但是它并不会重置当前会话所关联的全局变量, 也不会重置会话 cookie。该有的会话数据还是在,只不过“身份”变了而已。如果gc尚且还没有去回收它,那么它仍然是可以读取到的,这当然是不愿意看到的,因此在session_destroy() 之前往往还要session_unset()一下。

如果需要再次使用会话变量, 必须重新调用 session_start() 函数。 为了彻底销毁会话,比如在用户退出登录的时候,必须同时重置会话 ID。 如果是通过 cookie 方式传送会话 ID 的,那么同时也需要 调用 setcookie() 函数来 删除客户端的会话 cookie。

下面例子是销毁数据本身:

// 初始化会话。// 如果要使用会话,别忘了现在就调用:session_start();// 重置会话中的所有变量,销毁会话数据$_SESSION = array(); // 或者session_unset() // 如果要清理的更彻底,那么同时删除会话 cookie// 注意:这样不但销毁了会话中的数据,还同时销毁了会话本身if (ini_get("session.use_cookies")) {    $params = session_get_cookie_params();
    setcookie(session_name(), '', time() - 42000,        $params["path"], $params["domain"],        $params["secure"], $params["httponly"]
    );
}// 最后,销毁会话session_destroy();

销毁会话数据$_SESSION = array()session_unset() ;销毁会话本身session_destroy();和setcookie()session_destroy()执行后会话就变成垃圾会话,等待gc机制回收。

session_commit()

session_commit()session_write_close()别称。和session_start相反,这是关闭。即保存当前session数据,并且关闭当前会话。为了防止并发的写session,任何时刻只能允许有一个PHP脚本在操作session,因此,一个脚本一旦session_start打开session,那么在此脚本终止或者调用session_write_close()之前,别的任何脚本都不能使用session。在默认情况下脚本结束时会自动写入和关闭session,但是在脚本执行时间比较长的时候,此脚本就一致占据锁使得别的脚本无法使用session,因此导致许多错误。因此,最佳实践是,任何session变量,数据的更改(如$_SESSION[xx] = xxx),都要及时使用session_commit()保存数据,关闭会话。

session_id ()

session_id() 可以用来获取/设置 当前会话 ID。 为了能够将会话 ID 很方便的附加到 URL 之后, 你可以使用常量 SID 获取以字符串格式表达的会话名称和 ID。简单说,就是如果你开启的是POST/GET方式获取会话ID,那么这个参数可以通过session.use_trans_sid设定并在URL中看得见,而在脚本中通过全局变量SID来直接获取。

//配置ini_set('session.use_trans_sid', 'sid');//url中表现127.0.0.1?sid=xxxxx//直接获取$sid = SID;

如果指定了 session_id () 参数的值, 则使用指定值作为会话 ID。 必须在调用 session_start() 函数之前调用 session_id() 函数。不同的会话管理器对于会话 ID 中可以使用的字符有不同的限制。  如果当前没有会话,则返回空字符串(”“)。

这里有两点值得注意下:

  • 如果使用 cookie 方式传送会话 ID,并且指定了 id 参数, 在调用 session_start() 之后都会向客户端发送新的 cookie, 无论当前的会话 ID 和新指定的会话 ID 是否相同

  • 在通过session_id ($id )切换当前会话ID之前,需要通过session_commit()

    이름이 지정된 세션을 사용하려면 session_start() 함수를 호출하기 전에 session_name() 함수를 호출하세요.
  • session.use_trans_sid 옵션이 활성화된 경우 session_start() 함수는 URL 재작성을 완료하는 내부 출력 관리자를 등록합니다.

참고: 쿠키 기반 세션을 사용하려면 출력이 시작되기 전에 session_start() 함수를 호출해야 합니다.

session_unset()

🎜현재 세션 데이터를 삭제합니다. 또는 $_SESSION = array(); 개별 세션 데이터를 삭제하려면 unset ($_SESSION['varname']);할 수 있습니다. 🎜

session_destroy ()🎜 모든 세션 데이터를 파괴하는 session_unset()과 달리 session_destroy()는 이 함수가 나오면 현재 세션이 가비지가 됩니다. , gc 메커니즘이 이를 재활용할 때까지 기다리고 있습니다. 그러나 현재 세션과 연관된 전역 변수는 재설정되지 않으며 세션 쿠키도 재설정되지 않습니다. 있어야 할 세션 데이터는 여전히 존재하지만 "ID"가 변경되었습니다. gc가 아직 재활용하지 않은 경우 여전히 읽을 수 있습니다. 물론 이는 보고 싶은 내용이 아니므로 session_destroy() 전에 session_unset()이 필요한 경우가 많습니다. 잠시만요. 🎜🎜세션 변수를 다시 사용해야 하는 경우에는 session_start() 함수를 다시 호출해야 합니다. 사용자가 로그아웃하는 등 세션을 완전히 삭제하려면 세션 ID도 재설정해야 합니다. 세션 ID가 쿠키를 통해 전송되는 경우 클라이언트의 세션 쿠키를 삭제하려면 setcookie() 함수도 호출해야 합니다. 🎜🎜다음 예는 데이터 자체를 삭제하는 것입니다. 🎜
// 初始化会话。// 如果要使用会话,别忘了现在就调用:session_start();// 重置会话中的所有变量,销毁会话数据$_SESSION = array(); // 或者session_unset() // 如果要清理的更彻底,那么同时删除会话 cookie// 注意:这样不但销毁了会话中的数据,还同时销毁了会话本身if (ini_get("session.use_cookies")) {    $params = session_get_cookie_params();
    setcookie(session_name(), '', time() - 42000,        $params["path"], $params["domain"],        $params["secure"], $params["httponly"]
    );
}// 最后,销毁会话session_destroy();
🎜세션 데이터 삭제 $_SESSION = array() 또는 session_unset() 세션 자체를 삭제합니다. session_destroy() 및 <code>setcookie(). session_destroy()가 실행된 후 세션은 가비지 세션이 되어 gc 메커니즘에 의한 재활용을 기다립니다. 🎜

session_commit()

🎜session_commit()session_write_close()의 별칭입니다. session_start와 달리 이는 쓰기닫기입니다. 즉, 현재 세션 데이터를 저장하고 현재 세션을 닫습니다. 동시 세션 쓰기를 방지하기 위해 언제든지 하나의 PHP 스크립트만 세션을 작동하도록 허용됩니다. 따라서 session_start 스크립트가 세션을 열면 스크립트가 종료되거나 session_write_close()를 호출합니다. ), 다른 스크립트는 세션을 사용할 수 없습니다. 기본적으로 스크립트가 종료되면 세션이 자동으로 작성되고 닫힙니다. 그러나 스크립트 실행 시간이 상대적으로 길면 스크립트가 지속적으로 잠금을 점유하게 되어 다른 스크립트가 세션을 사용할 수 없게 되어 많은 오류가 발생합니다. 따라서 세션 변수 또는 데이터 변경(예: <code>$_SESSION[xx] = xxx)의 경우 session_commit()을 사용하여 데이터를 저장해야 하는 것이 가장 좋습니다. 적시에 세션을 닫습니다. 🎜

session_id ()

🎜session_id()는 현재 세션 ID를 가져오거나 설정하는 데 사용할 수 있습니다. URL에 세션 ID를 쉽게 추가하려면 상수 SID를 사용하여 세션 이름과 ID를 문자열 형식으로 가져올 수 있습니다. 간단히 말하면, 세션 ID를 얻기 위해 POST/GET 메소드를 활성화하면 이 매개변수는 session.use_trans_sid를 통해 설정될 수 있으며 전역 변수를 통해 URL 및 스크립트에서 볼 수 있습니다. SID를 사용하여 직접 가져옵니다. 🎜
//配置ini_set(&#39;session.use_trans_sid&#39;, &#39;sid&#39;);//url中表现127.0.0.1?sid=xxxxx//直接获取$sid = SID;
🎜session_id() 매개변수의 값을 지정하면 해당 값이 세션 ID로 사용됩니다. session_start() 함수를 호출하기 전에 session_id() 함수를 호출해야 합니다. 세션 관리자마다 세션 ID에 사용할 수 있는 문자에 대한 제한 사항이 다릅니다. 현재 세션이 없으면 빈 문자열("")이 반환됩니다. 🎜🎜여기서 주목할 만한 두 가지 사항이 있습니다: 🎜
  • 🎜 쿠키를 사용하여 세션 ID를 전송하고 id 매개변수를 지정하는 경우 session_start()를 호출한 후 현재 세션 ID와 새로 지정된 세션 ID가 동일한지 여부에 관계없이 클라이언트에 새 쿠키를 보냅니다🎜🎜
  • 🎜session_id($id)를 통해 현재 세션 ID를 전환하기 전에 다음이 필요합니다. session_commit()을 전달하여 이전 세션을 닫습니다. 그렇지 않으면 현재 세션이 동일하게 유지됩니다. 🎜🎜🎜🎜자세한 기능은 PHP 공식 웹사이트나 매뉴얼을 참조하세요. 🎜

    我们在前面的文章里面讲到session的原理和最佳实践,感到意犹未尽。现在再来聊下PHP Session用到的几个相关的函数。

    session_start()

    session_start() 会创建新会话或者重用现有会话。 如果通过 GET 或者 POST 方式,或者使用 cookie 提交了会话 ID, 则会重用现有会话。

    当会话自动开始或者通过 session_start() 手动开始的时候, PHP 内部会调用会话管理器的 open 和 read 回调函数。 会话管理器可能是 PHP 默认的, 也可能是扩展提供的(SQLite 或者 Memcached 扩展), 也可能是通过 session_set_save_handler() 设定的用户自定义会话管理器。 通过 read 回调函数返回的现有会话数据(使用特殊的序列化格式存储), PHP 会自动反序列化数据并且填充 $_SESSION 超级全局变量。

    要想使用命名会话,请在调用 session_start() 函数 之前调用 session_name() 函数。  
    如果启用了 session.use_trans_sid 选项, session_start() 函数会注册一个内部输出管理器, 该输出管理器完成 URL 重写的工作。

    注意:要使用基于 cookie 的会话, 必须在输出开始之前调用 session_start() 函数。

    session_unset()

    销毁当前会话数据。或者$_SESSION = array(); 如果要销毁个别会话数据,可以unset ($_SESSION['varname']);.

    session_destroy()

    session_unset()销毁所有会话数据不同,session_destroy()销毁的是会话本身,此函数一出,当前session就变成垃圾了,等待gc机制去回收它。但是它并不会重置当前会话所关联的全局变量, 也不会重置会话 cookie。该有的会话数据还是在,只不过“身份”变了而已。如果gc尚且还没有去回收它,那么它仍然是可以读取到的,这当然是不愿意看到的,因此在session_destroy() 之前往往还要session_unset()一下。

    如果需要再次使用会话变量, 必须重新调用 session_start() 函数。 为了彻底销毁会话,比如在用户退出登录的时候,必须同时重置会话 ID。 如果是通过 cookie 方式传送会话 ID 的,那么同时也需要 调用 setcookie() 函数来 删除客户端的会话 cookie。

    下面例子是销毁数据本身:

    // 初始化会话。// 如果要使用会话,别忘了现在就调用:session_start();// 重置会话中的所有变量,销毁会话数据$_SESSION = array(); // 或者session_unset() // 如果要清理的更彻底,那么同时删除会话 cookie// 注意:这样不但销毁了会话中的数据,还同时销毁了会话本身if (ini_get("session.use_cookies")) {    $params = session_get_cookie_params();
        setcookie(session_name(), &#39;&#39;, time() - 42000,        $params["path"], $params["domain"],        $params["secure"], $params["httponly"]
        );
    }// 最后,销毁会话session_destroy();

    销毁会话数据$_SESSION = array()session_unset() ;销毁会话本身session_destroy();和setcookie()session_destroy()执行后会话就变成垃圾会话,等待gc机制回收。

    session_commit()

    session_commit()session_write_close()别称。和session_start相反,这是关闭。即保存当前session数据,并且关闭当前会话。为了防止并发的写session,任何时刻只能允许有一个PHP脚本在操作session,因此,一个脚本一旦session_start打开session,那么在此脚本终止或者调用session_write_close()之前,别的任何脚本都不能使用session。在默认情况下脚本结束时会自动写入和关闭session,但是在脚本执行时间比较长的时候,此脚本就一致占据锁使得别的脚本无法使用session,因此导致许多错误。因此,最佳实践是,任何session变量,数据的更改(如$_SESSION[xx] = xxx),都要及时使用session_commit()保存数据,关闭会话。

    session_id ()

    session_id() 可以用来获取/设置 当前会话 ID。 为了能够将会话 ID 很方便的附加到 URL 之后, 你可以使用常量 SID 获取以字符串格式表达的会话名称和 ID。简单说,就是如果你开启的是POST/GET方式获取会话ID,那么这个参数可以通过session.use_trans_sid设定并在URL中看得见,而在脚本中通过全局变量SID来直接获取。

    //配置ini_set(&#39;session.use_trans_sid&#39;, &#39;sid&#39;);//url中表现127.0.0.1?sid=xxxxx//直接获取$sid = SID;

    如果指定了 session_id () 参数的值, 则使用指定值作为会话 ID。 必须在调用 session_start() 函数之前调用 session_id() 函数。不同的会话管理器对于会话 ID 中可以使用的字符有不同的限制。  如果当前没有会话,则返回空字符串(”“)。

    这里有两点值得注意下:

    • 如果使用 cookie 方式传送会话 ID,并且指定了 id 参数, 在调用 session_start() 之后都会向客户端发送新的 cookie, 无论当前的会话 ID 和新指定的会话 ID 是否相同

    • session_id($id)를 통해 현재 세션 ID를 전환하기 전에 session_commit()를 통해 이전 세션을 닫아야 합니다. 그렇지 않으면 현재 세션은 여전히 ​​원본

    자세한 기능은 PHP 공식 웹사이트를 참조하세요. 또는 수동.

    관련 권장 사항:

    Redis 공유 세션에 대한 자세한 설명

    PHP의 세션 잠금, 동시성 및 적용 범위에 대한 자세한 설명

    php 수정 세션 생존 저장 시간 코드 공유

위 내용은 PHP Session에서 자주 사용되는 함수에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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