Передача керування маршрутом з необов’язковим параметром після root у express?


87

Я працюю над простим додатком для скорочення URL-адрес і маю такі швидкі маршрути:

app.get('/', function(req, res){
  res.render('index', {
    link: null
  });
});

app.post('/', function(req, res){
  function makeRandom(){
    var text = "";
    var possible = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";

    for( var i=0; i < 3 /*y u looking at me <33??*/; i++ )
      text += possible.charAt(Math.floor(Math.random() * possible.length));
    return text;
  }
  var url = req.body.user.url;
  var key = makeRandom();
  client.set(key, url);
  var link = 'http://50.22.248.74/l/' + key;
  res.render('index', {
    link: link
  });
  console.log(url);
  console.log(key);
});

app.get('/l/:key', function(req, res){
  client.get(req.params.key, function(err, reply){
    if(client.get(reply)){
      res.redirect(reply);
    }
    else{
      res.render('index', {
        link: null
      });
    }
  });
});

Я хотів би видалити /l/з мого маршруту (щоб зробити мою URL-адресу коротшою) і зробити параметр: key необов’язковим. Чи буде це правильним способом зробити це:

app.get('/:key?', function(req, res, next){
  client.get(req.params.key, function(err, reply){
    if(client.get(reply)){
      res.redirect(reply);
    }
    else{
      next();
    }
  });
});

app.get('/', function(req, res){
  res.render('index, {
    link: null
  });
});

Не впевнений, чи потрібно мені вказати, що мій /маршрут - це той, до якого потрібно "прив'язати". Але оскільки моїм єдиним іншим маршрутом буде мій оновлений /маршрут, я думаю, це буде працювати нормально.

Відповіді:


193

Це буде працювати залежно від того, що робить client.get, якщо його першим параметром передано undefined.

Щось подібне було б безпечніше:

app.get('/:key?', function(req, res, next) {
    var key = req.params.key;
    if (!key) {
        next();
        return;
    }
    client.get(key, function(err, reply) {
        if(client.get(reply)) {
            res.redirect(reply);
        }
        else {
            res.render('index', {
                link: null
            });
        }
    });
});

Немає проблем із викликом next () всередині зворотного виклику.

Відповідно до цього , обробники викликаються в порядку додавання, тому, поки ваш наступний маршрут app.get ('/', ...), він буде викликаний, якщо немає ключа.


Дякую, чоловіче. Ви альтернатива також цінується. На жаль, у мене є ще одне питання, але я думаю, як ви зазначали, що це результат того, що повертається client.get. Мені видається cannot call method 'indexOf' of nullпомилка.
Qcom

Крім того, чи можна було б зателефонувати next()в else{}?
Qcom

Вибачте за commentfest ха-ха. Виправлено, але це супер jank xD
Qcom

1

Експрес-версія:

"dependencies": {
    "body-parser": "^1.19.0",
    "express": "^4.17.1"
  }

Необов’язкові параметри дуже зручні, їх можна легко оголосити та використовувати, використовуючи express:

app.get('/api/v1/tours/:cId/:pId/:batchNo?', (req, res)=>{
    console.log("category Id: "+req.params.cId);
    console.log("product ID: "+req.params.pId);
    if (req.params.batchNo){
        console.log("Batch No: "+req.params.batchNo);
    }
});

У наведеному вище коді batchNo не є обов'язковим. Express вважатиме це необов’язковим, оскільки після побудови URL-адреси я дав «?» символ після batchNo '/: batchNo?'

Тепер я можу зателефонувати лише з категорією id та productId або з усіма трипараметричними.

http://127.0.0.1:3000/api/v1/tours/5/10
//or
http://127.0.0.1:3000/api/v1/tours/5/10/8987

введіть тут опис зображення введіть тут опис зображення

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.