【发布时间】:2018-12-17 17:06:08
【问题描述】:
我编写了一个非常基本的 SQL 支持的 VSTO Outlook 插件,最终将在我工作的公司的多个办公室中被大约 20 人使用。所有人也将定期在家工作。
到目前为止,我所遵循的教程都将“您自己的”IP 地址添加到服务器防火墙规则中: https://docs.microsoft.com/en-gb/azure/sql-database/sql-database-get-started-portal-firewall
我在研究这个问题时遇到了一个类似的问题: SQL Azure Firewall Rules on New Portal
当我只是使用该应用程序时,这不是问题,我按照教程一次添加了我的办公室 IP 地址,一次添加了我的家庭 IP 地址。如果我必须让每个人都收集他们的 IP 地址并将每个人都设置在防火墙上,那将是非常尴尬的。
这将是我第一个使用远程资源的应用程序,因此我不确定防火墙的后续步骤,因此很难找到指南。我应该是:
- 向所有人开放防火墙,但创建存储在应用程序中的强密码
- 在应用程序中创建初始化步骤以授予新用户通过防火墙的访问权限
- 创建某种代理,以便所有 SQL 请求都来自同一个 IP 地址。
在 (2) 创建初始化步骤的情况下 - azure sql server firewall settings 似乎更改了防火墙规则 - 这是否意味着一次只能连接一个人?
【问题讨论】:
-
外接程序是否安装在人们的计算机上?那么数据库密码是否对任何有权访问该 PC 的人都可用?这听起来有点冒险。
-
插件将作为其 MS Outlook 安装的一部分进行安装。我不相信源代码对他们可见? Azure 教程将数据库用户名和密码编码到源代码中。 docs.microsoft.com/en-us/azure/sql-database/…
-
这篇文章建议了一个“中间层”应用程序——类似于我的选项 (3),但没有详细说明。然后我是否还必须编写一个用户身份验证应用程序,或者是否有一种直接的方法可以针对 Active Directory 或类似方法对其进行身份验证? social.msdn.microsoft.com/Forums/sqlserver/en-US/…
-
某种中间层 API 可能是最佳选择。我不能说推荐的身份验证方法是什么。
标签: azure azure-sql-database vsto