开发者社区> walb呀> 正文

ASP.NET Cookies简单应用 [ASP.NET | Cookies]

简介:
+关注继续查看

 CookiesHelper.cs

using System;
using System.Collections.Generic;
using System.Text;
using System.Web;

namespace TLibrary.ObjectHelper
{
    
public class CookiesHelper
    {

        
#region 获取Cookie

        
/// <summary>
        
/// 获得Cookie的值
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <returns></returns>
        public static string GetCookieValue(string cookieName)
        {
            
return GetCookieValue(cookieName, null);
        }

        
/// <summary>
        
/// 获得Cookie的值
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <param name="key"></param>
        
/// <returns></returns>
        public static string GetCookieValue(string cookieName,string key)
        {
            HttpRequest request 
= HttpContext.Current.Request;
            
if (request != null)
                
return GetCookieValue(request.Cookies[cookieName], key);
            
return "";
        }

        
/// <summary>
        
/// 获得Cookie的子键值
        
/// </summary>
        
/// <param name="cookie"></param>
        
/// <param name="key"></param>
        
/// <returns></returns>
        public static string GetCookieValue(HttpCookie cookie, string key)
        {
            
if (cookie != null)
            {
                
if (!string.IsNullOrEmpty(key) && cookie.HasKeys)
                    
return cookie.Values[key];
                
else
                    
return cookie.Value;
            }
            
return "";
        }

        
/// <summary>
        
/// 获得Cookie
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <returns></returns>
        public static HttpCookie GetCookie(string cookieName)
        {
            HttpRequest request 
= HttpContext.Current.Request;
            
if (request != null)
                
return request.Cookies[cookieName];
            
return null;
        }

        
#endregion

        
#region 删除Cookie

        
/// <summary>
        
/// 删除Cookie
        
/// </summary>
        
/// <param name="cookieName"></param>
        public static void RemoveCookie(string cookieName)
        {
            RemoveCookie(cookieName,
null);
        }

        
/// <summary>
        
/// 删除Cookie的子键
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <param name="key"></param>
        public static void RemoveCookie(string cookieName,string key)
        {
            HttpResponse response 
= HttpContext.Current.Response;
            
if (response != null)
            {
                HttpCookie cookie 
= response.Cookies[cookieName];
                
if (cookie != null)
                {
                    
if (!string.IsNullOrEmpty(key) && cookie.HasKeys)
                        cookie.Values.Remove(key);
                    
else
                        response.Cookies.Remove(cookieName);
                }
            }
        }

        
#endregion

        
#region 设置/修改Cookie

        
/// <summary>
        
/// 设置Cookie子键的值
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        public static void SetCookie(string cookieName, string key, string value)
        {
            SetCookie(cookieName, key, value, 
null);
        }

        
/// <summary>
        
/// 设置Cookie值
        
/// </summary>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        public static void SetCookie(string key, string value)
        {
            SetCookie(key, 
null, value, null);
        }

        
/// <summary>
        
/// 设置Cookie值和过期时间
        
/// </summary>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        
/// <param name="expires"></param>
        public static void SetCookie(string key, string value, DateTime expires)
        {
            SetCookie(key, 
null, value, expires);
        }

        
/// <summary>
        
/// 设置Cookie过期时间
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <param name="expires"></param>
        public static void SetCookie(string cookieName, DateTime expires)
        {
            SetCookie(cookieName, 
nullnull, expires);
        }

        
/// <summary>
        
/// 设置Cookie
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        
/// <param name="expires"></param>
        public static void SetCookie(string cookieName, string key, string value, DateTime? expires)
        {
            HttpResponse response 
= HttpContext.Current.Response;
            
if (response != null)
            {
                HttpCookie cookie 
= response.Cookies[cookieName];
                
if (cookie != null)
                {
                    
if (!string.IsNullOrEmpty(key) && cookie.HasKeys)
                        cookie.Values.Set(key, value);
                    
else
                        
if (!string.IsNullOrEmpty(value))
                            cookie.Value 
= value;
                    
if (expires != null)
                        cookie.Expires 
= expires.Value;
                    response.SetCookie(cookie);
                }
            }
            
        }

        
#endregion

        
#region 添加Cookie

        
/// <summary>
        
/// 添加Cookie
        
/// </summary>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        public static void AddCookie(string key, string value)
        {
            AddCookie(
new HttpCookie(key, value));
        }

        
/// <summary>
        
/// 添加Cookie
        
/// </summary>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        
/// <param name="expires"></param>
        public static void AddCookie(string key, string value, DateTime expires)
        {
            HttpCookie cookie 
= new HttpCookie(key, value);
            cookie.Expires 
= expires;
            AddCookie(cookie);
        }

        
/// <summary>
        
/// 添加为Cookie.Values集合
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        public static void AddCookie(string cookieName,string key, string value)
        {
            HttpCookie cookie 
= new HttpCookie(cookieName);
            cookie.Values.Add(key, value);
            AddCookie(cookie);
        }

        
/// <summary>
        
/// 添加为Cookie集合
        
/// </summary>
        
/// <param name="cookieName">Cookie名称</param>
        
/// <param name="expires">过期时间</param>
        public static void AddCookie(string cookieName, DateTime expires)
        {
            HttpCookie cookie 
= new HttpCookie(cookieName);
            cookie.Expires 
= expires;
            AddCookie(cookie);
        }

        
/// <summary>
        
/// 添加为Cookie.Values集合
        
/// </summary>
        
/// <param name="cookieName"></param>
        
/// <param name="key"></param>
        
/// <param name="value"></param>
        
/// <param name="expires"></param>
        public static void AddCookie(string cookieName, string key, string value, DateTime expires)
        {
            HttpCookie cookie 
= new HttpCookie(cookieName);
            cookie.Expires 
= expires;
            cookie.Values.Add(key, value);
            AddCookie(cookie);
        }

        
/// <summary>
        
/// 添加Cookie
        
/// </summary>
        
/// <param name="cookie"></param>
        public static void AddCookie(HttpCookie cookie)
        {
            HttpResponse response 
= HttpContext.Current.Response;
            
if (response != null)
            {
                
//指定客户端脚本是否可以访问[默认为false]
                cookie.HttpOnly = true;         
                
//指定统一的Path,比便能通存通取
                cookie.Path = "/";
                
//设置跨域,这样在其它二级域名下就都可以访问到了
                
//cookie.Domain = "chinesecoo.com";
                response.AppendCookie(cookie);
            }
        }

        
#endregion
    }
}

代码注意事项:

          1.     Cookies添加的时候注意一个Cookie可以添加多个子键

          2.     假如你不显示的设置   HttpCookie.Expires   那么此   cookie   生命期即为浏览器进程——关闭浏览器则过期

          3.     需要了解HttpCookie.Domain和HttpCookie.Path这两个属性,对于跨域和存储路径等高级应用有帮助

以下看实际调用代码

          页面加载

    protected void Page_Load(object sender, EventArgs e)
    {
        
if (!IsPostBack)
        {
            HttpCookie Cookie 
= CookiesHelper.GetCookie("UserInfo");
            
if (Cookie != null)
            {
                
this.txtUserName.Value = Cookie.Values["uName"];
            }
        }
    }

          代码说明:

                    1.     this.txtUserName是界面上输入用户名的控件,换成自己的控件名称就行;

                    2.     UserInfo为Cookie的名称,uName为Cookie的子键。

          这段代码的功能是在页面加载的时候显示用户Cookie中记录的用户名,这里也可以做成连密码一起记录然后在这里显示,这样用户就可以直接点登录按钮了

          登录验证

        string uName = this.txtUserName.Value.Trim();

        
//验证用户名密码
        if (IsLogin(uName, this.txtPass.Value.Trim()))
        {
            
//记住我的名字
            if (!string.IsNullOrEmpty(Request["remUsername"]))
            {
                HttpCookie Cookie 
= CookiesHelper.GetCookie("UserInfo");
                
if (Cookie == null)
                {
                    Cookie 
= new HttpCookie("UserInfo");
                    Cookie.Values.Add(
"uName", uName);
                    
//设置Cookie过期时间
                    Cookie.Expires = DateTime.Now.AddDays(365);
                    CookiesHelper.AddCookie(Cookie);
                }
                
else if (!Cookie.Values["uName"].Equals(uName))
                    CookiesHelper.SetCookie(
"UserInfo""uName", uName);
            }
            Response.Redirect(
"~/index.aspx");
        }

          代码说明:

                    1.     this.txtUserName和this.txtPass是界面上输入用户名和密码的控件,换成自己的控件名称就行;

                    2.     IsLogin方法是用来验证用户名和密码是否正确的,这里替换成自己的验证方法就行了。

                    3.     Request["remUsername"]是获得界面上是否选中了[记住我的名称]复选框

          这段代码的功能是在用户登录成功之后,如果选中了记住登录用户名就把用户名存入客户端的Cookie中,并设置过期时间为1年。

补充 

               1.     根据实际的经验,一般的情况下在本地调试不设置Domain属性,挂上服务器上配上域名之后就得指定Domain参数了,否则Cookies出不来的。(2008-11-24 10:32:00)

  本文转自博客园农民伯伯的博客,原文链接:ASP.NET Cookies简单应用 [ASP.NET | Cookies],如需转载请自行联系原博主。   

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
iOS网络编程之七——本地用户凭证Cookie的应用
iOS网络编程之七——本地用户凭证Cookie的应用
33 0
Servlet第六篇【Session介绍、API、生命周期、应用、与Cookie区别】
什么是Session Session 是另一种记录浏览器状态的机制。不同的是Cookie保存在浏览器中,Session保存在服务器中。用户使用浏览器访问服务器的时候,服务器把用户的信息以某种的形式记录在服务器,这就是Session 如果说Cookie是检查用户身上的”通行证“来确认用户的身份,那么Session就是通过检查服务器上的”客户明细表“来确认用户的身份的。
1254 0
一起谈.NET技术,SharePoint开发笔记-SharePoint2010添加ASP.NET应用程序
大家可能在sharepoint开发webpart会引入一些asp.net的控件,这时候就会需要添加dll引用..下图所示CRSWebControls便是我添加的.   部署这个项目到sharepoint后.
800 0
UWP开发入门(十一)——Attached Property的简单应用
原文:UWP开发入门(十一)——Attached Property的简单应用   UWP中的Attached Property即附加属性,在实际开发中是很常见的,比如Grid.Row:    Grid.Row这个属性并不是Button对象本身的实例方法,而是定义在Grid类型上的static property,实际使用时却又附在其他控件的XAML里。
1071 0
JSTL的简单应用
JSTL   JSP 标准标签库 是由  apache的 jarkata小组开发的 是为了简化 java web开发的工作量  以往需要大量的 java代码完成的 工作 现在只需要简单的  JSTL就可以完成 对于 JSP程序员来说是 一个重要的技术 在多层次架构设计中 有着重要的作用...
606 0
asp.net mvc应用架构的思考--Unity的应用及三层代码
最近要做一个项目,和国外的架构师聊过之后。对方提到了他准备采用asp.net mvc, jquery, Unity 等技术来代替老的技术: 如asp.net web form. 他请我帮他想一些关于架构的东西。
727 0
+关注
1038
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载