如何在.net核心中使用JwtSecurityTokenHandler和Compression DEFLATE生成/验证JWT令牌

时间:2018-08-31 10:03:59

标签: c# asp.net-core compression jwt

在Java中,我看到它具有选项

JwtBuilder b = Jwts.builder()
.compressWith(CompressionCodecs.DEFLATE); 

但是在.net核心中,我不知道如何生成用DEFLATE压缩的JWT令牌,类似于Java。我希望有人能帮助我。

1 个答案:

答案 0 :(得分:1)

您可以创建和应用自己的压缩提供程序。例如,使用 Deflate 压缩:

using Microsoft.AspNetCore.ResponseCompression;
using System.IO;
using System.IO.Compression;

namespace CompressionApp
{
    public class DeflateCompressionProvider : ICompressionProvider
    {
        public string EncodingName => "deflate";
        public bool SupportsFlush => true;

        public Stream CreateStream(Stream outputStream)
        {
            return new DeflateStream(outputStream, CompressionLevel.Optimal);
        }
    }
}

EncodingName属性指定客户端支持的压缩格式。该格式包含在对服务器的请求中的Accept-Encoding标头中,例如:

Accept-Encoding: gzip, deflate, sdch, br

也就是说,如果客户端在请求中的deflate标头中发送了Accept-Encoding的值,则此提供程序将起作用。

SupportsFlush属性指定是否将记录重置为流。

CreateStream ()方法在压缩或实际包装作为参数传递给该方法的初始响应线程之后,返回响应流本身。为了进行压缩,使用了内置类DeflateStream()。

ConfigureServices()类的Startup方法中应用此提供程序:

public void ConfigureServices(IServiceCollection services)
{
    services.AddResponseCompression(options =>
    {
        options.Providers.Add(new DeflateCompressionProvider());
    });
}

要添加提供者,将调用options.Providers.Add()方法。