最近,有很多同窗又问到,Aries里如何提供WebAPI接口?html
针对这个问题,今天给顺路写个教程,其实呢,很简单的。web
用这种方式,直接添加接口就能够了,Aries只是默认处理了.html后缀的请求。对于WS的asmx后缀是没有影响的,因此传统怎么添加就怎么添加。api
用这种方式,就是把接口独立成一个项目,而后经过IIS部署成子应用程序就能够了。spa
只是部署成子应用程序的时候,须要注意一会儿目录和根目录的web.config,出现重复的只能留根目录的那个。code
(通常都会建议用户用这种方式,好处是能够在IIS里学会一下怎么部署子应用程序。)htm
这个方式,其实也很简单,下面介绍一下简单的部署:blog
在Web.UI项目添加引用Taurus.Core.dll(能够在Nuget上引用,也能够引用源码项目再引用项目)继承
A、在HttpModule中添加URL拦截。教程
//这是原来有的: <add name="Aries.Core" type="Aries.Core.UrlRewrite,Aries.Core" /> //这是新添加的: <add name="Taurus.Core" type="Taurus.Core.UrlRewrite,Taurus.Core"/>
B、在AppSetting中设置路径模式:接口
<!--配置模式【值为0,1或2】[默认为1] 值为0:匹配{Action}/{Para} 值为1:匹配{Controller}/{Action}/{Para} 值为2:匹配{Module}/{Controller}/{Action}/{Para}--> <add key="Taurus.RouteMode" value="1"/>
C、在AppSetting中设置接口代码所在的项目:
<!--指定控制器所在的项目(Dll)名称(可改,项目编绎的dll叫什么名就写什么) <add key="Taurus.Controllers" value="Taurus.Controllers"/>-->
若是是用Nuget上引用的,默认都会有上面的两个,其它默认生的,能够注释掉。
接口代码写在哪里呢?放在哪一个项目均可以,只要上面C点的配置指向就能够了,若是接口代码分散在多个项目中,配置的value能够用“逗号”分隔。
按Taurus.MVC的方式写接口,继承自Taurus.Core.Controller便可:
如:
/// <summary> /// API 接口 /// </summary> public class APIController : Taurus.Core.Controller { public void Hello() { Write("hello Controllers.API"); } }
接口访问:http://.../api/hello
Aries中默认处理的是.html后缀。
Taurus默认处理的是无后缀。
因此二者并没有冲突,直接引用,加配置就能够了,没你想的复杂。