Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 79563
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 10, 20262026-05-10T21:09:55+00:00 2026-05-10T21:09:55+00:00

I need to revoke an authentication cookie if the user no longer exists (or

  • 0

I need to revoke an authentication cookie if the user no longer exists (or some other condition), after the forms authentication mechanism already have received the authentication cookie from the browser and have validated it. I.e. here is the use scenario:

  1. The user have been authenticated, and granted non-expiring auth cookie.
  2. In a few days, the user tries to access my web app again, and as the cookie is valid, the forms authentication mechanism will grant access.

  3. Now I want to perform a second check (whatever condition I want), and decide if I want to let the user continue, or to revoke the authentication.

The question is – is there an official automated way for this? So far I have come with some possibilities, but I do not know which one is better. I can capture the Authenticate event in global.asax, check whatever I want, and to revoke I clear the cookie, and then one of these:

  1. Redirect again to same url – this should work, as this time the forms authentication will fail, and it will redirect to logon page.

  2. Throw some exception ??? which one to make the redirect happen w/o me specifying anything?

  3. Somehow to get the logon page url from the config file (any ideas how/which config handler to use) and redirect directly?

  4. Some FormsAuthentication class/method I have overlooked, which is designed for this?

  5. Any other idea?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-10T21:09:56+00:00Added an answer on May 10, 2026 at 9:09 pm

    I don’t think there is an automated way to achive this. I think the best way would be to add a date to the auth cookie which will be the last time you checked whether the user exists. So when a user logs-in you’ll:

    FormsAuthenticationTicket ticket = new FormsAuthenticationTicket(                 1, // Ticket version                 name, // Username associated with ticket                 DateTime.Now, // Date/time issued                 DateTime.Now.AddMonths(1), // Date/time to expire                 true, // 'true' for a persistent user cookie                 DateTime.Now.ToUniversalTime(), // last time the users was checked                 FormsAuthentication.FormsCookiePath);// Path cookie valid for          // Encrypt the cookie using the machine key for secure transport         string hash = FormsAuthentication.Encrypt(ticket);         HttpCookie cookie = new HttpCookie(             FormsAuthentication.FormsCookieName, // Name of auth cookie             hash); // Hashed ticket          cookie.HttpOnly = true;          // Set the cookie's expiration time to the tickets expiration time         if (ticket.IsPersistent) cookie.Expires = ticket.Expiration;         //cookie.Secure = FormsAuthentication.RequireSSL;         Response.Cookies.Add(cookie); 

    Then everytime a user is authenicated you can check the additional date you passed to the Authentication ticket and in 10 minute intervals or less double check against the database whether the user exists. The code might look something like this:

    public void FormsAuthentication_OnAuthenticate(object sender,                             FormsAuthenticationEventArgs args)     {         if (FormsAuthentication.CookiesSupported)         {             if (Request.Cookies[FormsAuthentication.FormsCookieName] != null)             {                 try                 {                     FormsAuthenticationTicket ticket = FormsAuthentication.Decrypt(                       Request.Cookies[FormsAuthentication.FormsCookieName].Value);                      DateTime lastCheckedTime = DateTime.TryParse(ticket.UserData);                     TimeSpan elapsed = DateTime.Now - lastCheckedTime;                     if (elapsed.TotalMinutes > 10)//Get 10 from the config                     {                         //Check if user exists in the database.                          if (CheckIfUserIsValid())                         {                             //Reset the last checked time                             // and set the authentication cookie again                         }                         else                         {                             FormsAuthentication.SignOut();                             FormsAuthentication.RedirectToLoginPage();                             return;                         }                     }                  }                 catch (Exception e)                 {                     // Decrypt method failed.                 }             }         }     } 

    You can even cache the users that have been deleted the last 10 minutes and check against that collection.

    Hope that helps.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 66k
  • Answers 66k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • added an answer There are several options, but it does somewhat depend on… May 11, 2026 at 11:28 am
  • added an answer Found the solution. public partial class Group { public ObjectQuery<Member>… May 11, 2026 at 11:28 am
  • added an answer I ended up using a little server-side preprocessing. This site,… May 11, 2026 at 11:28 am

Related Questions

I need to revoke an authentication cookie if the user no longer exists (or
I need to know about Epoll On linux System. Could you recommend manual or
I need to copy hundreds of gigs of random files around on my computer
I need to send hundreds of newsletters, but would like to check first if
I need to launch a server on the remote machine and retrieve the port
I need to filter out anchor tags in a string. For instance, Check out
I need to add a web part zone to a wiki page. I'm opening
I need to create a historical timeline starting from 1600's to the present day.
I need to implement a Diff algorithm in VB.NET to find the changes between
I need to find out how to format numbers as strings. My code is

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.