이미 시작된 PHP 세션
PHP 코드에서 세션이 이미 시작된 상태에서 새 세션을 시작하려고하면 다음과 같은 알림이 표시됩니다.
주의 : 세션이 이미 시작되었습니다-session_start () 무시
이것을 어떻게 피할 수 있습니까?
시험
<?php
if(!isset($_SESSION))
{
session_start();
}
?>
새 것을 원하면 session_destroy()
시작하기 전에 수행 하십시오. 시작하기 전에 설정되었는지 확인하려면 다음을 호출하십시오 session_status()
.
$status = session_status();
if($status == PHP_SESSION_NONE){
//There is no active session
session_start();
}else
if($status == PHP_SESSION_DISABLED){
//Sessions are not available
}else
if($status == PHP_SESSION_ACTIVE){
//Destroy current and start new one
session_destroy();
session_start();
}
나는 글로벌 체크 피할 것 $_SESSION
대신 의 내가 부르고 session_status()
PHP가 명시 적으로이 기능을 구현하기 때문에 방법 :
새로운 기능인 session_status를 통해 세션 상태를 노출합니다. 이것은 (PHP> = 5.4.0)입니다.
이전 세션을 삭제하려는 경우에만 :
<?php
if(!isset($_SESSION))
{
session_start();
}
else
{
session_destroy();
session_start();
}
?>
또는 사용할 수 있습니다
unset($_SESSION['variable_session _data'])
특정 세션 변수를 파괴합니다.
예,을 확인하여 세션이 이미 실행 중인지 감지 할 수 있습니다 isset($_SESSION)
. 그러나 가장 좋은 대답은 단순히 session_start()
두 번 이상 전화하지 않는 것입니다.
스크립트의 아주 초기에, 아마도 첫 번째 줄에서도 호출되어야하며 다시 호출되지 않아야합니다.
코드의 여러 위치에있는 경우 이러한 종류의 버그를 요청하는 것입니다. 한 곳에만 있고 한 번만 호출 할 수 있도록 잘라냅니다.
이미 세션 시작을 호출해야 포함을 통해 다시 호출 될 수 있습니까?
if( ! $_SESSION)
{
session_start();
}
이 시도
if(!isset($_SESSION)){
session_start();
}
ob_start (); 사용하는 것이 좋습니다. sesson varriable을 시작하기 전에 브라우저 버퍼를 지정해야합니다.
편집 : $ _SESSION 후에 추가)
$ Session 변수에 의존하는 모든 PHP 파일에서 session_start ()를 호출하지 않고서는 위의 어느 것도 적합하지 않았습니다. 통지는 매우 성가 시며 Error_log를 빠르게 채 웁니다. 제가 찾을 수있는 유일한 해결책은 이것입니다 ....
error_reporting(E_ALL ^ E_NOTICE);
session_start();
잘못된 수정이지만 작동합니다.
$ _SESSION의 차단 동작을 수정하는 동안이 문제가 발생했습니다.
http://konrness.com/php5/how-to-prevent-blocking-php-requests/
세션 파일은 스크립트가 완료되거나 세션이 수동으로 닫힐 때까지 잠겨 있습니다.
따라서 기본적으로 페이지는 읽기 전용 모드로 세션을 열어야합니다. 그러나 읽기 전용으로 열리면 쓰기 모드에서 닫았다가 다시 열어야합니다.
const SESSION_DEFAULT_COOKIE_LIFETIME = 86400;
/**
* Open _SESSION read-only
*/
function OpenSessionReadOnly() {
session_start([
'cookie_lifetime' => SESSION_DEFAULT_COOKIE_LIFETIME,
'read_and_close' => true, // READ ACCESS FAST
]);
// $_SESSION is now defined. Call WriteSessionValues() to write out values
}
/**
* _SESSION is read-only by default. Call this function to save a new value
* call this function like `WriteSessionValues(["username"=>$login_user]);`
* to set $_SESSION["username"]
*
* @param array $values_assoc_array
*/
function WriteSessionValues($values_assoc_array) {
// this is required to close the read-only session and
// not get a warning on the next line.
session_abort();
// now open the session with write access
session_start([ 'cookie_lifetime' => SESSION_DEFAULT_COOKIE_LIFETIME ]);
foreach ($values_assoc_array as $key => $value) {
$_SESSION[ $key ] = $value;
}
session_write_close(); // Write session data and end session
OpenSessionReadOnly(); // now reopen the session in read-only mode.
}
OpenSessionReadOnly(); // start the session for this page
그런 다음 값을 쓰러 갈 때 :
WriteSessionValues(["username"=>$login_user]);
더 효율적입니다.
@session_start();
화면에서 오류 처리기 방지
베스트,
<?php
if ( session_id() != "" ) {
session_start();
}
Basically, you need to check if a session was started before creating another one; ... more reading.
On the other hand, you chose to destroy an existing session before creating another one using session_destroy()
.
session_status() === PHP_SESSION_ACTIVE ?: session_start();
Closed Game
참고URL : https://stackoverflow.com/questions/10648984/php-sessions-that-have-already-been-started
'Programing' 카테고리의 다른 글
Android에서 사용자 지정 등급 표시 줄을 만드는 방법 (0) | 2020.10.28 |
---|---|
Java에서 CamelCase를 camel_case로 변환하는 정규식 (0) | 2020.10.28 |
Xcode: Is it possible to 'Open Quickly' the right pane of the Assistant Editor? (0) | 2020.10.28 |
부팅시 node.js 서버 자동 시작 (0) | 2020.10.28 |
Android Studio에 레이아웃 미리보기가 표시되지 않습니다. (0) | 2020.10.28 |