PHP session FAQ highlights and solutions:
1.
Error Message
Warning: Cannot send session cookie-headers already sent
Warning: Cannot send session cache limiter-headers already sent
Analysis and Solutions
The reason for this problem is that when you use session_start () in the program, the actual html content is output. Maybe you said, I didn't. I just echo or print a message. Sorry, the output produced by your echo or print statement is the actual html content output. The solution to this problem is to tune your session_start () to the first line of the program.
2.
Error Message
Warning: open (F:/689phpsessiondatasess_66a39376b873f4daecf239891edc98b5, O_RDWR) failed
Analysis and Solution
This error occurs generally because the session. save_path item in your php. ini is not set. The solution is to set session. save_path and session. cookie_path
Session_save_path = c: temp
Session. cookie_path = c: temp
Create a temp directory under the c: directory.
3.
Error Message
Warning: Trying to destroy uninitialized session in
Analysis and Solution
Generally, you directly call the session_destroy () function. Many friends think that the session_destroy () function can run independently, but it is not. The solution is to enable the session function with session_start () before you call the session_destroy () function.
4. Question: How can I obtain the id of the current session?
The simplest method is:
Echo SID;
You will find.
5. problem: My program has no output before calling the header function, although I include a config. PHP file, but in config. there is no output in the PHP file. Why does the session still report the same error as Question 1? Is it because I used session_start () before the header?
A: Maybe you have carefully checked your php program. There is no output before header () is referenced, and there is no output in your include file! But are you using the mouse key?> What about the mobile check after the conclusion of this PHP code? Then you will find in?> There is a blank line or space behind this. If you delete these blank lines or spaces, the problem is solved.
Note: If this problem occurs, PHP 4.1.2 is later than PHP4.1.2 and has not been tested.
6. Q: How can I use session to restrict logon to other pages after I use session to log on to the home page...
A: The simplest method is
Session_start ();
If (! Session_registered ('login') │ login! = True ){
Echo "You have not logged on ";
Exit;
}
7. q: I used session_register () to register the session variable. However, when I use the header or javascript redirection statement, on the following page, but I cannot access the variable value registered by the session. How can this problem be solved?
Program segment of the problem:
Session_start ();
OK = 'Love you ';
Session_register ('OK ');
Header ("location: next. php ");
?>
Next. php
Session_start ();
Echo OK;
?>
Solution:
When you use the header function or window. after the location function, the session variables registered on the previous page will be easily lost. There is still no detailed answer to this question.
But there are solutions. As shown below
Header ("Location: next. php "."? ". SID );
When you jump to the next page, use the current session id as a parameter and upload it to the next page.
8. How to pass an array in a session
Session_register ('data ');
Data = array (1, 2, 3, 4 );
The method is to first register and then assign a value.
9. Question 9: Can I access the session value in a way like HTTP_GET_VARS?
A: Yes. You can use the following global array to access sessions to enhance web page security.
HTTP_SESSION_VARS
_ SESSION
Routine:
CODE:
Session_start ();
Username = 'stangly. wrong ';
Session_register ('username ');
Echo HTTP_SESSION_VARS ['username'];
Echo'
';
Echo _ SESSION ['username'];
?>
Refer to this routine to modify your own program.
Question 10: What is the difference between session_unregister () and session_destroy?
The session_unregister () function is used to describe the current session variable. However, if you use HTTP_SESSION_VARS or _ SESSION to reference the session variable on the current page, you may need to work with unset () to cancel the session variable.
Session_destroy () clears the current session environment. That is to say, when you use the session_destroy () function, you cannot use session_is_registered () to detect session variables. However, you must note that it cannot clear sessions in global or sessions that use session cookies. therefore, before using session_destroy, it is best not to use HTTP_SESSION_VARS _ SESSION to access the session. (translated from php.net)
Routine:
If (isset (_ COOKIE [session_name ()]) {
Session_start ();
Session_destroy ();
Unset (_ COOKIE [session_name ()]);
}