码迷,mamicode.com
首页 > Web开发 > 详细

ASP.NET Core2.2 和2.1 版本中对cookie的设置和存储

时间:2019-03-28 00:45:29      阅读:339      评论:0      收藏:0      [点我收藏+]

标签:protect   image   启用   js代码   use   message   startup   发送   .net   

1.需要在startup.cs中添加cookie的服务

 services.Configure<CookiePolicyOptions>(option =>{
                option.CheckConsentNeeded=ContextBoundObject=>true;
                option.MinimumSameSitePolicy=SameSiteMode.None;
            }); //添加cookie的服务

图示:

技术图片

2.在startup.cs中启动服务

 app.UseCookiePolicy();      //启用cookie服务

图示:

技术图片

startup.cs中添加的引用:

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.DependencyInjection;


//参数验证,路由的参数验证配置
using Microsoft.AspNetCore.Routing;
using Microsoft.AspNetCore.Routing.Constraints;
//mysql基础配置引用
using Online.Examination.Web.Repositories;
using Online.Examination.Web.Controllers;
using Online.Examination.Web.Repositories.DBBase;

图示:

技术图片

3.在控制层使用Append方法向客户端添加cookie 

//cookie的引用    需要引用这三个包

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.CookiePolicy;
using Microsoft.AspNetCore.Http.Features;

图示: 

技术图片技术图片

4.最后一步:很重要  如果服务器要想客户端存储cookie,客户端需要向服务器发送第一次请求,请求允许使用cookie

所以需要在控制层中写入方法,这个方法只需要请求一次,就可以向客户端存储cookie了

技术图片

5.js代码示例

 

$(function() {
    $.post("/login/OkCookie", function() {}) //如果使用cookie,客户端必须向服务端发送一次请求////
})

function login() {
    $(".error").text("");
    var uname = $("input[name=‘name‘]").val();
    var pwd = $("input[name=‘pwd‘]").val();
    var type = $("input[name=‘login_type‘]:checked").val();
    if (uname == "" || pwd == "") return false;
    $.post("/login/login", { "uname": uname, "pwd": pwd, "type": type }, function(msg) {
        if (msg.message == "success") {
            window.location.href = "index.html?id=" + msg.users.name;
        } else {
            $(".error").text("密码或账号错误");
        }
    })
}

 

图示:

技术图片

技术图片

 6.关于cookie其他的使用方法

代码:

 protected void DeleteCookies(string key)    //删除指定的cookie
        {
            HttpContext.Response.Cookies.Delete(key);
        }

        protected string GetCookies(string key)     //获取指定的cookie
        {
            HttpContext.Request.Cookies.TryGetValue(key, out string value);
            if (string.IsNullOrEmpty(value))
                value = string.Empty;
            return value;
        }

 

 

 

图示:

技术图片

 

ASP.NET Core2.2 和2.1 版本中对cookie的设置和存储

标签:protect   image   启用   js代码   use   message   startup   发送   .net   

原文地址:https://www.cnblogs.com/han-guang-xue/p/10612265.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!