我有一个控制器,它需要调用另一个控制器。我们在客户端上做这项工作。出于性能原因,我们希望执行此服务器端。
请求是POST 请求网址=“http://example.com/api/foo/1234567(非常标准的网址,带有绑定ID)
请求数据
{
something1:'abc',
something2:'def',
copyFromUrl : '/api/bar/7654321'
};
copyFromUrl可以是应用程序中的任何其他控制器。我不想在堆栈中上下一堆if语句来进行绑定。
使问题复杂化的是大多数控制器都有三种不同的GET签名。 得到(刺痛id) 获取(sting id,string xpath) 得到()
答案 0 :(得分:2)
这样做的一种方法是基本上将HttpServer和HttpClient类短路。我在这里使用ASP.NET Web API 2,但希望同样的技术可以与原始Web API一起使用。
这是简约的工作样本:
public class BarController : ApiController
{
// GET http://localhost/api/bar
[HttpGet]
public IEnumerable<string> Get()
{
return new string[] {"Foo Bar", "Progress Bar"};
}
// GET http://localhost/api/bar?bar=Towel Bar
[HttpGet]
public IEnumerable<string> GetCustomBar(string bar)
{
return new string[] {"Foo Bar", "Progress Bar", bar};
}
// POST http://localhost/api/bar?action=/api/bar?bar=Towel Bar
[HttpPost]
public HttpResponseMessage StartAction(string action)
{
var config = new HttpConfiguration();
WebApiConfig.Register(config);
var server = new HttpServer(config);
var client = new HttpClient(server);
var response = client.GetAsync("http://localhost/" + action).Result;
return response;
}
正如您在此处看到的,前两个操作的参数不同,第三个操作接受url(如代码示例中所示),允许它调用任何其他操作。
我们基本上在内存中托管服务器,应用我们真实服务器的相同路由,然后立即查询它。
硬编码localhost
实际上没有使用运行时,路由会忽略它,但我们需要有效的绝对URL名称才能传递内部验证。
如果您愿意,此代码只是一个插图,概念验证。