Ответ 1
Вы можете использовать Request.Cookies для чтения куки файлов.
if(Request.Cookies["key"]!=null)
{
var value=Request.Cookies["key"].Value;
}
Я создаю файл cookie и сохраняю значение имени пользователя после succesfull login. Как я могу получить доступ к файлу cookie при открытии веб-сайта. Если файл cookie существует, я хочу заполнить текстовое поле имени пользователя из значения cookie. И как расшифровать значение, чтобы получить имя пользователя. Я выполняю проверку на стороне сервера, получая пользовательские данные из базы данных. Я использую vs 2010 с С#
FormsAuthenticationTicket tkt;
string cookiestr;
HttpCookie ck;
tkt = new FormsAuthenticationTicket(1, txtUserName.Value, DateTime.Now,
DateTime.Now.AddYears(1), chk_Rememberme.Checked, "User Email");
cookiestr = FormsAuthentication.Encrypt(tkt);
ck = new HttpCookie(FormsAuthentication.FormsCookieName, cookiestr);
if (chk_Rememberme.Checked)
{
ck.Expires = tkt.Expiration;
ck.Path = FormsAuthentication.FormsCookiePath;
Response.Cookies.Add(ck);
}
cookie создается с именем как .YAFNET_Authentication и содержимое зашифровывается
WebConfig:
<forms name=".YAFNET_Authentication" loginUrl="Home.aspx"
protection="All" timeout="15000" cookieless="UseCookies"/>
Вы можете использовать Request.Cookies для чтения куки файлов.
if(Request.Cookies["key"]!=null)
{
var value=Request.Cookies["key"].Value;
}
FormsAuthentication.Decrypt принимает фактическое значение cookie, а не его имя. Вы можете получить значение cookie, например
HttpContext.Current.Request.Cookies[FormsAuthentication.FormsCookieName].Value;
и расшифруйте это.
добавьте эту функцию в свой файл global.asax
protected void Application_AuthenticateRequest(Object sender, EventArgs e)
{
string cookieName = FormsAuthentication.FormsCookieName;
HttpCookie authCookie = Context.Request.Cookies[cookieName];
if (authCookie == null)
{
return;
}
FormsAuthenticationTicket authTicket = null;
try
{
authTicket = FormsAuthentication.Decrypt(authCookie.Value);
}
catch
{
return;
}
if (authTicket == null)
{
return;
}
string[] roles = authTicket.UserData.Split(new char[] { '|' });
FormsIdentity id = new FormsIdentity(authTicket);
GenericPrincipal principal = new GenericPrincipal(id, roles);
Context.User = principal;
}
то вы можете использовать HttpContext.Current.User.Identity.Name, чтобы получить имя пользователя. надеюсь, что это поможет
HttpCookie cook = new HttpCookie("testcook");
cook = Request.Cookies["CookName"];
if (cook != null)
{
lbl_cookie_value.Text = cook.Value;
}
else
{
lbl_cookie_value.Text = "Empty value";
}
Ссылка Нажмите здесь