4

我试图找出将以下逻辑放入我的 Delphi datasnap 服务器的最佳/“正确”位置。

用户连接到服务器,并使用提供的凭据,我使用集中的 AuthorizationDatabase(Oracle 数据库)对其进行验证。如果他们实际上是一个有效用户,那么我想根据授权存储库所说的(可能是另一个主机、数据库、用户名、密码)为他们提供与他们的数据实际所在位置的连接。

我在自己的服务器类中有 AuthorizationDatabase,这是服务器生命周期,因为没有人可以在没有经过验证的情况下进入。这会产生并发问题吗?10个用户同时登录验证,这样可以吗?

我有一个基本服务器模块,所有会话级数据模块都来自该模块,它具有应用程序连接。应用程序连接参数可以根据用户登录而改变。

我遇到的问题是在哪里放置授权/验证/新的数据库参数分配过程。

这种两步数据库方法最适合哪里?这似乎很常见,用户在一个地方得到验证,但他们最终要访问的数据在另一个地方。

在查看这些示例时,我看不出它会去哪里。

4

1 回答 1

2

跨多个会话共享一个连接是不安全的,当 2 个会话尝试同时读取数据库时,您将收到“读取错误”或其他错误。

但是你可以有一个集中的登录位置,只要让它线程安全,就可以了:

TMonitor.Enter(LoginDM);
Try
 valid := LoginDM.Login(username, password);
finally
  TMonitor.Exit(LoginDM);
end;

关于访问数据的用户,因为每个用户都有自己的会话在线程上运行,您可以为每个 ServerClass 实例创建一个连接并将生命周期定义为“Session”,因此每个新会话都会产生一个新的 ServerMethod 的类实例并具有它自己的连接,这样您就不必担心编写服务器方法的方式,因为它们将始终拥有自己的“独占”连接。

于 2014-05-22T20:47:43.480 回答