使用Relay和graphql-dotnet上传文件

Jon*_*old 6 asp.net asp.net-mvc graphql relayjs graphql-dotnet

我正在尝试在包含文件的中继中构建一个突变。一旦实现了getFiles()此处引用的方法,就可以:https : //facebook.github.io/relay/docs/api-reference-relay-mutation.html#getfiles

中继发送一个多部分请求,导致来自ASP.NET Core MVC的415错误。

我正在寻找一个工作示例,类似于带有graphql-dotnet库的如何在React-Relay应用程序中上传文件? ” 。

Jon*_*old 4

GraphQL 端点不接受多部分表单 mimetype,因为它不是 JSON。一旦我通过 RootObject 和突变中可用的上下文将它们放入 graphql-dotnet 中,我就可以使用这些文件了。让我失望的是 MVC。

所以我写了一个简单的过滤器:

public class RelayResourceFilter : IResourceFilter
{
    private readonly string jsonMediaType = "application/json";

    public void OnResourceExecuted(ResourceExecutedContext context)
    {
    }

    public void OnResourceExecuting(ResourceExecutingContext context)
    {


        if (!string.Equals(MediaTypeHeaderValue.Parse(context.HttpContext.Request.ContentType).MediaType,
            this.jsonMediaType, StringComparison.OrdinalIgnoreCase))
        {
            var encoder = JavaScriptEncoder.Create();
            var variables = encoder.Encode(context.HttpContext.Request.Form["variables"]);
            var query = encoder.Encode(context.HttpContext.Request.Form["query"]);
            var body = $"{{\"query\":\"{query}\", \"variables\":\"{variables}\"}}";

            byte[] requestData = Encoding.UTF8.GetBytes(body);
            context.HttpContext.Request.Body = new MemoryStream(requestData);
            context.HttpContext.Request.ContentType = this.jsonMediaType;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

注册了它:

services.AddScoped<RelayResourceFilter>();
Run Code Online (Sandbox Code Playgroud)

然后在控制器中像这样应用它:

[ServiceFilter(typeof(RelayResourceFilter))]
    public async Task<ExecutionResult> Post([FromBody]GraphQLQuery query, bool? useErrorCode)
{
var files = this.Request.HasFormContentType ? this.Request.Form.Files : null;
// ... assignment to Root Object
}
Run Code Online (Sandbox Code Playgroud)