0

我已经在服务器上部署了我的 react 应用程序和 .net core api。当我从浏览器检查时,.net core api 调用工作正常。但是当我从反应应用程序调用它时,它会给出 204 no-content。在本地一切正常。

我已经启用了这样的 CORS

options.AddPolicy(MyAllowSpecificOrigins,
                builder =>
                {
                    builder.WithOrigins("http://serverip:5000",
                            "http://serverip:3000"
}   

api调用---

[HttpGet]
    [Route("path/{id}")]
    public async Task<ActionResult<List<myData>>> GetByType(byte id)
    {

      if (IsUserAuthenticated())
            return await _myRepo.GetMyData(id);
        else
            return null;
    }

反应呼叫-----

      axios.get('http://ip:5000/api/value1/value2/' + param1, { 
      withCredentials: true })

感谢任何帮助!

4

3 回答 3

1

尝试将代码更改为

[HttpGet]
[Route("path/{id}")]
public async Task<ActionResult<List<myData>>> GetByType(byte id)
{

  if (IsUserAuthenticated())
        return await _myRepo.GetMyData(id);
    else {
        HttpContext.Response.StatusCode = 401;
        return null;
     }
}

这将确保 NoContent 204 结果不仅仅是代码的空部分。

如果您收到未经授权的响应,那么您需要弄清楚您的安全性。

顺便说一句,您可以使用过滤器进行授权或属性,而不是将其写入每个操作。

于 2019-12-22T07:47:52.893 回答
1

您的 api 路线是

[路线(“路径/{id}”)]

你应该改变

axios.get('http://ip:5000/api/value1/value2/' + param1, {
      withCredentials: true })

axios.get(' http://ip:5000/api/path/ ' + param1, {
      withCredentials: true })

于 2019-12-22T06:02:58.370 回答
1

最后,这是我的一个愚蠢的错误。我在流程中的某处硬编码了 localhost url,这在从服务器访问时导致了 CORS 问题。感谢所有帮助!

于 2019-12-22T12:06:19.230 回答