在去年的 DB 勒索事件之后, 不少的同學(xué)開始加強(qiáng) MongoDB 的安全性, 其中一種辦法就是設(shè)置復(fù)雜的密碼. 那么問題來了, 如果設(shè)置的密碼里包含一些如 “@”, “:” 一樣的特殊字符怎么辦?
站在用戶的角度思考問題,與客戶深入溝通,找到通榆網(wǎng)站設(shè)計與通榆網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:做網(wǎng)站、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、主機(jī)域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋通榆地區(qū)。
mongodb://username:password@host:port/db
這種情況可能使得你的 Mongodb 連接串不能被正常解析, 并且完全有可能出現(xiàn). 煩人的地方在于:
1.使用 “” 雙引號將 password 包起來沒有用
2,使用 \@ 轉(zhuǎn)義也沒有用
解決方案 1
開啟 uri_decode_auth 功能, 拼接連接串之后先 encode 一下, 然后通過 uri_decode_auth 在 driver 內(nèi)部 decode 來繞過這個問題
mongoClient.connect("mongodb://username:p%40ssword@host:port/dbname", { uri_decode_auth: true }, function(err, db) { } );
解決方案2
老老實(shí)實(shí)查文檔, 在 options 中指明:
mongoose.connect('mongodb://localhost/test', {user: 'username', pass: 'p@ssword'}, callback);
以上所述是小編給大家介紹的Node.js Mongodb 密碼特殊字符 @的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!