Home » Categories » Multiple Categories

Issue with Storing Session

Sometimes, the session on your website can expire earlier than you expect. The followings are the steps you need to check:

1. In .Net, you cannot use authentication without session. The session ID can be transmitted with client either in a cookie, or in the page url. There is no need to choose between session and cookie, as the cookie actually holds the session id.

2. On the server, session data is stored either in memory (in process or outside process), or in database.

3. The cookie is encrypted using a key called the "machine key". By default, everytime the app pool is recycled, a new machine key is created and the session data that is in memory is lost. On a shared server, this results in the end of a session, since the cookie cannot be decrypted anymore.

The solution: Store a static machine key in the web.config of the web application.

Also, storing the session data in the database instead of memory (in proc) can be useful to preserve sessions.




Attachments Attachments
There are no attachments for this article.
Related Articles RSS Feed
Domain Name Server (DNS) Amplification Attack
Viewed 2007 times since Wed, Oct 15, 2014
My website session times out earlier than expected. Why?
Viewed 2995 times since Tue, May 1, 2012
How do I send an email from my ASP.NET website by using SMTP Authentication?
Viewed 4396 times since Tue, May 1, 2012
How do I query MySQL database in ASP.NET?
Viewed 4162 times since Tue, May 1, 2012
How to solve the Let’s Encrypt SSL on ASP.NET Core
Viewed 1952 times since Mon, Jul 17, 2017
I cannot see my website. What should I do?
Viewed 2320 times since Thu, May 3, 2012
My site is showing 500 Internal Server error message. What is wrong here?
Viewed 2195 times since Thu, May 3, 2012
How do I redirect a subdomain to a subdirectory?
Viewed 2324 times since Tue, May 1, 2012