开发随笔记录——关于Swagger无法上传文件问题解决方案。

首先自己先创建一个SwaggerFileUploadFilter类集成IOperationFilter接口。接口可导入Swashbuckle.AspNetCore.SwaggerGen管理包。

    public class SwaggerFileUploadFilter : IOperationFilter
    {
        public void Apply(OpenApiOperation operation, OperationFilterContext context)
        {
            //判断上传文件的类型,只有上传的类型是IFormCollection的才进行重写。
            if (context.ApiDescription.ActionDescriptor.Parameters.Any(w => w.ParameterType == typeof(IFormCollection)))
            {
                Dictionary<string, OpenApiSchema> schema = new Dictionary<string, OpenApiSchema>();
                schema["fileName"] = new OpenApiSchema { Description = "Select file", Type = "string", Format = "binary" };
                Dictionary<string, OpenApiMediaType> content = new Dictionary<string, OpenApiMediaType>();
                content["multipart/form-data"] = new OpenApiMediaType { Schema = new OpenApiSchema { Type = "object", Properties = schema } };
                operation.RequestBody = new OpenApiRequestBody() { Content = content };
            }
        }
    }

之后Startup.cs里面找到ConfigureServices方法,在该方法里面的services.AddSwaggerGen中添加如下代码:

 options.OperationFilter<SwaggerFileUploadFilter>();

之后启动测试即可了。

posted @ 2021-07-06 10:56  苏瑾~  阅读(2205)  评论(0)    收藏  举报