加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net – 如何从网络外部的外部站点允许内部MVC Web Api

发布时间:2020-12-16 09:26:59 所属栏目:asp.Net 来源:网络整理
导读:我有一个MVC Web API(托管在IIS中),它位于wwwroot文件夹中,可以在网络中本地访问.我可以执行这样的api调用:http:// mylocalapi:133 / api / Values / Get我得到一个结果. 我有一个外部网站http://example.org,我想执行相同的http:// mylocalapi:133 / a
我有一个MVC Web API(托管在IIS中),它位于wwwroot文件夹中,可以在网络中本地访问.我可以执行这样的api调用:http:// mylocalapi:133 / api / Values / Get我得到一个结果.

我有一个外部网站http://example.org,我想执行相同的http:// mylocalapi:133 / api / Values / Get.

外部站点站点以及内部API站点都托管在同一台服务器上(但它可以是不同的,例如网络外的第三方供应商)

我在我的API中设置了CORS,如下所示:

[EnableCors(起源:“http://example.org”,标题:“*”,方法:“*”)]

但我不断收到以下错误:

XMLHttpRequest无法加载http:// mylocalapi:133.请求的资源上不存在“Access-Control-Allow-Origin”标头.因此,不允许来源“http://example.org”访问.

因此,我在外部站点创建了一个虚拟目录(APICALLS),并创建了一个指向本地IIS站点的web.config文件:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <system.webServer>
        <httpRedirect enabled="true" destination="http://mylocalapi:133" exactDestination="true" />
    </system.webServer>
</configuration>

当我这样做时,我尝试访问这样的API:http://example.org/APICALLS/api/Values/Get但我收到以下错误:

XMLHttpRequest cannot load http://mylocalapi:133. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://example.org' is therefore not allowed access.

我做错了什么,我该如何解决这个问题.

解决方法

您无法通过JavaScript访问内部网站,因为JavaScript在客户端运行,位于最终用户的计算机上,位于内部网络之外.通过JavaScript访问API的唯一方法是:1)将API公开给外部网络,或者2)在外部站点中创建代理.

代理基本上是一个提供外部访问的操作或操作,然后将调用转换为内部API.最简单的,你可以有一个单独的动作,基本上响应如下:

https://foo.com/api?endpoint=/internal/api/endpoint/&someParam=foo

然后,该操作将在查询字符串中获取此信息,并使用该信息通过类似HttpClient的内容向内部API发出请求.但是,这种方法几乎暴露了整个内部API,因此您可能只是将其移到外面.更好的方法是为需要通过JavaScript进行的特定内部API调用创建特定端点(操作方法).

UPDATE

没有上下文,很难在这里给你任何真正的指导.假设有一个内部API端点返回一个窗口小部件列表,并且您希望通过AJAX检索此窗口小部件列表.你需要这样的东西:

public async Task<ActionResult> GetWidgets()
{
    // fetch widgets from internal API via HttpClient
    return Json(widgets,JsonRequestBehavior.AllowGet);
}

然后,您的AJAX会在您的网站上调用此操作方法的URL,该网站会调用内部API.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读