Angular 6和.Net Core 2 - XSRF令牌生成,但在发送回API时为空。
创始人
2024-10-16 08:01:19
0

在Angular 6中使用.Net Core 2时,如果XSRF令牌在发送回API时为空,可能是由于未正确配置Angular的HttpInterceptor所致。以下是一个解决方法的代码示例:

  1. 首先,创建一个名为XsrfInterceptor的HttpInterceptor类,并实现intercept方法:
import { Injectable } from '@angular/core';
import { HttpInterceptor, HttpRequest, HttpHandler, HttpEvent } from '@angular/common/http';
import { Observable } from 'rxjs';

@Injectable()
export class XsrfInterceptor implements HttpInterceptor {
  intercept(req: HttpRequest, next: HttpHandler): Observable> {
    const xsrfToken = localStorage.getItem('xsrfToken'); // 从本地存储中获取XSRF令牌
    if (xsrfToken) {
      req = req.clone({
        headers: req.headers.set('X-XSRF-TOKEN', xsrfToken) // 将XSRF令牌添加到请求头中
      });
    }
    return next.handle(req);
  }
}
  1. 然后,在你的AppModule中将该拦截器提供给HTTP_INTERCEPTORS:
import { NgModule } from '@angular/core';
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
import { XsrfInterceptor } from './xsrf.interceptor';

@NgModule({
  imports: [
    HttpClientModule
  ],
  providers: [
    { provide: HTTP_INTERCEPTORS, useClass: XsrfInterceptor, multi: true } // 提供XsrfInterceptor
  ]
})
export class AppModule { }
  1. 在你的.Net Core 2 API中,确保启用了XSRF令牌生成和验证。在Startup.cs文件的ConfigureServices方法中添加以下代码:
services.AddAntiforgery(options =>
{
    options.HeaderName = "X-XSRF-TOKEN"; // 设置XSRF令牌的请求头名称
    options.Cookie.Name = "XSRF-TOKEN"; // 设置XSRF令牌的Cookie名称
    options.Cookie.HttpOnly = false; // 允许客户端JavaScript访问Cookie
});

通过以上步骤,你的Angular应用程序将会在发送请求时自动添加XSRF令牌到请求头中,并与你的.Net Core 2 API进行验证。确保在登录或获取XSRF令牌时将其存储在本地,以便在每个请求中使用。

相关内容

热门资讯

透视专业!德普之星辅助软件(透... 透视专业!德普之星辅助软件(透视)hh poker辅助器先试用,教程经验(的确有挂)-哔哩哔哩1、h...
hhpoker脚本!fishp... hhpoker脚本!fishpoker透视底牌(透视)方法-切实解密存在有挂1、玩家可以在fishp...
透视开挂!wpk透视插件(透视... 透视开挂!wpk透视插件(透视)wepokerplus透视脚本免费,教程经验(有挂攻略)-哔哩哔哩1...
竞技联盟破解版最新版!德州透视... 竞技联盟破解版最新版!德州透视插件(透视)教程-真是关于是有挂1、超多福利:超高返利,海量正版游戏,...
透视推荐!hh poker软件... 透视推荐!hh poker软件(透视)wepokerplus开挂,教程教材(有挂助手)-哔哩哔哩1、...
epoker有透视吗!wepo... epoker有透视吗!wepoker怎么看牌型(透视)挂-其实分享是真的挂1、这是跨平台的wepok...
透视开挂!wepoker-h5... 透视开挂!wepoker-h5下载(透视)wpk私人局有透视吗,教程烘培(有挂方法)-哔哩哔哩1、w...
wepoker开辅助能查到吗!... wepoker开辅助能查到吗!wepoker有辅助工具吗(透视)方法-果然教你真的有挂wepoker...
透视总结!佛手大菠萝有挂吗(透... 透视总结!佛手大菠萝有挂吗(透视)wepoker挂,教程妙计(有挂细节)-哔哩哔哩1、佛手大菠萝有挂...
wpk模拟器多开!We pok... wpk模拟器多开!We poker辅助器下载(透视)工具-竟然有挂有挂wpk模拟器多开!We pok...