900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > 转载牛人的ASP.NET Cookies简单应用 记住用户名和密码

转载牛人的ASP.NET Cookies简单应用 记住用户名和密码

时间:2020-01-16 14:47:13

相关推荐

转载牛人的ASP.NET Cookies简单应用 记住用户名和密码

不要试图给Password类型的TextBox赋值!

在中,不要试图给Password类型的TextBox控件赋值! 无论是在设计或是运行时,都不可以的。

猜测的原因是,password类型的TextBox控件从根本上,没有Text属性的Set方法,只有Get !!

同样,html中的Input控件,如果设置为ruanat="server",password类型的Input控件也是一样。无论是在设计或是运行时,都不容许设置它的值。

解决办法:txtPassword.Attributes["value"] = "123";

前言

一般只要有会员、用户机制的网站或论坛在登录的时候都会有这么一个复选框——[记住我的名字 | 两周内不再登陆 |],说法较多,实现起来差不多,本文做了一个简单的例子并附带了一个C# Cookies帮助类 CookiesHelper.cs和实现代码片段,希望能对初学者有帮助: )

正文

CookiesHelper.cs

usingSystem;

usingSystem.Collections.Generic;

usingSystem.Text;

usingSystem.Web;

namespaceTLibrary.ObjectHelper

{

publicclassCookiesHelper

{

#region获取Cookie

///<summary>

///获得Cookie的值

///</summary>

///<paramname="cookieName"></param>

///<returns></returns>

publicstaticstringGetCookieValue(stringcookieName)

{

returnGetCookieValue(cookieName,null);

}

///<summary>

///获得Cookie的值

///</summary>

///<paramname="cookieName"></param>

///<paramname="key"></param>

///<returns></returns>

publicstaticstringGetCookieValue(stringcookieName,stringkey)

{

HttpRequestrequest=HttpContext.Current.Request;

if(request!=null)

returnGetCookieValue(request.Cookies[cookieName],key);

return"";

}

///<summary>

///获得Cookie的子键值

///</summary>

///<paramname="cookie"></param>

///<paramname="key"></param>

///<returns></returns>

publicstaticstringGetCookieValue(HttpCookiecookie,stringkey)

{

if(cookie!=null)

{

if(!string.IsNullOrEmpty(key)&&cookie.HasKeys)

returncookie.Values[key];

else

returncookie.Value;

}

return"";

}

///<summary>

///获得Cookie

///</summary>

///<paramname="cookieName"></param>

///<returns></returns>

publicstaticHttpCookieGetCookie(stringcookieName)

{

HttpRequestrequest=HttpContext.Current.Request;

if(request!=null)

returnrequest.Cookies[cookieName];

returnnull;

}

#endregion

#region删除Cookie

///<summary>

///删除Cookie

///</summary>

///<paramname="cookieName"></param>

publicstaticvoidRemoveCookie(stringcookieName)

{

RemoveCookie(cookieName,null);

}

///<summary>

///删除Cookie的子键

///</summary>

///<paramname="cookieName"></param>

///<paramname="key"></param>

publicstaticvoidRemoveCookie(stringcookieName,stringkey)

{

HttpResponseresponse=HttpContext.Current.Response;

if(response!=null)

{

HttpCookiecookie=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>

///<paramname="cookieName"></param>

///<paramname="key"></param>

///<paramname="value"></param>

publicstaticvoidSetCookie(stringcookieName,stringkey,stringvalue)

{

SetCookie(cookieName,key,value,null);

}

///<summary>

///设置Cookie值

///</summary>

///<paramname="key"></param>

///<paramname="value"></param>

publicstaticvoidSetCookie(stringkey,stringvalue)

{

SetCookie(key,null,value,null);

}

///<summary>

///设置Cookie值和过期时间

///</summary>

///<paramname="key"></param>

///<paramname="value"></param>

///<paramname="expires"></param>

publicstaticvoidSetCookie(stringkey,stringvalue,DateTimeexpires)

{

SetCookie(key,null,value,expires);

}

///<summary>

///设置Cookie过期时间

///</summary>

///<paramname="cookieName"></param>

///<paramname="expires"></param>

publicstaticvoidSetCookie(stringcookieName,DateTimeexpires)

{

SetCookie(cookieName,null,null,expires);

}

///<summary>

///设置Cookie

///</summary>

///<paramname="cookieName"></param>

///<paramname="key"></param>

///<paramname="value"></param>

///<paramname="expires"></param>

publicstaticvoidSetCookie(stringcookieName,stringkey,stringvalue,DateTime?expires)

{

HttpResponseresponse=HttpContext.Current.Response;

if(response!=null)

{

HttpCookiecookie=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>

///<paramname="key"></param>

///<paramname="value"></param>

publicstaticvoidAddCookie(stringkey,stringvalue)

{

AddCookie(newHttpCookie(key,value));

}

///<summary>

///添加Cookie

///</summary>

///<paramname="key"></param>

///<paramname="value"></param>

///<paramname="expires"></param>

publicstaticvoidAddCookie(stringkey,stringvalue,DateTimeexpires)

{

HttpCookiecookie=newHttpCookie(key,value);

cookie.Expires=expires;

AddCookie(cookie);

}

///<summary>

///添加为Cookie.Values集合

///</summary>

///<paramname="cookieName"></param>

///<paramname="key"></param>

///<paramname="value"></param>

publicstaticvoidAddCookie(stringcookieName,stringkey,stringvalue)

{

HttpCookiecookie=newHttpCookie(cookieName);

cookie.Values.Add(key,value);

AddCookie(cookie);

}

///<summary>

///添加为Cookie集合

///</summary>

///<paramname="cookieName">Cookie名称</param>

///<paramname="expires">过期时间</param>

publicstaticvoidAddCookie(stringcookieName,DateTimeexpires)

{

HttpCookiecookie=newHttpCookie(cookieName);

cookie.Expires=expires;

AddCookie(cookie);

}

///<summary>

///添加为Cookie.Values集合

///</summary>

///<paramname="cookieName"></param>

///<paramname="key"></param>

///<paramname="value"></param>

///<paramname="expires"></param>

publicstaticvoidAddCookie(stringcookieName,stringkey,stringvalue,DateTimeexpires)

{

HttpCookiecookie=newHttpCookie(cookieName);

cookie.Expires=expires;

cookie.Values.Add(key,value);

AddCookie(cookie);

}

///<summary>

///添加Cookie

///</summary>

///<paramname="cookie"></param>

publicstaticvoidAddCookie(HttpCookiecookie)

{

HttpResponseresponse=HttpContext.Current.Response;

if(response!=null)

{

//指定客户端脚本是否可以访问[默认为false]

cookie.HttpOnly=true;

//指定统一的Path,比便能通存通取

cookie.Path="/";

//设置跨域,这样在其它二级域名下就都可以访问到了

//cookie.Domain="";

response.AppendCookie(cookie);

}

}

#endregion

}

}

代码注意事项:

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

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

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

以下看实际调用代码

页面加载

protectedvoidPage_Load(objectsender,EventArgse)

{

if(!IsPostBack)

{

HttpCookieCookie=CookiesHelper.GetCookie("UserInfo");

if(Cookie!=null)

{

this.txtUserName.Value=Cookie.Values["uName"];

}

}

}

代码说明:

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

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

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

登录验证

stringuName=this.txtUserName.Value.Trim();

//验证用户名密码

if(IsLogin(uName,this.txtPass.Value.Trim()))

{

//记住我的名字

if(!string.IsNullOrEmpty(Request["remUsername"]))

{

HttpCookieCookie=CookiesHelper.GetCookie("UserInfo");

if(Cookie==null)

{

Cookie=newHttpCookie("UserInfo");

Cookie.Values.Add("uName",uName);

//设置Cookie过期时间

Cookie.Expires=DateTime.Now.AddDays(365);

CookiesHelper.AddCookie(Cookie);

}

elseif(!Cookie.Values["uName"].Equals(uName))

CookiesHelper.SetCookie("UserInfo","uName",uName);

}

Response.Redirect("~/index.aspx");

}

代码说明:

补充

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

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

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

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

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。