Cookies storing values even after closing the browser.

Hi all,
I am creating one cookie in a javascript and one cookie in a php page. I am setting them both with a expire date to '0' i.e of one cookie that's set:  setcookie("isQR","57",0,'/');

But still i see that when I close the browser and open another page, I can see that the cookies are still there, theoreticallly it should have been deleted after the browser is closed.
But why I am not seeing it happening. Please let me know how to proceed. I want the cookies to get deleted as soon as the browser is closed.

Thanks.
sandhya01Asked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

HonorGodSoftware EngineerCommented:
If you don't specify an expiration time, then a cookie should be a session cookie, and expire when the browser closes.

Please show us the code for your setcookie() routine.
0
SadafRasheedCommented:
just to add to what HonorGod said,, if you are using browsers with tabs then be careful while testing. closing tab is different from closing browser window.. session remains active even if you close the tab..
0
sandhya01Author Commented:
Hi Experts,
Please find the javascirpt code and php code for setting cookies in php and javascript page respectively.
After doing some testing i had the following observation:
1. If I open a single IE window and access the page in which cookies are set after I provide my login id and password, and then close it and if I try to open it again, I see that there are no cookies available, means closing the window destroys the cookies ---As per Expectation
2. If I open 2 different IE windows at the same time and then try to access the page in one of the IE windows and then close that particular IE window and If I try to open that page again in IE window I see that the cookies are still there - Not Per Expectation

So, somehow the second IE window is either delaying the deletion of cookies are not allowing them to net get deleted at all!, I am not able to understand this behaviour as the cookie is supposed to be set for a particular domain and the second IE window is not accessing any page in that domain( do I have to explicitly mention the domain also while setting cookie or by default the cookie takes the domain value in which it is created?).

Waiting for your expert suggestion

Thanks


//call to the function create cookies
createCookie('isQR','57',0,'/');
 
//actual function code
function createCookie(name, value, expires, path) {
	document.cookie = name + "=" + escape(value) + "; ";
	
	if(expires){
		expires = setExpiration(expires);
		document.cookie += "expires=" + expires + "; ";
	}
	if(path){
		document.cookie += "path=" + path + "; ";
	}
	
}
 
 
//php code to set cookie
setcookie("isQR","57",0,'/');

Open in new window

0
Big Business Goals? Which KPIs Will Help You

The most successful MSPs rely on metrics – known as key performance indicators (KPIs) – for making informed decisions that help their businesses thrive, rather than just survive. This eBook provides an overview of the most important KPIs used by top MSPs.

TimYatesCommented:
How are you opening the two IE windows?

Using File->New Window will just give you two windows with the same session

At least it used to with IE6/7
0
HonorGodSoftware EngineerCommented:
What code do you have for setCookie() and setExpiration()?
0
sandhya01Author Commented:
Hi
Please find the setExpiration() code:
fuction setExpiration(CookieLife)
{
var today = new Date();
var expr = new Date(today.getTime() + cookieLife *24*60*60*1000)
return expr.toGMTString();
}

yes, I am opening two windows one by one seperately not as tab, I am using IE 6.0 and I am clicking desktop IE icon for opening IE.

Thanks


0
HonorGodSoftware EngineerCommented:
ok, setExpiration() looks reasonable.

What about setCookie() ?
0
Pravin AsarPrincipal Systems EngineerCommented:
Cookies are stored at client browser, so they are not deleted , but you set expiration time.

For a comprehensive cookie tutorial, look at

http://javascriptjournal.com/ws/?p=54

Please feel free to view source
0
Steve BinkCommented:
As per my own experiences with this very same issue awhile back, having any of the browser windows open will retain the session cookies.  This behavior is present in both IE and Firefox.  At least, it was when I did my tests with it about 3 years ago.  It looks like the browser software works on the principle that all windows must be closed for the browsing session to be over.

The only way I found to work around this is to expire the cookie manually, but that is not always possible.  You'll need to plan for this behavior in your application.
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
Pravin AsarPrincipal Systems EngineerCommented:
Try not to cache the page.

header("Cache-Control: no-cache, must-revalidate");
header("Expires: Sat, 26 Jul 1997 05:00:00 EST");
0
sandhya01Author Commented:
Hi All,
Thanks for the comments...let me try out your comments...will let you know
0
b0lsc0ttIT ManagerCommented:
>> 2. If I open 2 different IE windows at the same time ... Not Per Expectation  <<
The comment at http:#a24909989 is correct.  Your expectation for the second case is wrong.  Cookies will remain as long as ANY window is open in that browser program.  Whether tab or its own window doesn't matter.  If you think about this it is actually a good design because otherwise the steps you expected would make it so the cookie couldn't be used by another browser window.  Definitely not behavior people would want.
If you want you could provide a logout or clear cookie link or button that will destroy the cookie (or at least clear the values).  That is a common step to have if you provide a logout option.
Let me know if you have a question about this.
bol
0
Steve BinkCommented:
I recommend #24909989, but I may be biased.  :)
0
b0lsc0ttIT ManagerCommented:
>> I recommend #24909989 <<

I agree.  I believe my post at http:#a24943026 adds a bit but the answer is in the comment at http:#a24909989 .

bol
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
PHP

From novice to tech pro — start learning today.