asp.netcore下的如何给网站做安全设置

首先,我们来看下stack overflow网站的请求头文件:
asp.netcore下的如何给网站做安全设置

可以看到一些我们熟悉或是陌生的HTTP头部文件字段。
在这里我们在对HTTP输入流的头部文件中,做一些基本的防护。首先要明确,既然我们是对HTTP头部做处理,那么就需要在Startup.cs类的
Configuration方法中做处理,因为这里就是处理HTTP输入流的。

首先做一些基本的处理,比如中间件和基本的类:

public class SecurityHeadersPolicy { public IDictionary<string, string> SetHeaders { get; } = new Dictionary<string, string>(); public ISet<string> RemoveHeaders { get; } = new HashSet<string>(); }

这里的头部信息是我们定义好的,用来增加或是删除头部信息,然后就是我们的中间件:

public class SecurityHeadersMiddleware { private readonly RequestDelegate _next; private readonly SecurityHeadersPolicy _policy; public SecurityHeadersMiddleware(RequestDelegate next, SecurityHeadersPolicy policy) { _next = next; _policy = policy; } public async Task Invoke(HttpContext context) { IHeaderDictionary headers = context.Response.Headers; foreach (var headerValuePair in _policy.SetHeaders) { headers[headerValuePair.Key] = headerValuePair.Value; } foreach (var header in _policy.RemoveHeaders) { headers.Remove(header); } await _next(context); } }

基于IApplicationBuilder接口做一个中间件的扩展方法:

public static class MiddlewareExtensions { public static IApplicationBuilder UseSecurityHeadersMiddleware(this IApplicationBuilder app, SecurityHeadersBuilder builder) { SecurityHeaderPolicy policy = builder.Build(); return app.UseMiddleware<SecurityHeadersMiddleware>(policy); } }

封装好相关的安全类:

public class SecurityHeadersBuilder { private readonly SecurityHeadersPolicy _policy = new SecurityHeadersPolicy(); public SecurityHeadersBuilder AddDefaultSecurePolicy() { AddFrameOptionsDeny(); AddXssProtectionBlock(); AddContentTypeOptionsNoSniff(); AddStrictTransportSecurityMaxAge(); RemoveServerHeader(); return this; } public SecurityHeadersBuilder AddFrameOptionsDeny() { _policy.SetHeaders[FrameOptionsConstants.Header] = FrameOptionsConstants.Deny; return this; } public SecurityHeadersBuilder AddFrameOptionsSameOrigin() { _policy.SetHeaders[FrameOptionsConstants.Header] = FrameOptionsConstants.SameOrigin; return this; } public SecurityHeadersBuilder AddFrameOptionsSameOrigin(string uri) { _policy.SetHeaders[FrameOptionsConstants.Header] = string.Format(FrameOptionsConstants.AllowFromUri, uri); return this; } public SecurityHeadersBuilder RemoveServerHeader() { _policy.RemoveHeaders.Add(ServerConstants.Header); return this; } public SecurityHeadersBuilder AddCustomHeader(string header, string value) { _policy.SetHeaders[header] = value; return this; } public SecurityHeadersBuilder RemoveHeader(string header) { _policy.RemoveHeaders.Add(header); return this; } public SecurityHeadersPolicy Build() { return _policy; } }

最后注入到HTTP的输入流中:

app.UseSecurityHeadersMiddleware(new SecurityHeadersBuilder() .AddDefaultSecurePolicy() );

然后我们浏览一下网页,就可以在HTTP的头部信息中看到:

HTTP/1.1 200 OK Content-Type: text/html; charset=utf-8 X-Frame-Options: DENY X-XSS-Protection: 1; mode=block X-Content-Type-Options: nosniff Strict-Transport-Security: max-age=31536000 X-Powered-By: ASP.NET

还有一个就是CSRF的防护,如果之前你用过ASP.NET MVC,在最基本的MVC模板中,可能你会留意到已有的cshtml页面中的form表单有这么一句:

@Html.AntiForgeryToken()

这就是微软在MVC框架中为我们提供的防护CSRF的方法。我们在表单中直接使用上面那句代码就可以了,然后在表单提交的Action方法中:

[ValidateAntiForgeryToken] [HttpPost] public IActionResult AntiForm(string message) { return Content(message); }

使用[ValidateAntiForgeryToken]属性,来验证CSRF。

参考链接:
How to add security headers in ASP.NET Core using custom middleware(如何使用自定义中间件在ASP.NET Core中添加安全标头)

初探CSRF在ASP.NET Core中的处理方式

代码地址:
https://github.com/RyanOvO/aspnetcore-fileup-demo

原文链接:https://www.cnblogs.com/zhiyong-ITNote/p/9240633.html

原创文章,作者:优速盾-小U,如若转载,请注明出处:https://www.cdnb.net/bbs/archives/18067

(0)
优速盾-小U的头像优速盾-小U
上一篇 2023年10月29日 16:16
下一篇 2023年10月29日 19:09

相关推荐

  • 揭秘阿里云WAF背后神秘的AI智能防御体系

      背景 应用安全领域,各类攻击长久以来都危害着互联网上的应用,在web应用安全风险中,各类注入、跨站等攻击仍然占据着较前的位置。WAF(Web应用防火墙)正是为防御和阻…

    2023年12月6日
    00724
  • WEB开发-安全原则

    Web安全原则 1.认证模块必须采用防暴力破解机制,例如:验证码或者多次连续尝试登录失败后锁定帐号或IP。 说明:如采用多次连续尝试登录失…

    网站百科 2023年5月24日
    00678
  • Vue项目SEO优化

    Vue SEO 优化:搜索引擎优化 让搜索引擎更好的 定位到相应数据 vue 项目本身不具备SEO基本条件 解决方案一:预渲染 解决方案二:服务端渲染 Nuxt(终极解决方案) S…

    2023年10月22日
    00649
  • Web安全性测试总结

    一、工具扫描 目前web安全扫描器针对 XSS、SQL injection 、OPEN redirect 、PHP File Include漏洞的检测技术已经比较成熟。 商业软件w…

    网站百科 2023年10月16日
    00591
  • ps5dns最快港服2022,ps5dns最快港服2021

    PS5有很多玩家觉得下载游戏太慢了,导致自己无法第一时间玩上各种大作,本次小编就为大家带来最快的港服DNS推荐,让大家可以更稳定的进行下载,下面就一起来看看吧。 首选DNS:114…

    2023年11月28日
    002.8K
  • git

    git clone 太慢的解决方法 原因:git clone特别慢是因为github.global.ssl.fastly.net域名被限制了。只要找到这个域名对应的ip地址,然后在…

    网站百科 2024年4月18日
    00419
  • 普通企业站的seo优化策略

    这里的普通企业站特指目标关键词竞争力度不大的。针对小型企业站,有一些效率较高的网站seo优化策略,即可达成首页目标关键词的理想排名。 普通企业站更多的重…

    2023年9月22日
    00654
  • Window/Linux网络服务配置与管理视频教程

    课程介绍李享梅,成都信息工程大学信息安全工程学院讲师,自2004年6月进入成都信息工程大学以来,承担了《Liux实用操作系统》、《网络测试技术》、《网络设备配置与管理》、《网络服务…

    网站百科 2025年6月18日
    00209
  • 苏宁安全架构

    苏宁安全架构是伴随苏宁易购一起成长的,经历了从无到有到逐步完善的过程,期间不管是在技术上还是在管理上,都遇到了非常多的难题,但一旦闭环安全体系完善起来后,安全事件发现、处理效率会得…

    网站百科 2024年3月15日
    00404
  • 企业为什么要做SEO?

    1、提升流量并获客:通过SEO优化,可以让企业通过网站获得精准潜在用户的搜索,从而使企业获得更多网络订单。 2、提升知名度:通过SEO优化,让网民通过搜索行业关键词时,在搜索引擎首…

    网站百科 2023年9月6日
    00450

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

优速盾注册领取大礼包www.cdnb.net
/sitemap.xml