3

我目前有一个 WCF 数据服务,位于www.mywebsite.com. 这是一个看起来像这样的基本服务:

namespace MyWeb
{
    [JSONPSupportBehavior]
    public class MyDataService : DataService<MyEntities>
    {
        public static void InitializeService(IDataServiceConfiguration config)
        {
            config.UseVerboseErrors = true;
            config.SetEntitySetAccessRule("Entities", EntitySetRights.AllRead);
            ServiceOperationRights.All);
        }
    }
}

目前,我们有现场客户通过发布 ajax 调用来发出请求,例如:

$.ajax({
        url: serverAddress + "MyDataService.svc/Entities?$top=20&$filter=IsConfirmed%20eq%20null&$format=json&$callback=?",
        headers: {
        version: "1.0",
        platform: "a platform"
        },
        timeout: 12000,
        dataType: 'jsonp',
        cache: false,
        context: document.body
})

这按预期工作,返回一个包含实体表中所需对象的 javascript 对象。

但是,我们想在服务器端添加一些智能来限制可以从此查询返回的结果。为此,我试图在上述MyDataService类中实现一个查询拦截器:

[QueryInterceptor("Entities")]
public IQueryable<Entity> OnQueryFares(IQueryable<Entity> query)
{
    return from e in query 
           where DataCheck(e) 
           select e;
}

预期的逻辑是服务现在将只返回 DataCheck(e) 评估为 true 的表条目。这个功能似乎起作用了。但是,在使用客户端进行测试时,我收到以下错误:

Web Console(4448): Uncaught SyntaxError: Unexpected token < at
http://www.mywebsite.com/MyDataService.svc/Entities?$top=20&$filter=IsConfirmed%20eq%20null&$format=json&$callback=jQuery17207441281890496612_1340223164872&_=1340223166622:1

这个特殊的错误让我猜测,出于某种原因,我实现的查询检查器返回的数据是以 XML 形式出现的,而不是像我实现拦截器之前的查询那样以 JSON 形式出现。

我找不到任何关于此的说明。如何在查询拦截器中强制执行 JSON 响应行为?

4

2 回答 2

6

有关查询拦截器的用法,请参阅此:http: //msdn.microsoft.com/en-us/library/dd744842.aspx

我很惊讶上面甚至启动了服务(我怀疑它没有启动,并且您返回了一个错误有效负载,因此无法读取它,您可以尝试使用例如 Fiddler 进行确认)。

查询拦截器返回一个谓词(表达式),该谓词在执行之前添加到查询中。因此,您无需返回新查询,只需修改现有查询即可。

在上面的示例中,只需像这样修改它:

[QueryInterceptor("Entities")]
public Expression<Func<Entity,bool>> OnQueryFares()
{
    return e => DataCheck(e);
}
于 2012-06-21T09:25:01.163 回答
0

这是一个扩展版本

[QueryInterceptor("Entities")]
public Expression<Func<Entity,bool>> OnQueryFares()
{
    // Assuming e has two properties Name and Age. 
    return e => e.Name=="John" && e.Age=23 ;
}
于 2013-08-11T01:13:33.570 回答