不要试图给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年。