-
为了测试先做一个简单的webapi,直接用新建项目时默认的就可以了。
-
在浏览器中测试request get,得到结果
-
然后再项目中新建一个AjaxOnly的类
-
AjaxOnly继承ActionFilterAttribute,代码如下
public class AjaxOnlyAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(HttpActionContext filterContext)
{
var request = filterContext.Request;
var headers = request.Headers;
if (!headers.Contains("X-Requested-With")
|| headers.GetValues("X-Requested-With").FirstOrDefault() != "XMLHttpRequest")
{
throw new InvalidOperationException("This operation can only be accessed via Ajax requests");
}
else {
base.OnActionExecuting(filterContext);
}
}
}
其中 if (!headers.Contains("X-Requested-With")
|| headers.GetValues("X-Requested-With").FirstOrDefault() != "XMLHttpRequest") 就是判断它是不是ajax请求,如果true则说明不是
如果是controller的话可以用HttpContext.Request.IsAjaxRequest()来判断,webapi的actionContext中不支持IsAjaxRequest
-
把filter加在webapi的get方法上
-
然后再通过浏览器查看,得到报错。如果是ajax则会返回正常的结果。
-
可以把这个filter注册在global下,那每一个webapi都只能通过ajax访问
GlobalConfiguration.Configuration.Filters.Add(new AjaxOnlyAttribute());
END
相关文章
- ajax 异步请求返回只刷新一次页面
- jquery.ajax 跨域请求webapi,设置headers
- 前端通信:ajax设计方案(八)--- 设计请求池,复用请求,让前端通信快、更快、再快一点
- 让python bottle框架支持jquery ajax的RESTful风格的PUT和DELETE等请求
- php脚本获取两个ajax请求,只返回一个?
- mvc中的api操作的ajax请求没有执行成功事件(asp.net webapi)
- 为什么IE只在使用阿拉伯语或波斯语等其他语言发送ajax请求时才识别字符
- jquery ajax请求只适用于firefox。
- webapi 解决ajax跨域请求问题
- ASP.NET MVC & WebApi 中实现Cors来让Ajax可以跨域访问 (转载)