freeCodeCamp/guide/chinese/miscellaneous/storing-mongo-username--pas.../index.md

84 lines
6.1 KiB
Markdown
Raw Blame History

This file contains invisible Unicode characters!

This file contains invisible Unicode characters that may be processed differently from what appears below. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to reveal hidden characters.

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

---
title: Storing Mongo Username Password Persistently Using Dotenv
localeTitle: 使用Dotenv持久存储Mongo用户名密码
---
## 使用dotenv存储应用程序的安全信息
本文是关于在本地测试环境中保存第三方站点例如mLab上的安全数据库访问的用户名和密码凭据信息以保护他们免受在github等站点上查看公共存储库的任何人的攻击。
安全信息或私人信息不应存储在您的代码中并推送到存储库因为它会被公开暴露从而使您的信息面临风险如果有人以欺诈手段使用您的凭据您将面临失去API或数据库访问权的风险。
[这篇wiki文章](//forum.freecodecamp.com/t/guide-for-using-mongodb-and-deploying-to-heroku/19347/3)讨论了如何使用export命令保护您的凭据但为了使这些变量保持持久性您有两种选择。但是每次重新启动shell时都会删除以这种方式设置的enivorment变量例如当您关闭计算机并重新启动新的编码会话时。
每次启动新的终端shell时都必须再次执行所有步骤来设置环境变量。这意味着您需要将凭据存储在某个文本文件中或者在第三方帐户例如mLab中查找它们。
每次开始一个新会话时这样做都很乏味,而不是将它们存储在易于查找的代码本身中,我将向您展示一种使用文本文件并导入凭据的方法。
第一种选择是使用您的shell配置文件并在每次启动新终端时导出这些变量。然而在开发新应用程序和项目的几周内您的shell配置文件会被大量的变量堵塞这些变量在每个会话中都不需要。您只需要当前正在处理的应用程序的凭据。
## 清理包含安全凭据的git仓库
如果您已经使用存储在代码库中的凭据将存储库推送到github则只需删除它们并再次推送它将无济于事因为您的凭据存储在历史记录中这对公众也是可见的。如果是这种情况请使用这些命令重置git存储库以清除历史记录。
**首先,**从github删除你的repo。我们准备好之后你会创建一个新的。
**其次,**从工作目录中删除本地git存储库。
\- 将目录更改为工作目录。你的.git repo文件应该在这里。
请注意:如果使用不正确,使用-rf标志可以删除整个硬盘。我使用-i标志代表交互以确定我在正确的目录中。在对几个文件进行排序后我100确定我在正确的位置我会杀死该命令并在没有-i标志的情况下再次运行它。做你觉得最舒服的事情但建议你在运行-rm命令之前有一个完整的计算机备份在多个地方
```
cd <project-name>
rm -i -rf .git
```
**第三,**确保更新.gitignore文件以包含.env文件以及您希望保密的任何其他文件夹。本地IDE文件例如.idea / if例如使用jetbrains可以在此文件中。我的.gitignore文件看起来像这样。请注意您可以在创建文件夹或文件之前添加它而不会导致任何错误。
`.gitignore`
node\_modules
.ENV
数据/
。理念/
**最后**创建一个新的存储库。现在,您已准备好继续创建.env文件并将您的repo安全地推送到github并保证您的凭据安全。
`git init`
## 如何在本地应用程序中使用dotenv
这是节点模块dotenv可以提供帮助的地方。要使用dotenv您需要在应用程序代码中要求它调用它上面的config函数该函数从您计算机上的本地存储文件中提取您的凭据。该文件名为`.env`
**第1步**创建.env文件并将变量存储在其中
`MONGOLAB_URI="mongodb://username:password@ds01316.mlab.com:1316/food"`
**第2步**在主应用程序中要求dotenv
在你的主`app.js` (或任何你命名的)
`var dotenv = require('dotenv');`
**第3步**在变量上调用config函数。 (注意这可以通过链接在一行中完成,但我喜欢看到这是一个单独的活动)。
`dotenv.config();`
**第4步**通过调用流程变量来设置您的mongodb URL
`var url = process.env.MONGOLAB_URI;`
此解决方案可以保护您的代码清洁您不希望推送到公共存储库的安全凭据,同时保持每个应用程序整齐有序并节省开发期间的时间。
**参考文献:**
[osxdaily.com](http://osxdaily.com/2015/07/28/set-enviornment-variables-mac-os-x/)
\[\]http://cdn.osxdaily.com/wp-content/uploads/2014/08/terminal-icon-osx.png ### [在Mac OS X中设置环境变量的位置](http://osxdaily.com/2015/07/28/set-enviornment-variables-mac-os-x/) 在命令行中为当前shell定义环境变量并由任何正在运行的命令或进程继承。他们可以从默认的shellPATH......中确定任何东西......
[stackoverflow.com](http://stackoverflow.com/questions/35356692/best-practice-when-using-an-api-key-in-node-js)
[\[Drake Main](https://i.stack.imgur.com/jRaTj.jpg?s=128&g=1) \]http://stackoverflow.com/users/4956243/drake-main #### [在Node.js中使用API密钥时的最佳实践](http://stackoverflow.com/questions/35356692/best-practice-when-using-an-api-key-in-node-js)
\*\* node.jsapi-key \*\*
[Drake Main](http://stackoverflow.com/users/4956243/drake-main)在[上午07:05 - 2月12日](http://stackoverflow.com/questions/35356692/best-practice-when-using-an-api-key-in-node-js)问道
[stackoverflow.com](http://stackoverflow.com/questions/1213430/how-to-fully-delete-a-git-repository-created-with-init)
[\[Peiniau](https://www.gravatar.com/avatar/9db1745a666cface1731c12d54e189e6?s=128&d=identicon&r=PG) \]http://stackoverflow.com/users/105813/peiniau #### [如何完全删除使用init创建的git存储库](http://stackoverflow.com/questions/1213430/how-to-fully-delete-a-git-repository-created-with-init)
\*\* gitgit-init \*\*
[Peiniau](http://stackoverflow.com/users/105813/peiniau)在[04:06](http://stackoverflow.com/users/105813/peiniau) [PM - 2009年7月31日](http://stackoverflow.com/questions/1213430/how-to-fully-delete-a-git-repository-created-with-init) [提问](http://stackoverflow.com/users/105813/peiniau)