.net中WebApi跨域Session为null的问题

前言:

这几天用webapi做后台的数据接口,session一直为null,之前跳过这个坑,今天这方面的业务的时候忘了咋解决的了,自己又弄了好久才解决。今天写个博客记录一下。


问题描述:

由于Net中的webapi是默认不开启的,我们想要使用session必须配置session(别忘了解决跨域的问题,webapi中跨域也是要自己解决的)

解决办法:

如果是前后台分离的话必须进行配置跨域

webapi中解决跨域的方法有2种:

①:在webconfig中配置(<system.webServer>节点下)这种方式有时候会出错

代码如下:

<httpProtocol>
      <customHeaders>
        <add name="Access-Control-Allow-Origin" value="*" />
        <add name="Access-Control-Allow-Headers" value="Content-Type" />
        <add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS" />
      </customHeaders>
    </httpProtocol>

②:

1.在NuGet里下载Cors包(两个都下载)

2.在Global文件里重写Init()

 public override void Init()
        {
            this.PostAuthenticateRequest += (sender, e) => HttpContext.Current.SetSessionStateBehavior(SessionStateBehavior.Required);
            base.Init();
        }

3.在WebApiConfig文件里配置:

 var cors = new EnableCorsAttribute("*", "*", "*");
            //config.EnableCors(new EnableCorsAttribute("*", "*", "*"));
            cors.SupportsCredentials = true;// 允许cookie发送,否则session不可用
            config.EnableCors(cors);

到此为止:问题解决!!

结尾:

        分享:慢慢成长!!

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章