小编Ank*_*kar的帖子

存储库模式是否遵循SOLID原则?

我正在对SOLID主体进行一些研究,并在Repository模式的实现中发现了一些问题.我将解释每一个问题,如果我错了,请纠正我.

问题1

存储库模式中断单一责任原则(S)

假设我们有一个定义为的接口

public interface IRepository<T> where T: IEntity
{ 
    IEnumerable<T> List { get; }
    void Add(T entity);
    void Delete(T entity);
    void Update(T entity);
    T FindById(int Id);
}
Run Code Online (Sandbox Code Playgroud)

显然它违反了单一责任原则,因为当我们实现这个接口时,在一个类中,我们将命令和查询都放在一起.这不是预期的.

问题2

存储库模式中断接口隔离原则(I)

假设我们有2个以上接口的实现.

第一次实施

CustomerRepository : IRepository<Customer>
{
   //All Implementation
}
Run Code Online (Sandbox Code Playgroud)

第二次实施

ProductRepository : IRepository<Product>
{
   //All Implementation except Delete Method. So Delete Method Will be
   void Delete (Product product){
       throw Not Implement Exception!
   }
}
Run Code Online (Sandbox Code Playgroud)

并且根据ISP"没有客户应该被迫依赖它不使用的方法." 所以我们看到它显然也违反了ISP.

所以,我的理解是Repository模式不遵循SOLID主体.你怎么看?我们为什么要选择这种违反校长的模式呢?需要你的意见.

c# asp.net asp.net-mvc design-patterns solid-principles

15
推荐指数
3
解决办法
3818
查看次数

如何在MongoDB聚合查询中使用$ hint?

我在ubuntu机器上使用mongo v3.0.1.我收集了3亿行.我已根据查询首选项创建了两个索引.

当我尝试使用explain进行聚合时,它会使用效率低下的索引,这就是为什么它需要花费20-25秒的时间.有没有办法放置$hint,以便我的聚合查询使用适当的索引.

$match是我的第一个管道阶段.我有两个索引:

  1. "HOST_-1_SiteType_-1"

  2. "VisitTime_-1_AccountId_-1_Host_-1_SiteType_-1_Extension_-1_LifeTime_-1"

我的$match管道就像:

{ "$match" : {
    "AccountId": accID, 
    "VisitTime": { "$lte" : today, "$gte" : last365Days },
    "$or": [
        { "$and": [
            { "Extension":{ "$in": ["chrome_0","firefox_0"] }},
            { "LifeTime": 0 }
        ]},
        {  "LifeTime": { "$gt": 1000 }}
    ],
    "Host": { "$ne": "localhost" },
    "SiteType" : { "$exists": true },
}
Run Code Online (Sandbox Code Playgroud)

它使用的是第一个索引,而不是第二个索引.以及第一个指数在50秒内所花费的时间,而使用第二个指数只需要18秒.

这是我的一个文档示例:

{ 
    "_id" : "2bc1143c-07e4-4c37-a020-a7485b2802a3", 
    "CreatedDate" : ISODate("2015-07-22T04:05:06.802+0000"), 
    "UpdatedDate" : ISODate("2015-07-22T05:28:26.469+0000"), 
    "AccountId" : accID, 
    "Url" : "http://www.test.com/test.html", 
    "Host" …
Run Code Online (Sandbox Code Playgroud)

mongodb mongodb-query aggregation-framework

8
推荐指数
2
解决办法
6720
查看次数

无法通过X509Store访问自签名CA.

我在Win10机器上使用LINUX容器运行dotnet core 2.1我使用openssl创建了一个自签名CA并安装在docker机器中.Docker输出显示已添加CA.

在此输入图像描述

当我在命令下运行时,它还会向我显示已安装的证书

awk -v cmd='openssl x509 -noout -subject' '/BEGIN/{close(cmd)};{print | cmd}' < /etc/ssl/certs/ca-certificates.crt
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

但是,无法通过X509Store访问已安装的证书

下面的代码显示count:0

 using (var store = new X509Store(StoreName.CertificateAuthority, StoreLocation.LocalMachine))
            {
                store.Open(OpenFlags.ReadOnly);
                Console.WriteLine($"LocalMachine-> CertificateAuthority-> Count: {store.Certificates.Count}");
                foreach (var cert in store.Certificates)
                {
                    Console.WriteLine($"cert: {cert}");
                }
            }
Run Code Online (Sandbox Code Playgroud)

下面的代码显示计数:151

  using (var store = new X509Store(StoreName.Root, StoreLocation.LocalMachine))
            {
                store.Open(OpenFlags.ReadOnly);
                Console.WriteLine($"LocalMachine-> Root-> Count: {store.Certificates.Count}");

                foreach (var cert in store.Certificates)
                {
                    Console.WriteLine($"cert: {cert.IssuerName.Name}");
                }
            }
Run Code Online (Sandbox Code Playgroud)

但我认为它应该是152.

这是我的docker文件

FROM microsoft/dotnet:2.1-runtime AS base
WORKDIR /app

FROM microsoft/dotnet:2.1-sdk AS build
WORKDIR /src
COPY TestWebApp1/TestWebApp1.csproj …
Run Code Online (Sandbox Code Playgroud)

ubuntu openssl docker .net-core asp.net-core-2.0

8
推荐指数
1
解决办法
520
查看次数