- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道这里已经有很多关于这个主题的问题(我已经阅读了尽可能多的问题),但我还无法弄清楚如何最好地满足我的特定标准。以下是目标:
ASP.NET 应用程序将在几个不同的 Web 服务器上运行,包括用于开发的本地主机工作站。 这意味着使用机器 key 加密 web.config 已经过时了。 Web 服务器的每种“类型”或环境(dev、test、prod)都有其自己相应的数据库(dev、test、prod)。我们希望分离这些连接字符串,以便处理“dev”代码的开发人员无法看到任何“prod”连接字符串密码,也不允许这些生产密码部署到错误的服务器或提交到 SVN。/p>
应用程序将应该能够根据服务器名称(使用 switch 语句)决定尝试使用哪个连接字符串。例如,“localhost”和“dev.example.com”将应该知道使用 DevDatabaseConnectionString,“test.example.com”将使用 TestDatabaseConnectionString,“www.example.com”将使用例如,使用 ProdDatabaseConnectionString。这样做的原因是为了限制发生任何部署事故的可能性,即错误类型的 Web 服务器连接到错误的数据库。
理想情况下,完全相同的可执行文件和 web.config 应该能够在任何这些环境上运行,而无需在每次部署时单独定制或配置每个环境(这看起来很容易)在部署期间有一天忘记/弄乱,这就是为什么我们不再只需要在每个目标上更改一个连接字符串)。目前部署是通过 FTP 完成的。 更新:使用“构建事件”并修改我们的部署过程可能不是一个坏主意。
我们将无法通过命令行访问生产 Web 服务器。这意味着使用 aspnet_regiis.exe 加密 web.config 已经过时了。 更新:我们可以通过编程方式执行此操作,因此这一点没有实际意义。
我们希望不必在密码更改时重新编译应用程序,因此使用 web.config(或 db.config 或其他)似乎最有意义。
开发人员不应该能够获取生产数据库密码。如果开发人员将源代码检查到他们的本地主机笔记本电脑上(这将确定它应该使用 DevDatabaseConnectionString,还记得吗?)并且笔记本电脑丢失或被盗,则应该无法获取其他连接字符串。因此,不能考虑使用单个 RSA 私钥来解密所有三个密码。 (与上面的#3相反,如果我们走这条路,我们似乎确实需要三个单独的 key 文件;这些文件可以在每台机器上安装一次,并且如果错误的 key 文件部署到错误的服务器,最糟糕的情况是应该发生的是应用程序无法解密任何内容,并且不允许错误的主机访问错误的数据库!)
更新/附录:该应用程序有几个独立的面向 Web 的组件:一个经典的 ASMX Web 服务项目、一个 ASPX Web 表单应用程序和一个较新的 MVC 应用程序。为了避免在每个单独的环境的每个单独的项目中配置相同的连接字符串,最好让它只出现在一个地方。 (可能在我们的 DAL 类库或单个链接的配置文件中。)
我知道这可能是一个主观问题(要求采取“最佳”方式来做某事),但考虑到我提到的标准,我希望确实会出现一个最佳答案。
谢谢!
最佳答案
集成身份验证/Windows 身份验证是一个不错的选择。没有密码,至少没有需要存储在 web.config 中的密码。事实上,这是我更喜欢的选项,除非管理员明确将其从我手中夺走。
就个人而言,对于因机器而异的任何内容(不仅仅是连接字符串),我使用此技术从 web.config 中放入外部引用:http://www.devx.com/vb2themax/Tip/18880
当我将代码越过栅栏扔给生产服务器管理员时,他获得了一个新的 web.config,但没有获得外部文件 - 他使用了之前的文件。
关于asp.net - 如何保证多个connectionString密码安全、独立且易于部署?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3019427/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
有没有办法保证您的系统托盘图标被删除? 添加系统托盘图标: Shell_NotifyIcon(NIM_ADD, &m_tnd); 删除系统托盘图标: Shell_NotifyIcon(NIM_DELE
是否保证(-x) % m,其中x和m在c++中为正standard (c++0x) 为负数,等于 -(x % m)? 我知道它在我知道的所有机器上都是正确的。 最佳答案 除了Luchian的回答,这是
可能还有其他方法可以作为示例,但这不是我要问的重点。 我正在这样做: (future (clojure.java.shell/sh "sleep" "3" :dir "/tmp")) 启动对Shell
可以使用 XREAD(或者可能是另一个命令)以原子方式检测数据是否写入 Redis 流? 进一步来说: 假设您在一个进程中将一些数据添加到 Redis 流中,并看到数据已通过某个自动生成的 key 成
Kotlin 协程是否提供任何“发生之前”保证? 例如,在这种情况下,写入 mutableVar 和随后在(可能)其他线程上读取之间是否存在“发生之前”保证: suspend fun doSometh
我正在开发一个跟踪行程的应用程序。在搜索了这件事之后,我得出结论,实现这一点(持续跟踪用户的位置)的最好方法是使用前台服务。在某些情况下工作得很好,但在其他一些情况下(即使关闭 DOZE),我得到一些
我正在使用 ORM (sqlalchemy) 从 PG 数据库中获取数据。我想避免在我手工编写的 SQL 语句中指定所有表列名称*。 到目前为止,我的假设是返回的列按照用于创建数据库表的 DDL 语句
在 setState 的文档中这样说: setState() does not immediately mutate this.state but creates a pending state tr
我有一个与不同硬件接口(interface)的简单应用程序。对于每个硬件,我针对一个独特的监视器函数生成了一个 pthread_t,总共有 6 个线程:1 个管理线程和 5 个工作线程。 每个线程都有
目前,我有 private ThreadLocal shortDateFormat = new ThreadLocal() { @Override protected DateFormat i
我有一个使用 SolrCloud 将文档写入 Solr 的 Java 作业。输入数据被转换为不同实体的映射,然后将每个实体写入与其实体类型对应的 Solr 集合。 我的代码如下: public voi
我们使用嵌入式设备通过串行到以太网转换器将数据包从串行端口发送到服务器。我们使用的一家制造商 Moxa 将始终以与构建它们相同的方式发送数据包。意思是,如果我们构建一个大小为 255 的数据包,它将始
我是从 C++ 转到 Java 的。在 C++ 世界中,我们关注异常安全,并注意到变元器可以在变元器本身或其委托(delegate)的方法抛出异常时提供不同的保证(最小、强、不抛出)。实现具有强异常保
我想将来自 SAAJ 的 SOAPConnectionFactory 和 MessageFactory 类与多个线程一起使用,但事实证明我不能假设它们是线程安全的。一些相关的帖子: javax.xml
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 5 年前。 Improve
关于正确性,我找不到以下代码片段没有设计缺陷的证据/反证据。 template class MyDirtyPool { public: template std::size_t ad
对于这个问题,我找到了不同的答案,我知道一定有一个确定的答案。 C 中四种主要数据类型的最小分配内存大小是多少? int , double , float , 和 char是我在想什么。做 signe
我正在使用 Kafka Producer,我的应用程序将具有相同键的各个 ProducerRecords 发送到单个分区中,然后这些 ProducerRecords 在发送到代理之前进行批处理(使用
您好,我是服务器端编程 (java) 的新手,正在阅读 SendRedirect 与 Forward 之间的区别。来自 Post-redirect-get pattern它解释说这将阻止通过点击刷新按
我是一名优秀的程序员,十分优秀!