本文用到组件RazorEngine,Github地址:https://github.com/Antaris/RazorEngine。关于RazorEngine的详细使用,请参看RazorEngine相关教程。
一、规则定义,视图存放路径
沿用ASP.NET MVC的视图存放规则:~/Views/{controller}/{action}.cshtml。(不考虑区域)
public static string GetViewPath(this HttpActionContext actionContext)
{
return string.Format("~/Views/{0}/{1}.cshtml"
,actionContext.ControllerContext.ControllerDescriptor.ControllerName
,actionContext.ActionDescriptor.ActionName);
}
二、初次启动,预加载视图文件
扫描Web根目录(Self Host模式为类库所在目录,IIS模式为网站根目录)下所有视图文件,将扫描到的视图文件缓存起来。
var rootPath = config.RootPath();
var cshtmls = Directory.GetFiles(rootPath, "*.cshtml",SearchOption.AllDirectories);
foreach (var itemin cshtmls)
{
var name = item.Replace(rootPath, "~").Replace("\\","/");
Engine.Razor.AddTemplate(name, File.ReadAllText(item));
}
三、为ContentType为text/html的客户端请求渲染视图
AspNet.WebApi默认会自动识别客户端请求的内容类型,当客户端请求的是JSON时,将返回JSON;当客户端请求的是XML时,将返回XML。这些都是隐式的处理方式。本文提供的是显式的处理方式,提供了一个View的扩展方法,要向客户端返回text/html类型的内容,必须显式调用该方法。
public class DefaultController : ApiController
{
[HttpGet]
public