gpt4 book ai didi

linq-to-sql - oData/ADO.NET 使用带有解密层的 LINQ-to-SQL 的数据服务

转载 作者:行者123 更新时间:2023-12-04 06:55:14 25 4
gpt4 key购买 nike

我使用 LINQ-to-SQL 编写了一个应用程序,该应用程序将 Web 表单提交到数据库中。我使用存储库模式抽象出 LINQ-to-SQL。

此存储库具有基本方法:Get()、Save() 等。

作为项目的开发,我需要对表单中的某些字段进行加密。这很简单,因为我刚刚将加密调用添加到存储库中的 Get()、Save() 方法。

现在,我想在它上面放置一个 oData 层,以允许从 MS Excel 2010 中提取 RESTful(当它出现时)。在偶然发现一些无用的错误消息等之后,我有了这个工作。

但是,显然,那些加密字段仍然是加密的。我的存储库模式会为我解密这些。据我所知,我必须将我的 oData 服务直接绑定(bind)到 LINQ-to-SQL 上下文以使架构等工作 - 除非我进入一个痛苦的世界(任何 URL 赞赏)。

有没有办法可以将我的加密/解密层插入到请求中,以便“即时”完成解密?我查看了 DataService 的 OnStartProcessingRequest() 重载,但这似乎没什么用。

最佳答案

您不必直接绑定(bind)到 L2S 即可公开 OData 服务。
您可以编写自己的 Context 类并直接使用反射提供程序从您的类公开的 IQueryable 属性中推断模型。

注意:您使用的 L2S 方法也只是使用反射提供程序。

关键是简单地包装 L2S DataContext 的可查询对象 (see this),这样您就可以将自己注入(inject)到查询执行中:

  • 只需将生成的表达式转发到 L2S 并在数据库中运行查询。
  • 由于结果是从 L2S 返回的,因此您可以在内存中枚举它们进行动态解密,然后再将它们返回给 Data Services。

  • 有关反射提供程序的更多信息,请查看 this post .

    希望这可以帮助

    Alex James

    OData/数据服务项目经理

    关于linq-to-sql - oData/ADO.NET 使用带有解密层的 LINQ-to-SQL 的数据服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2644243/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com