首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用FormsAuthentication持久cookie超时

使用FormsAuthentication持久cookie超时是指在ASP.NET应用程序中,使用FormsAuthentication类创建的持久cookie在一定时间后会自动过期。这是由于cookie的过期时间设置不正确或者浏览器设置导致的。

以下是一些可能的原因和解决方案:

  1. 确保在创建cookie时设置了正确的过期时间。在创建cookie时,可以使用如下代码设置过期时间:
代码语言:csharp
复制
FormsAuthenticationTicket ticket = new FormsAuthenticationTicket(
    1,                                  // version
    userName,                            // user name
    DateTime.Now,                        // creation
    DateTime.Now.AddMinutes(30),         // expiration
    true,                                // persistent
    userData,                            // user data
    FormsAuthentication.FormsCookiePath // cookie path
);

在上面的代码中,可以通过修改DateTime.Now.AddMinutes(30)来设置cookie的过期时间。

  1. 确保浏览器接受了cookie。有些浏览器可能会阻止cookie的存储,需要用户手动设置。可以尝试在其他浏览器中测试应用程序,以确保问题不是由于浏览器设置导致的。
  2. 如果使用的是跨域的cookie,需要确保在创建cookie时设置了正确的域名。可以使用如下代码设置cookie的域名:
代码语言:csharp
复制
HttpCookie cookie = new HttpCookie("name", "value");
cookie.Domain = ".example.com"; // set the domain to example.com and all subdomains
Response.Cookies.Add(cookie);
  1. 如果问题仍然存在,可以尝试使用ASP.NET Core的身份验证系统,它提供了更多的灵活性和控制,可以更好地处理cookie超时等问题。
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

WCF服务中操作FormsAuthenticationCookie

在asp.net 应用程序和WCF服务之间共享FormsAuthentication,默认是不支持的,设置一下非常的简单,只需要两步就可以了: 1、在web.config的system.serviceModel...AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)] 这样在WCF服务上就可以操作cookie...(formAuthTicket); // 以加密票的密文存入Cookie                HttpCookie authCookie = new HttpCookie(FormsAuthentication.FormsCookieName...;                authCookie.Secure = FormsAuthentication.RequireSSL; if (FormsAuthentication.CookieDomain...= null)                {                    authCookie.Domain = FormsAuthentication.CookieDomain;

56450

android cookie持久

在解析网页信息的时候,需要登录后才能访问,所以使用httpclient模拟登录,然后把cookie保存下来,以供下一次访问使用,这时就需要持久cookie中的内容。...什么是持久化的和非持久化的Cookies 我们可以将cookies分成两类: (1)    持久化的cookies (2)    非持久化的cookies 持久化的cookies:这可以被称为永久性的...非持久化cookies:也可以被称之为临时性的cookies。如果没有定义失效时间,那么cookie将会被存储在浏览器的内存中。我上面展示的例子就是一个非持久的cookies。...Cookie持久化 HttpClient可以和任意物理表示的实现了CookieStore接口的持久cookie存储一起使用。...是使用数据库来保存的,这里我是使用SharedPreferences保存。

1.5K90
  • Android持久化保存cookie的方法

    在解析网页信息的时候,需要登录后才能访问,所以使用httpclient模拟登录,然后把cookie保存下来,以供下一次访问使用,这时就需要持久cookie中的内容。...什么是持久化的和非持久化的Cookies 我们可以将cookies分成两类: (1)持久化的cookies (2)非持久化的cookies 持久化的cookies:这可以被称为永久性的cookies,它被存储在客户端的硬盘内...非持久化cookies:也可以被称之为临时性的cookies。如果没有定义失效时间,那么cookie将会被存储在浏览器的内存中。我上面展示的例子就是一个非持久的cookies。...Cookie持久化 HttpClient可以和任意物理表示的实现了CookieStore接口的持久cookie存储一起使用。...保存cookie有两种方式一种是数据库,另一种是SharedPreferences,其中https://www.zalou.cn/article/140423.htm是使用数据库来保存的,这里我是使用

    2.2K20

    Retrofit OKHttp 教你怎么持久化管理Cookie

    鉴于现在Retrofit现在网上很多教程,所以基本的使用方法就不介绍了,小编也不重复造轮子了,如果你还不会用,看看下面几篇文章: Retrofit 2.0使用详解,配合OkHttp、Gson,Android...最强网络请求框架 Retrofit 2.0:有史以来最大的改进 Retrofit初探和简单使用 持久Cookie 今天小编要讲的是,怎么持久化管理你的Cookie,也就是实现用户免登陆过程。...cookie = cookies.get(i); cookieHeader.append(cookie.name()).append('=').append(cookie.value())...().saveFromResponse(userRequest.url(), cookies); } 那么我们该怎么持久化管理呢?...当然你也可以用这个: https://github.com/franmontiel/PersistentCookieJar 都是可以的,这样就完美实现了cookie持久化管理。

    2K100

    Retrofit+OKHttp 教你怎么持久化管理Cookie

    鉴于现在Retrofit现在网上很多教程,所以基本的使用方法就不介绍了,小编也不重复造轮子了,如果你还不会用,看看下面几篇文章: Retrofit 2.0使用详解,配合OkHttp、Gson,Android...最强网络请求框架 Retrofit 2.0:有史以来最大的改进 Retrofit初探和简单使用 持久Cookie 今天小编要讲的是,怎么持久化管理你的Cookie,也就是实现用户免登陆过程。...cookie = cookies.get(i); cookieHeader.append(cookie.name()).append('=').append(cookie.value())...().saveFromResponse(userRequest.url(), cookies); } 那么我们该怎么持久化管理呢?...当然你也可以用这个: https://github.com/franmontiel/PersistentCookieJar 都是可以的,这样就完美实现了cookie持久化管理。

    1.1K30

    Java web Cookie详解(持久化+原理详解+共享问题+设置中文+发送多个Cookie

    cookie用来保存少量及不太敏感的数据 可以在不登入的情况下,对客户端完成身份识别(即在客户端设置一个set-cookie的键值对,在访问的时候使用键值对来获取客户端的身份) 如何使用Cookie...我从以下三个步骤来介绍cookie使用 1.创建cookie对象 2.发送cookie对象 3.获取cookie对象 由Servlet1设置cookie,Servlet2获取cookie Servlet1...Cookie的相关问题 1.如何实现发送多个Cookie 2.Cookie可以在浏览器中保存多长时间 3.Cookie如何保存中文 4.Cookie共享问题 1.如何实现发送多个Cookie 使用...为正数,将Cookie持久化写入硬盘,并且指定存储的时间,时间到了cookie自动失效 2.second为零,删除cookie 3.second小于零,默认值,即浏览器关闭后删除cookie 3.Cookie...特殊字符还是不支持,建议使用URL编码存储,URL解码解析 比如我使用以下代码往Cookie中加入数据发送cookie浏览器就会报错,因为往cookie中加入了空格 Cookie cookie = new

    75720

    ASP.NET AJAX(10)__Authentication ServiceAuthentication ServiceAuthentication Service属性Authentication

    ,这也是一种用法很简单的方式 一个使用FormsAuthentication保护WebService调用的示例 首先创建一个名为ProtectedService的WebService,代码如下 using...("xiaoyaojian", false);//使用FormsAuthentication,登陆Username为xiaoyaojian的用户,false表示不使用持久化的Cookie }...password,//密码 isPersistent,//是否生成持久Cookie customInfo,//预留字段 redirectUrl,//登陆成功后跳转目标 loginCompletedCallback...,//身份验证完成回调函数(是完成,而不是成功) failedCallback,//身份验证出错回调函数(出错,而不是没有通过验证,比如超时) userContext//用户任意指定的上下文对象 );...AJAX方式来验证 Authentication Service属性 timeout属性:设置超时时间(Sys.Service.AuthecticationService.get_timtout()/set_timeout

    1.8K90

    接口测试平台代码实现121:cookie持久化-4

    上节我们成功搞定了普通接口调用登陆态cookie保持会话的后台逻辑,本节我们要去搞用例库相关的逻辑。 所以我们要改的函数是那个run_case文件,它是负责动态生成用例的。...在它的demo函数中,我们写好了登陆态的插入等操作,不过现在,我们加入了cookie的设置,所以demo函数也要进行对应的兼容。...所以让我们先来回顾一下目前逻辑: 首先这个demo函数是被数次执行的,每一个步骤接口,都会执行一次demo函数,每次之间,他们的数据共享,也就是我们的登陆态接口的返回值,是通过global 变成全局变量 来保存并使用的...但是我们为了避免多次调用登陆态接口,所以在每次去使用的时候先判断一下,是否存在公共变量,若存在就不用调用生成新的登陆态字段了,直接拿来用。但是如果没有,那么就只能去调用生成了。...持久化的操作就算全部完成了!

    17720

    接口测试平台代码实现120:cookie持久化-3

    本节我们来把接口库普通接口调试功能中的登陆态接口的cookie保持对话功能完善。...但是现在如果是cookie持久化的话,那么返回的就是a,a是什么呢?我们不用关心,反正a不是字典就可以了。...所以我们在接收的时候对登陆态返回的东西用类型判断一下,就知道是字典还是a了,若是a,那就是说明登陆态设置的是cookie持久化,那么普通接口的请求代码也要改,也要从requests.request改成a.request...所以我们需要判断login_res的类型看看是不是cookie持久化,若是,那么后面的所有具体不同的请求体类型的请求代码,直接全换即可。...然后是各种请求体: 首先是none: 其实就是简单判断了下,如果是字典那么还是之前的requests.request,如果不是,那么就是cookie持久化,那么就用a.requests来请求,此时a就是

    20930

    关于ASP.NET MVC中使用Forms验证的问题

    这些信息被存放在加密过的cookie里面,这些cookie和响应绑定在一起,因此每一次后续请求都会被自动提交到服务器。...如果用户验证成功,你只需要告诉ASP.NET架构验证成功(通过调用FormsAuthentication类的一个方法),运行库会自动设置验证cookie(实际上包含了票据)并将用户转到原先请求的页面。...通过这个请求,运行库检测到验证cookie中包含一个有效票据,然后赋给用户对这个页面的访问权限。 下面,就是具体的实现。..., FormsAuthentication.Encrypt(Ticket)); } 其中Biz126.Cache.SetCookies.AddCookie是我自己封装的保存Cookie方法。...];//获取cookie FormsAuthenticationTicket Ticket = FormsAuthentication.Decrypt(authCookie.Value

    1.4K20

    登陆后设置cookie的方法

    public void SetCookie(string userName, string role,string cookieValueName) {FormsAuthentication.FormsCookieName...userName, System.DateTime.Now.AddMinutes(30),DateTime.Now, false, role); string encryptTick=FormsAuthentication.Encrypt...System.DateTime.Now.AddMinutes(30); HttpContext.Current.Response.Cookies.Add(myCookie); } 这是我登陆后设置cookie...的方法,本来cookieValueName是用FormsAuthentication.FormsCookieName替代的,突然有一天发总是得到null值,(目前情况也不明,可能是多个cookie的问题...[也不太像,之前好好的,突然就变了]) 之后,直接改名传固定值"CQSPACE",之后也一直发现得不到值,换了N种Cookie写法,N种修改方法,也发现无效,两天后,新建一工程,发现可以得到值,就是自己的项目无法值

    1.5K70

    HttpURLConnection 中Cookie 使用

    如果想通过 HttpURLConnection 访问网站,网站返回cookie信息,下次再通过HttpURLConnection访问时,把网站返回 cookie信息再返回给该网站。可以使用下面代码。...信息存储起来,下次访问网站的时候,自动帮你把cookie信息带上。...Paste_Image.png 循环cookies中的cookie,根据设置的CookiePolicy来判断是否接收该Cookie信息, 如果接收则存储到CookieStore。...再次访问网站的时候调用CookieHandler中的get方法获取该uri响应的cookie,并提交到该站点中。 这样开发人员就不需要干预cookie信息,则每次访问网站会自动携带cookie。...代码示例 本例子中使用到了CookieHandler、CookieManager 、CookieStore、 HttpCookie。

    3.4K120

    接口测试平台代码实现118:登陆态cookie持久

    但是有些平台却不是靠这样的方式来保持登陆态的,他们用的是cookie,最常见的就是web端。...可能大家平时用postman做web端的接口测试会发现,我们的普通接口是要利用统一的cookie插入到请求头中,才可以实现带登陆状态。那么在我们接口测试平台中,要怎么使用呢?...所以我们接下来要在登陆态接口的模块中加入这种方式,也就是把cookie持久化,来让后续的所有普通接口都可以自动享受到登陆状态,而从用户的角度看,整个操作没有任何卡顿,甚至不用关心这个登陆态到底是什么原理加入的...其实核心的使用就是requests.session() 方法 例子: a = requests.session() 登陆接口 = a.request(url,method,headers...在前端的登陆态接口设置中提取返回值的设置中加入特殊字符串“cookie”,若后台检测到这个特殊字符串“cookie”,则放弃进行返回值提取,而是转为采用会话保持的功能。

    37430
    领券