Если вы хотите установить cookie-файл с несколькими значениями или «подразделами» и сделать их читаемыми из .NET, вам необходимо сохранить подраздел как пары имя-значение, отформатированные как строка запроса.Вы можете использовать метод jQuery.param () для преобразования объекта Javascript в строку запроса.
var obj = { email: 'jdoe@example.com', username: 'jdoe' };
$.cookie("MyTestCookie", $.param(obj), { expires: 10 });
Затем на сервере вы можете получить доступ к значениям как:
var email = Request.Cookies["MyTestCookie"]["email"];
var username = Request.Cookies["MyTestCookie"]["username"];
РЕДАКТИРОВАТЬ: Я создал тестовую страницу, чтобы показать чтение / запись многозначных куки как на сервере, так и на клиенте.http://www.systemex.net/Cookies/
ПРИМЕЧАНИЯ:
- Вам необходимо позаботиться о том, чтобы избежать или убрать подразделы.Таким образом, любые встроенные = и & обрабатываются корректно
- При чтении и записи файлов cookie jquery используйте параметр {raw: true}, чтобы он не удваивался.
- Я написал $ .deparamфункция, которая преобразует строку name = value & name2 = value2 в объект javascript {name: value, name2: value2}
- И последнее: плагин cookie jquery не перезаписывает cookie с тем же именем, он простодобавляет его к текущей коллекции файлов cookie.На этом этапе, вероятно, было бы лучше переписать плагин для поддержки подразделов и изменения существующих файлов cookie.
В любом случае, надеюсь, это поможет.
Вот Default.aspx
<h1>Get Cookie From Server:</h1>
<ul>
<li>Email: <%= GetCookie("MyTestCookie", "email")%></li>
<li>Username: <%= GetCookie("MyTestCookie", "username")%></li>
</ul>
<h1>Get Cookie From Client:</h1>
<ul>
<li>Email: <span class="cookie" data-name="MyTestCookie" data-key="email" /></li>
<li>Username: <span class="cookie" data-name="MyTestCookie" data-key="username" /></li>
<li>Raw: <span id="raw" /></li>
</ul>
<h1>Set Cookie From Client:</h1>
<ul>
<li>Email: <input type="text" name="email" value="" /></li>
<li>Username: <input type="text" name="username" value="" /></li>
</ul>
<input type="submit" value="Submit" />
<script>
$(function () {
$(".cookie").each(function (index) {
var name = $(this).data('name');
var key = $(this).data('key');
var cookie = $.deparam($.cookie(name, { raw: true }));
$(this).html(cookie[key]);
});
$('#raw').text(escape($.cookie("MyTestCookie"), { raw: true }));
$("form").submit(function () {
var o = {};
o.email = $('input[name=email]').val();
o.username = $('input[name=username]').val();
var value = $.param(o);
var cookie = $.cookie('MyTestCookie', value, { raw: true });
return true;
});
});
jQuery.deparam = function (params) {
var o = {};
if (!params) return o;
var a = params.split('&');
for (var i = 0; i < a.length; i++) {
var pair = a[i].split('=');
o[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1]);
}
return o;
}
</script>
Default.aspx.cs
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
var cookie = new HttpCookie("MyTestCookie");
cookie["email"] = HttpUtility.UrlEncode("jdoe@example.com");
cookie["username"] = HttpUtility.UrlEncode("jdoe&123");
Response.Cookies.Add(cookie);
}
}
public string GetCookie(string name, string key)
{
var cookie = Request.Cookies[name];
return cookie != null ? HttpUtility.UrlDecode(cookie[key]) : "";
}