Middleware pre viditeľnosť heslo (Uzol JS)

0

Otázka

Vzhľadom na tieto router-scenár:

router.get('/A', [returns password])
router.get('/B', [returns no password])

Čo by mal správny middleware vyzerať, že sa vráti heslo v závislosti na trase?

Môj pokus vyzerá takto:

function passwordCheck(req, res, next) {
  let user= req.body_id
  User.findOne({_id: id}).select('+password').exec(function(err, result) {
    if (err) {
      console.log("error: " + err)
    } else {

      console.log("okay.");
      res.send(result)
    }
  })
}
express javascript mongoose router
2021-11-22 11:51:13
1

Najlepšiu odpoveď

0

Môžete vytvoriť niečo podobné middleware výroby:

const checkPassword = (returnPassword = false) => {
    return (req, res, next) => {
        User.findOne({_id: req.body_id })
        .select('+password')
        .exec((err, result) => {
            if (err) {
                console.error(err);
                return res.status(500).send() // End of request on error?
            } else {
                const password = result['password'] // get your password this way or somehow else
                if (returnPassword) {
                    // Store password in request if returnPassword=true 
                    res.locals.userPassword = password;
                } 
                next();
            }
        })
    }
}

Použitie:

router.get('/A', checkPassword(true), routeA)
router.get('/B', checkPassword(false), routeB)

Prístup v trasách:

router.get('/', (req, res) => {
  console.log(res.locals.userPassword) // Actual password for /A, undefined for /B
});

Pozrite sa tiež Vyjadriť dokumenty: Písanie middleware pre použitie v Express aplikácie pochopiť, čo je next a ako to funguje (všimol som si, ako ste nemali používať ho vo svoj pokus o spojenie).
Tiež myslím, že máte niekoľko preklepov:

  • select('+password') - ste si istý, plus je to potrebné?
  • findOne({_id: id}) - by mal byť findOne({_id: user})? Alebo, prečo ste definované user inak?

P. S. ... a nikdy nezabudnem na rukoväť chyby :)

2021-11-22 14:23:19

Môžem pridať, že by sme sa mali snažiť obchod našich premenných v niečo ako res.locals namiesto priamo na req. Tento zvyk môže prepísať dôležité premenné v req objekt.
Someone Special

@SomeoneSpecial dohodli, vďaka za tip! Som aktualizoval svoju kód
Xeelley

Ja som skoro tam: if(!req.body.userID && !req.body.userName && !req.body.password) { let so userService.getUsers(function(error, users) { for(let i = 0; i < users.length; i++){ console.log(users[i].noPassword) so=users[i].noPassword() console.log(so) /* res.write(so) */ res.write(toString(so)) } res.end() }) } Som iterovať cez mongoose objekty a vymazať na každý jeden heslo. ALE ako mám dať tieto nové objekty späť do zbierky ?
pawl123

@pawl123 prosím. nepoužívajte komentáre pre veľké útržky kódu (pre lepšiu čitateľnosť účely), lepšie aktualizovať vašu odpoveď.
Xeelley

V iných jazykoch

Táto stránka je v iných jazykoch

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................