Node.js Mongodb 密码特殊字符 @的解决方法
2017-04-11 10:23
1336 查看
在去年的 DB 勒索事件之后, 不少的同学开始加强 Mongodb 的安全性, 其中一种办法就是设置复杂的密码. 那么问题来了, 如果设置的密码里包含一些如 “@”, “:” 一样的特殊字符怎么办?
mongodb://username:password@host:port/db
这种情况可能使得你的 Mongodb 连接串不能被正常解析, 并且完全有可能出现. 烦人的地方在于:
1.使用 “” 双引号将 password 包起来没有用
2,使用 \@ 转义也没有用
解决方案 1
开启 uri_decode_auth 功能, 拼接连接串之后先 encode 一下, 然后通过 uri_decode_auth 在 driver 内部 decode 来绕过这个问题
mongoClient.connect("mongodb://username:p%40ssword@host:port/dbname", { uri_decode_auth: true }, function(err, db) { } );
解决方案2
老老实实查文档, 在 options 中指明:
mongoose.connect('mongodb://localhost/test', {user: 'username', pass: 'p@ssword'}, callback);
以上所述是小编给大家介绍的Node.js Mongodb 密码特殊字符 @的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- js的form表单提交url传参数(包含+等特殊字符)的解决方法
- js的form表单提交url传参数(包含+等特殊字符)的两种解决方法
- Oracle用户密码含有特殊字符导致无法登陆解决方法
- js传参数受特殊字符影响错误的解决方法
- js传参数受特殊字符影响错误的解决方法
- exp 时遇到密码有特殊字符(!@#)解决方法
- Oracle用户密码含有特殊字符导致无法登陆解决方法
- js的form表单提交url传参数(包含+等特殊字符)的解决方法
- Oracle用户密码含有特殊字符导致无法登陆解决方法
- 【ASP.NET】"密码最短长度为7,其中必须包含以下非字母数字字符1"解决方法
- "密码最短长度为7,其中必须包含以下非字母数字字符1"解决方法 (转)
- mysql自动过滤特殊字符的解决方法
- Linux系统下串口接收数据,部分特殊字符丢失的解决方法
- url 特殊字符 传递参数解决方法
- .net 中Request.QueryString 中传递特殊字符的解决方法
- url 传递参数(特殊字符)解决方法
- url特殊字符转义及解决方法
- 【oracle密码特殊字符使用方法】
- url 传递参数(特殊字符)解决方法
- url 传递参数(特殊字符)解决方法