gpt4 book ai didi

c# - 这些类/方法应该去哪里?

转载 作者:太空宇宙 更新时间:2023-11-03 16:49:01 24 4
gpt4 key购买 nike

我有这样的结构

WebUI 项目 - Controller 、 View 框架项目-存储库、服务层和域

所以现在我有 3 个方法/类

  1. 开放ID/开放授权

起初我以为我会把我所有的逻辑放在我的框架项目的服务层中(准备请求、检查响应等都在这一层)。

现在我正在使用 dotnetopenauth 库,因为我需要在我的 Controller 中使用 AsActionResult 方法(我从我的服务层返回“OutgoingWebResponse”,因为我不想在我的服务层中使用任何 MVC)

当我决定在我的服务层中不使用任何 MVC 时,我开始思考。据我了解,包含业务逻辑的服务层不应该有任何依赖关系,例如 MVC 引用,因为如果你转到 Windows Phone 应用程序,你不应该使用 MVC 东西。

您的业务层应该可以即插即用到任何应用程序中。

因此,出于上述原因,现在我不确定是否应该将我为 openId 编写的内容移动到我的 mvc 项目中的模型文件夹中。因为如果我确实转到 Windows Phone 应用程序或表单应用程序,我将不会使用 dotnetopenauth,因为我认为这些类型的应用程序不支持它。

  1. 我的第二个是表单例份验证。再次与上述几乎相同的原因。这是否应该在我的模型文件夹中作为本地服务/ repo 层(即在同一个项目文件中)。

  2. 我正在使用 nhibernate、fluent nhiberate 和 ninject。我的 repo 协议(protocol)都在我的框架项目中。所以我当然有所有的引用资料。但是因为我正在使用 ninject for ioc,所以我的 webui 项目中也有所有引用。

我不知道是否可以更改这个以从我的 webui 中删除这些引用。我认为不,因为他们不能在我认为应该去的 webui 中放置我的 ioc。

最佳答案

根据一般经验,您不应针对不存在的要求编写代码(将应用程序移植到 Windows Phone)。

通常您会在服务层中将其抽象出来,但是 OAuth 或 Facebook 集成会带来问题,因为它依赖于 http 并且能够访问身份验证站点。

您将遇到的问题是因为“all abstractions are leaky”,无论您将服务层放置在何处,openauth 注册过程都会以某种方式破坏您的服务层。有关用户注册和登录的详细信息(例如他们的 openid url 是什么)将最终保存在您的数据库中。你是 service/repo/db/model/mvc/viewmodel/controllers 类,因为它的性质,都将知道 openauth 是什么。

好处是这些基于浏览器的身份验证策略可以存在于 Windows 窗体、WPF 或 Silverlight 应用程序中。您只需在应用程序内打开浏览器,而不是使用 MVC 进行 native 重定向。

所以我建议将您的 dotnetopen 身份验证注册代码放在您的服务层中,并实际抽象出重定向和回调过程是如何发生的。

类似于:

public interface IOpenAuthRedirect
{
public void Redirect( url )
public void ParseCallback( url )
}


public class MVCOpenAuthRedirect
{
public void Redirect(url)
{
HttpContext.Current.Response.Redirect(url);
}
}

public class SilverlightOpenAuthRedirect
{
public void RedirectUrl( url )
{
SomeBrowserControl.IForgetTheCallToRedirect( url );
}

}

现在不同的实现细节很灵活,您可以轻松过渡到 MVC 以外的其他平台。

关于c# - 这些类/方法应该去哪里?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4778690/

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