ChatGPT解决这个技术问题 Extra ChatGPT

如何让 ASP.NET Web API 使用 Chrome 返回 JSON 而不是 XML?

这个问题的答案是社区的努力。编辑现有答案以改进这篇文章。它目前不接受新的答案或交互。

使用较新的 ASP.NET Web API,在 Chrome 中我看到 XML - 如何将其更改为请求 JSON,以便我可以在浏览器中查看它?我确实相信它只是请求标头的一部分,我是否正确?

这里有一个讨论使返回 JSON 成为默认行为:github.com/aspnet/Mvc/issues/1765

R
Ryan Leach

注意:阅读此答案的评论,如果您使用 WebAPI 的默认错误处理,它可能会产生 XSS 漏洞

我只是在我的 MVC Web API 项目的 App_Start / WebApiConfig.cs 类中添加以下内容。

config.Formatters.JsonFormatter.SupportedMediaTypes
    .Add(new MediaTypeHeaderValue("text/html") );

这可确保您在大多数查询中获得 JSON,但您可以在发送 text/xml 时获得 XML

如果您需要将响应 Content-Type 作为 application/json,请检查 Todd's answer below

NameSpace 正在使用 System.Net.Http.Headers


这是一个令人惊讶的被忽视的答案,尽管最初的问题并不完全清楚,但这直接使 JSON 成为 Web 浏览器的默认响应(发送 Accept: text/html)。好工作。
+1 最好的答案。我想有很多人选择完全删除 XML 只是因为他们在浏览器中看不到 JSON。
当我这样做时,我发现第三方提供的带有 HTML 中断标签的数据以回车结束。然后 JSON 无效。如果这会影响您,最好使用已接受的答案。
请注意,响应的 Content-Type 标头仍为 text/html
这太可怕了。响应内容类型标头应为 application/json。这个“解决方案”使它成为 text/html。
R
Ryan Leach

如果您在 WebApiConfig 中执行此操作,您将默认获得 JSON,但如果您将 text/xml 作为请求 Accept 标头传递,它仍然允许您返回 XML。

注意:这删除了对 application/xml 的支持

public static class WebApiConfig
{
    public static void Register(HttpConfiguration config)
    {
        config.Routes.MapHttpRoute(
            name: "DefaultApi",
            routeTemplate: "api/{controller}/{id}",
            defaults: new { id = RouteParameter.Optional }
        );

        var appXmlType = config.Formatters.XmlFormatter.SupportedMediaTypes.FirstOrDefault(t => t.MediaType == "application/xml");
        config.Formatters.XmlFormatter.SupportedMediaTypes.Remove(appXmlType);
    }
}

如果您没有使用 MVC 项目类型,因此一开始就没有此类,请see this answer了解有关如何合并它的详细信息。


请注意,原始行为是正确的。 Chrome 请求优先级为 0.9 的 application/xml 和优先级为 0.8 的 */*。通过删除 application/xml,您将删除 Web API 在客户端特别请求时返回 XML 的能力。例如,如果您发送“Accept: application/xml”,您将仍然收到 JSON。
是我,还是第一句话不正确?该代码似乎完全删除了 XML,而不是简单地更改默认值。
@NickG:此处忽略的解决方案,恕我直言,这是一个更好的选择(保留 application/xml)是 Felipe Leusin 在此页面下方提出的解决方案。使用 config.Formatters.XmlFormatter.SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/html"));
那么,我们如何通过 web config 来做到这一点,以便我们默认获取 json 并在请求时获取 XML?
@Felipse Leusin 下面的答案实际上更短,效果更好。
L
Liam

使用 RequestHeaderMapping 效果更好,因为它还在响应标头中设置 Content-Type = application/json,这允许 Firefox(带有 JSONView 插件)将响应格式化为 JSON。

GlobalConfiguration.Configuration.Formatters.JsonFormatter.MediaTypeMappings
.Add(new System.Net.Http.Formatting.RequestHeaderMapping("Accept", 
                              "text/html",
                              StringComparison.InvariantCultureIgnoreCase,
                              true, 
                              "application/json"));

这是最精简和最简单的解决方案,Fiddler 还检测到作为 josn 返回的内容类型。
好的!你会建议把它放在代码中的什么地方?
它应该进入 WebApiConfig.cs
为我工作。我需要添加一个 using System.Net.Http.Formatting;
需要明确的是,这只是更改了默认值。只需包含相关的“Accept”标头,您就可以随时获取 JSON 或 XML。
C
Community

我最喜欢Felipe Leusin's approach - 确保浏览器获取 JSON,而不会影响来自实际需要 XML 的客户端的内容协商。对我来说唯一缺少的是响应标头仍然包含内容类型:text/html。为什么这是个问题?因为我使用 JSON Formatter Chrome extension,它检查内容类型,但我没有得到我习惯的漂亮格式。我使用一个简单的自定义格式化程序来解决这个问题,该格式化程序接受 text/html 请求并返回 application/json 响应:

public class BrowserJsonFormatter : JsonMediaTypeFormatter
{
    public BrowserJsonFormatter() {
        this.SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/html"));
        this.SerializerSettings.Formatting = Formatting.Indented;
    }

    public override void SetDefaultContentHeaders(Type type, HttpContentHeaders headers, MediaTypeHeaderValue mediaType) {
        base.SetDefaultContentHeaders(type, headers, mediaType);
        headers.ContentType = new MediaTypeHeaderValue("application/json");
    }
}

像这样注册:

config.Formatters.Add(new BrowserJsonFormatter());

如果您希望它在没有浏览器扩展的情况下打印得漂亮,请在构造函数中添加 this.SerializerSettings.Formatting = Formatting.Indented;
你为什么要它漂亮地打印在电线上?
@dmit77 的 Answer 不是比这个更好(更简洁)吗?
@eddiegroves,您不想在电线上进行漂亮的打印。您希望服务器通过线路发送最少的位(即:没有空格)。然后你希望浏览器用插件等很好地格式化它。 Javascript 通常需要解析 JSON,为什么要通过引入不必要的格式来使其变慢
对于正在寻找的谷歌人:不要忘记添加using System.Net.Http.Formattingusing Newtonsoft.Json
D
Drew Noakes

MVC4 快速提示 #3 – 从 ASP.Net Web API 中删除 XML 格式化程序

Global.asax 中添加以下行:

GlobalConfiguration.Configuration.Formatters.XmlFormatter.SupportedMediaTypes.Clear();

像这样:

protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();

    RegisterGlobalFilters(GlobalFilters.Filters);
    RegisterRoutes(RouteTable.Routes);

    BundleTable.Bundles.RegisterTemplateBundles();
    GlobalConfiguration.Configuration.Formatters.XmlFormatter.SupportedMediaTypes.Clear();
}

工作 - 让 JSON 作为默认而不是 XML 更好。
但是你还能返回xml吗?
我测试了它,你不能。所以这正在删除 XML 支持。请注意,亲爱的谷歌人
如果您在下面查看我的答案,如果您愿意,这将让 xml 仍然返回,但让网站使用 JSON 响应浏览器
@GlennSlaven 是的,您的答案应该是标记为正确的答案。
S
Stacked

在 WebApiConfig.cs 中,在 Register 函数的末尾添加:

// Remove the XML formatter
config.Formatters.Remove(config.Formatters.XmlFormatter);

Source


在 MVC5 中,这可以通过将 config 替换为 GlobalConfiguration.Configuration 来完成
对于必须仅支持 JSON 并且在任何情况下都不允许发出 XML 的项目,这是迄今为止最好的选择。
config.Formatters.Add(config.Formatters.JsonFormatter);
这太可怕了。 -- 无论如何,这将始终返回 JSON,即使客户端在 Content-Type 标头中特别要求 XML。
没有像 JSON 版本那样彻底测试 API 的 XML 版本的项目应该选择这个。根据 Michael 包含的链接,不同的格式化程序对对象进行不同的序列化。例如:XML 格式化程序不会序列化只读字段,而 JSON 格式化程序会。
S
Stacked

Global.asax 我使用下面的代码。我获取 JSON 的 URI 是 http://www.digantakumar.com/api/values?json=true

protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();

    FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    BundleConfig.RegisterBundles(BundleTable.Bundles);

    GlobalConfiguration.Configuration.Formatters.JsonFormatter.MediaTypeMappings.Add(new  QueryStringMapping("json", "true", "application/json"));
}

很棒的一个。你的方法期望一个参数是什么?像localhost:61044/api/values/getdate?json=true,date=2012-08-01
A
Aaron Daniels

看看 WebAPI 中的内容协商。这些 (Part 1 & Part 2) 非常详细和透彻的博客文章解释了它的工作原理。

简而言之,您是对的,只需要设置 AcceptContent-Type 请求标头即可。鉴于您的操作未编码为返回特定格式,您可以设置 Accept: application/json


“所以我可以在浏览器中查看它”
@Spongman,是的,你可以。但是使用 REST Client 之类的扩展 - 大多数浏览器都有类似的。在浏览器中直接输入 url 是 1. 限制太多(无法控制标题,无法发布数据等); 2. 不正确 - 浏览器没有像预期的那样使用 web api - 你不能依赖它来正确地测试它。所以,再一次,一个好的 REST 客户端插件可以解决这个问题。
C
Chris S

由于问题是特定于 Chrome 的,您可以获得 Postman extension,它允许您设置请求内容类型。

https://i.stack.imgur.com/A4GfR.png


在 Firefox 中,只需转到 about:config,搜索 accept.default 并将 network.http.accept.default 配置的内容更改为 text/html,application/xhtml+xml,application/json;q=0.9,application/xml;q=0.8,*/*;q=0.7
或者更好的是,只需 text/html,application/xhtml+xml;q=1.0,*/*;q=0.7 即可避免有问题的主机(例如 Bitbucket)意外地为您的浏览器提供 JSON 来代替 HTML。
URL 已死。一个新的是 chrome.google.com/webstore/detail/postman/…
R
RyBolt

此代码使 json 成为我的默认值,并允许我使用 XML 格式。我将只附加 xml=true

GlobalConfiguration.Configuration.Formatters.XmlFormatter.MediaTypeMappings.Add(new QueryStringMapping("xml", "true", "application/xml"));
GlobalConfiguration.Configuration.Formatters.JsonFormatter.SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/html"));

感谢大家!


这是最灵活的答案(现在确实应该是默认配置)。要添加到此答案,JSON 是默认值,包括来自浏览器。要查看 XML,请添加查询字符串:?xml=true
尝试了多种策略。对 XML 和 JSON 进行了简单的测试,并且开箱即用
s
suhair

一种快速的选择是使用 MediaTypeMapping 专业化。以下是在 Application_Start 事件中使用 QueryStringMapping 的示例:

GlobalConfiguration.Configuration.Formatters.JsonFormatter.MediaTypeMappings.Add(new QueryStringMapping("a", "b", "application/json"));

现在,只要 url 在这种情况下包含查询字符串 ?a=b,Json 响应就会显示在浏览器中。


这非常有用。如果你想使用 path.to/item.json,你也可以使用 UriPathExtensionMapping 而不是 QueryStringMapping
I
Ivaylo Slavov

不要使用您的浏览器来测试您的 API。

相反,请尝试使用允许您指定请求的 HTTP 客户端,例如 CURL,甚至 Fiddler。

这个问题的问题在于客户端,而不是 API。根据浏览器的请求,Web API 行为正确。


为什么不用浏览器?这是一个明显的工具。
我认为这里的观点是正确和重要的——如果问题是由客户端引起的,我们不应该过度修复应用程序的工作部分(MVC WebAPI 基础设施)。 Api 的真正用例是正确使用(通过提供正确的标头),这是应用程序的责任。不过,我不同意完全放弃浏览器——为了测试,几乎所有浏览器都有很多工具(从类似 Rest Client 的扩展开始)。
这应该是一个评论。
p
pavan kumar

上面的大多数答案都很有意义。由于您看到数据以 XML 格式格式化,这意味着应用了 XML 格式化程序,因此您只需从 HttpConfiguration 参数中删除 XMLFormatter 即可查看 JSON 格式,例如

public static void Register(HttpConfiguration config)
        {
            config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );                
            config.Formatters.Remove(config.Formatters.XmlFormatter);                
            config.EnableSystemDiagnosticsTracing();
        }

因为 JSON 是默认格式


S
Stacked

返回正确的格式由媒体类型格式化程序完成。正如其他人提到的,您可以在 WebApiConfig 类中执行此操作:

public static class WebApiConfig
{
    public static void Register(HttpConfiguration config)
    {
        ...

        // Configure Web API to return JSON
        config.Formatters.JsonFormatter
        .SupportedMediaTypes.Add(new System.Net.Http.Headers.MediaTypeHeaderValue("text/html"));

        ...
    }
}

有关更多信息,请查看:

ASP.NET Web API 2 中的媒体格式化程序。

ASP.NET Web API 中的内容协商。

如果您的操作返回 XML(默认情况下是这种情况)并且您只需要一个特定的方法来返回 JSON,那么您可以使用 ActionFilterAttribute 并将其应用于该特定操作。

过滤器属性:

public class JsonOutputAttribute : ActionFilterAttribute
{
    public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)
    {
        ObjectContent content = actionExecutedContext.Response.Content as ObjectContent;
        var value = content.Value;
        Type targetType = actionExecutedContext.Response.Content.GetType().GetGenericArguments()[0];

        var httpResponseMsg = new HttpResponseMessage
        {
            StatusCode = HttpStatusCode.OK,
            RequestMessage = actionExecutedContext.Request,
            Content = new ObjectContent(targetType, value, new JsonMediaTypeFormatter(), (string)null)
        };

        actionExecutedContext.Response = httpResponseMsg;
        base.OnActionExecuted(actionExecutedContext);
    }
}

适用于行动:

[JsonOutput]
public IEnumerable<Person> GetPersons()
{
    return _repository.AllPersons(); // the returned output will be in JSON
}

请注意,您可以省略动作装饰中的 Attribute 一词,而只使用 [JsonOutput] 而不是 [JsonOutputAttribute]


完美的解释
R
Roger Lipscombe

User-Agent 标头包含“Chrome”时,我使用全局操作过滤器删除 Accept: application/xml

internal class RemoveXmlForGoogleChromeFilter : IActionFilter
{
    public bool AllowMultiple
    {
        get { return false; }
    }

    public async Task<HttpResponseMessage> ExecuteActionFilterAsync(
        HttpActionContext actionContext,
        CancellationToken cancellationToken,
        Func<Task<HttpResponseMessage>> continuation)
    {
        var userAgent = actionContext.Request.Headers.UserAgent.ToString();
        if (userAgent.Contains("Chrome"))
        {
            var acceptHeaders = actionContext.Request.Headers.Accept;
            var header =
                acceptHeaders.SingleOrDefault(
                    x => x.MediaType.Contains("application/xml"));
            acceptHeaders.Remove(header);
        }

        return await continuation();
    }
}

似乎工作。


D
DanielV

我发现 Chrome 应用程序“高级 REST 客户端”非常适合与 REST 服务一起使用。您可以将 Content-Type 设置为 application/json 等:Advanced REST client


X
Xiddoc
config.Formatters.Remove(config.Formatters.XmlFormatter);

虽然此代码可能会回答问题,但提供有关它如何和/或为什么解决问题的额外上下文将提高答案的长期价值。请阅读此stackoverflow.com/help/how-to-answer
X
Xiddoc

在最新版本的 ASP.net WebApi 2 中,在 WebApiConfig.cs 下,这将起作用:

config.Formatters.Remove(GlobalConfiguration.Configuration.Formatters.XmlFormatter);
config.Formatters.Add(GlobalConfiguration.Configuration.Formatters.JsonFormatter);

C
Community

我不清楚为什么答案中存在所有这些复杂性。当然有很多方法可以做到这一点,使用 QueryStrings、标题和选项......但我认为最佳实践很简单。您请求一个纯 URL(例如:http://yourstartup.com/api/cars)并作为回报获得 JSON。您将获得带有正确响应标头的 JSON:

Content-Type: application/json

在寻找同一个问题的答案时,我找到了这个线程,并且不得不继续下去,因为这个接受的答案并不完全有效。我确实找到了一个我觉得太简单而不是最好的答案:

Set the default WebAPI formatter

我也会在这里添加我的提示。

WebApiConfig.cs

namespace com.yourstartup
{
  using ...;
  using System.Net.Http.Formatting;
  ...
  config.Formatters.Clear(); //because there are defaults of XML..
  config.Formatters.Add(new JsonMediaTypeFormatter());
}

我确实有一个问题是默认值(至少是我看到的那些)来自哪里。它们是 .NET 默认值,还是可能在其他地方创建(由我项目中的其他人创建)。无论如何,希望这会有所帮助。


A
Akshay Kapoor

您可以使用如下:

GlobalConfiguration.Configuration.Formatters.Clear();
GlobalConfiguration.Configuration.Formatters.Add(new JsonMediaTypeFormatter());

如果您正在制作一个仅用于传递 JSON 消息的 WebAPI 应用程序,请考虑这个答案。
C
Community

这是一个类似于 jayson.centeno's 和其他答案的解决方案,但使用来自 System.Net.Http.Formatting 的内置扩展。

public static void Register(HttpConfiguration config)
{
    // add support for the 'format' query param
    // cref: http://blogs.msdn.com/b/hongyes/archive/2012/09/02/support-format-in-asp-net-web-api.aspx
    config.Formatters.JsonFormatter.AddQueryStringMapping("$format", "json", "application/json");
    config.Formatters.XmlFormatter.AddQueryStringMapping("$format", "xml", "application/xml");

    // ... additional configuration
 }

该解决方案主要针对在 WebApi 的早期版本中支持 OData 的 $format,但它也适用于非 OData 实现,并在响应中返回 Content-Type: application/json; charset=utf-8 标头。

它允许您在使用浏览器进行测试时将 &$format=json&$format=xml 添加到 uri 的末尾。使用可以设置自己的标头的非浏览器客户端时,它不会干扰其他预期行为。


M
Md. Sabbir Ahamed

只需在您的 WebApiConfig 类上添加这两行代码

public static class WebApiConfig
{
     public static void Register(HttpConfiguration config)
     {
          //add this two line 
          config.Formatters.Clear();
          config.Formatters.Add(new JsonMediaTypeFormatter());


          ............................
      }
}

v
vaheeds

您只需像这样更改 App_Start/WebApiConfig.cs

public static void Register(HttpConfiguration config)
    {
        // Web API configuration and services

        // Web API routes
        config.MapHttpAttributeRoutes();
        //Below formatter is used for returning the Json result.
        var appXmlType = config.Formatters.XmlFormatter.SupportedMediaTypes.FirstOrDefault(t => t.MediaType == "application/xml");
        config.Formatters.XmlFormatter.SupportedMediaTypes.Remove(appXmlType);
        //Default route
        config.Routes.MapHttpRoute(
           name: "ApiControllerOnly",
           routeTemplate: "api/{controller}"
       );
    }

删除格式化程序通常不是一个好主意,您正在删除功能。
实际上在这种情况下,它对我来说效果很好,还有许多其他人提出了这样的方法。我是从 myview.rahulnivi.net/building-spa-angular-mvc-5 本书中学到的!
r
rism

自从提出(并回答)这个问题以来已经过去了一段时间,但另一个选择是在请求处理期间使用 MessageHandler 覆盖服务器上的 Accept 标头,如下所示:

public class ForceableContentTypeDelegationHandler : DelegatingHandler
{
    protected async override Task<HttpResponseMessage> SendAsync(
                HttpRequestMessage request,
                CancellationToken cancellationToken)
    {
        var someOtherCondition = false;
        var accHeader = request.Headers.GetValues("Accept").FirstOrDefault();
        if (someOtherCondition && accHeader.Contains("application/xml"))
        {
            request.Headers.Remove("Accept");
            request.Headers.Add("Accept", "application/json");
        }
        return await base.SendAsync(request, cancellationToken);
    }
}

其中 someOtherCondition 可以是任何内容,包括浏览器类型等。这适用于仅有时我们想要覆盖默认内容协商的条件情况。否则,根据其他答案,您只需从配置中删除不必要的格式化程序。

你当然需要注册它。您可以全局执行此操作:

  public static void Register(HttpConfiguration config) {
      config.MessageHandlers.Add(new ForceableContentTypeDelegationHandler());
  }

或逐条路线:

config.Routes.MapHttpRoute(
   name: "SpecialContentRoute",
   routeTemplate: "api/someUrlThatNeedsSpecialTreatment/{id}",
   defaults: new { controller = "SpecialTreatment" id = RouteParameter.Optional },
   constraints: null,
   handler: new ForceableContentTypeDelegationHandler()
);

由于这是一个消息处理程序,它将在管道的请求和响应端都运行,很像 HttpModule。因此,您可以使用自定义标头轻松确认覆盖:

public class ForceableContentTypeDelegationHandler : DelegatingHandler
{
    protected async override Task<HttpResponseMessage> SendAsync(
                HttpRequestMessage request,
                CancellationToken cancellationToken)
    {
        var wasForced = false;
        var someOtherCondition = false;
        var accHeader = request.Headers.GetValues("Accept").FirstOrDefault();
        if (someOtherCondition && accHeader.Contains("application/xml"))
        {
            request.Headers.Remove("Accept");
            request.Headers.Add("Accept", "application/json");
            wasForced = true;
        }

        var response =  await base.SendAsync(request, cancellationToken);
        if (wasForced){
          response.Headers.Add("X-ForcedContent", "We overrode your content prefs, sorry");
        }
        return response;
    }
}

X
Xiddoc

这是我在应用程序中使用的最简单的方法。在 Register 函数的 App_Start\WebApiConfig.cs 中添加以下 3 行代码:

var formatters = GlobalConfiguration.Configuration.Formatters;

formatters.Remove(formatters.XmlFormatter);

config.Formatters.JsonFormatter.SupportedMediaTypes.Add(new MediaTypeHeaderValue("application/json"));

Asp.net Web API 将自动将您返回的对象序列化为 JSON,并且在标头中添加 application/json,以便浏览器或接收器了解您正在返回 JSON 结果。


l
lko

MSDN Building a Single Page Application with ASP.NET and AngularJS(大约 41 分钟)。

public static class WebApiConfig
{
    public static void Register(HttpConfiguration config)
    {
        // ... possible routing etc.

        // Setup to return json and camelcase it!
        var formatter = GlobalConfiguration.Configuration.Formatters.JsonFormatter;
        formatter.SerializerSettings.ContractResolver =
            new Newtonsoft.Json.Serialization.CamelCasePropertyNamesContractResolver();
    }

它应该是最新的,我试过了,它奏效了。


C
Charles Burns

多年来使用 Felipe Leusin 的答案,在最近更新核心库和 Json.Net 之后,我遇到了 System.MissingMethodException:SupportedMediaTypes。就我而言,希望对遇到同样意外异常的其他人有所帮助的解决方案是安装 System.Net.Http。 NuGet 在某些情况下显然会删除它。手动安装后,问题解决。


P
Pang

WebApiConfig 是您可以配置是否要以 json 或 xml 输出的地方。默认情况下,它是 xml。在 register 函数中,我们可以使用 HttpConfiguration Formatters 来格式化输出。

System.Net.Http.Headers => MediaTypeHeaderValue("text/html") 是获取 json 格式的输出所必需的。

https://i.stack.imgur.com/n3ksj.png


u
user3285954

我很惊讶地看到如此多的回复需要编码来更改一个 API 中的单个用例 (GET),而不是使用必须安装一次且可用于任何 API(自己或第 3 方)和所有 API 的适当工具用例。

所以好的答案是:

如果您只想请求 json 或其他内容类型,请安装 Requestly 或类似工具并修改 Accept 标头。如果您也想使用 POST 并且有格式良好的 json、xml 等,请使用适当的 API 测试扩展,如 Postman 或 ARC。


有些人更喜欢在不增加额外工具和库形式的膨胀的情况下做事。
仅仅因为某人使用了错误的工具来完成这项工作,而对 API 进行更改仍然是错误的。 Web 浏览器的设计目的不是为了测试 API,甚至不是为了查看 API 的输出,而是为了查看文档。如果有人认为 API 测试工具过于臃肿,而不是任何 API 开发人员的必备工具包的一部分,那就更糟了,老实说,我也会添加前端开发人员,因为他们也需要与 API 进行交互和试验。这也可能还不够,因为没有插件的浏览器不允许设置标头、发布到 API 甚至检查响应标头。
我明白你在说什么,你没有错。但只是题外话,你被否决的原因是你回答问题的语气。你听起来非常好斗,给人的印象是那个认为他们无所不知的开发人员,这非常令人反感。从您的回答来看,我确信您是一位出色的开发人员。但是,您必须学习,尤其是在这样的专业 QA 环境中,以更友好、更人性化的方式解决和说服人们。也许,首先给出他们想要的答案,然后解释更好的方法,并激发为什么它更好。