Nodejs Express查询蒙古语使用来自表单的数据进行单个条目



我是一个nodejs newbie,并试图使用来自表单条目中的数据来搜索我的蒙古数据库(我知道存在的(条目(我知道存在(。这是我的代码:

var express = require('express');
var mongoose = require('mongoose');
var bodyParser = require('body-parser');
var cors = require('cors');
var path = require('path');
const MongoClient = require('mongodb').MongoClient;
var app = express();
app.set('view engine', 'ejs')
const port = 3000;
MongoClient.connect('mongodb://<user>:<password>@ds111882.mlab.com:11882/serene-brushlands-55292-db', function(err, database) {
    if(err) return console.log(err);
    db = database
    app.listen(port, function() {
    console.log('Server started at port:'+port);
    });
});
// var urlencodedParser = bodyParser.urlencoded({ extended:false });
app.use(bodyParser.urlencoded({extended:false}));
app.get('/', function(req, res) {
    res.sendFile(__dirname+'/index.html');
});
app.all('/addUser', function(req, res) {
    res.render('addUser');
    db.collection('users').save(req.body, function(err, result) {
        if (err) return console.log(err);
        console.log('saved to database');
    })
    console.log(req.body);
});

app.get('/outputAll', function(req, res) {
    db.collection('users').find().toArray(function (err, result) {
    if (err) return console.log(err);
    res.render('outputall', {users:result});
    });
});
app.get('/Search', function(req, res) {
    res.render('search');
    var query = {}
    console.log(req.body);
    if (req.body.username)
    {
    console.log("true");
    query.username = req.body.username;
    }
    db.collection('users').find({query}).toArray(function(err, result) {
    if (err) return console.log(err);
    console.log(1);
    });
});

search部分旨在实现这一目标。但是我不确定如何从我的输入表单中收集查询并将其传递给该app.get并将其传递给搜索的数据库。这是Search EJS文件:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>MY APP</title>
</head>
<body>
    <div style="margin: 0 auto;width: 500px;">
    <form action="/Search" method="GET" style="margin: 0 auto; width: 200px; margin-top: 100px;">
        <input type="text" placeholder="Search" name="username"  style="margin: 20px auto; font-size: 50px;">
        <!-- <input type="file" name="picture"> -->
        <button type="submit"  style="margin: 20px auto; font-size: 50px;">Submit</button>
    </form>
    </div>
</body>
</html>

我运行时在控制台上的输出是:

服务器从端口开始:3000

{}

[]

{}

[]

我期望{}form数据,而[]是在数据库中搜索查询的结果。请帮助!

--------------------编辑--------------------------------

将表单方法更改为 post之后我会收到的响应是:

Request body  = undefined
[ { _id: 59384e971f8bc03d4ef35486 },
  { _id: 59385153304b40406d49ad28 },
  { _id: 5938519c58358a40e55cded8 },
  { _id: 593889193448616054a95b0d },
  { _id: 59388945b268a0607bce2e9c },
  { _id: 5938894bb268a0607bce2e9d,
    username: 'asfj',
    specialty: 'lkjsf',
    address: 'lkjsdf' },
  { _id: 59388ae40d294f6168c55ccf },
  { _id: 59388ddeba074c630a1a8861 },
  { _id: 5938922a9f549f667c9f7a91 },
  { _id: 5938c29c453e40053965e9eb },
  { _id: 5938c2f9453e40053965e9ec,
    username: 'abc',
    specialty: 'dsfsaddfjk',
    address: 'oidjfioa' },
  { _id: 5938c327453e40053965e9ed } ]
Request body  = abc
[ { _id: 59384e971f8bc03d4ef35486 },
  { _id: 59385153304b40406d49ad28 },
  { _id: 5938519c58358a40e55cded8 },
  { _id: 593889193448616054a95b0d },
  { _id: 59388945b268a0607bce2e9c },
  { _id: 5938894bb268a0607bce2e9d,
    username: 'asfj',
    specialty: 'lkjsf',
    address: 'lkjsdf' },
  { _id: 59388ae40d294f6168c55ccf },
  { _id: 59388ddeba074c630a1a8861 },
  { _id: 5938922a9f549f667c9f7a91 },
  { _id: 5938c29c453e40053965e9eb },
  { _id: 5938c2f9453e40053965e9ec,
    username: 'abc',
    specialty: 'dsfsaddfjk',
    address: 'oidjfioa' },
  { _id: 5938c327453e40053965e9ed } ]

我将add.get('Search',fn)更改为:

app.all('/Search', function(req, res) {
    res.render('search');
    db.collection('users').find().toArray(function(err, result) {
    if (err) return console.log(err);
    var query = {}
    console.log("Request body  = "+req.body.username);
    // if (req.body.username)
    // {
    //     console.log(req.body);
    //     query.username = req.body.username;
    // }
    console.log(result);
    });
});

您要提出的/Search请求是使用GET请求&amp;不是POST。如果要通过请求主体访问表单数据,我建议您使用POST方法或访问GET方法的URL参数。

接收数据后,您可以通过创建对象将其格式化为查询。

在猫鼬中,您应该通过将对象作为参数发送在DB中的文档。例如,如果您在数据库中寻找一个名称约翰的人,则使用

db.collection('users').find({name: 'John'}).then(function(resp){}).catch(function(err){})

{name:'john'}是您的javaScript对象,在执行查询时会使用

由于您说自己是新的,因此学习这种名为Promises的模式很有用。

最新更新