Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/379.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 使用NodeJS/AngularJS创建到MySQL的RESTful API桥_Javascript_Mysql_Angularjs_Node.js_Rest - Fatal编程技术网

Javascript 使用NodeJS/AngularJS创建到MySQL的RESTful API桥

Javascript 使用NodeJS/AngularJS创建到MySQL的RESTful API桥,javascript,mysql,angularjs,node.js,rest,Javascript,Mysql,Angularjs,Node.js,Rest,我是RESTful API的新手,我的应用程序有问题。我想设置HTTP GET方法从mysql检索数据,我认为app.js文件已经连接到数据库(但我不太清楚路由器是如何工作的)。我知道我需要创建一个路由器,但我只是不知道如何做,比如post和get等,我不确定我缺少了什么。请帮忙!我感谢你的时间和回应 ========================================================================= 我想我没有描述我的问题,让我重新表述一下 现在我

我是RESTful API的新手,我的应用程序有问题。我想设置HTTP GET方法从mysql检索数据,我认为app.js文件已经连接到数据库(但我不太清楚路由器是如何工作的)。我知道我需要创建一个路由器,但我只是不知道如何做,比如post和get等,我不确定我缺少了什么。请帮忙!我感谢你的时间和回应

========================================================================= 我想我没有描述我的问题,让我重新表述一下

  • 现在我有了一个模型

    @models/Users.js

  • 我有路由器文件

    @路由器/index.js和user.js`

  • (它们都是express生成的默认文件)

  • 我还有一个半设置文件(我不确定)

    @app.js

  • 我的目标是在url中键入/whatever可以从http获得响应,比如json数据或数据库中的任何内容。我知道我的文件中有很多问题(可能所有的问题都写得不正确),我只是想得到一个帮助,使其正确,以便我了解结构。谢谢你的帮助

    app.js:

    var express = require('express');
    var path = require('path');
    var favicon = require('serve-favicon');
    var logger = require('morgan');
    var cookieParser = require('cookie-parser');
    var bodyParser = require('body-parser');
    
    var routes = require('./routes/index');
    var users = require('./routes/users');
    
    var app = express();
    
    var mysql = require('mysql');
    require('./models/Users');
    
    
    
    // view engine setup
    app.set('views', path.join(__dirname, 'views'));
    app.set('view engine', 'ejs');
    
    // uncomment after placing your favicon in /public
    //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
    app.use(logger('dev'));
    app.use(bodyParser.json());
    app.use(bodyParser.urlencoded({ extended: false }));
    app.use(cookieParser());
    app.use(express.static(path.join(__dirname, 'public')));
    
    app.use('/', routes);
    app.use('/users', users);
    
    // catch 404 and forward to error handler
    app.use(function(req, res, next) {
      var err = new Error('Not Found');
      err.status = 404;
      next(err);
    });
    
    // error handlers
    
    // development error handler
    // will print stacktrace
    if (app.get('env') === 'development') {
      app.use(function(err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
          message: err.message,
          error: err
        });
      });
    }
    
    // production error handler
    // no stacktraces leaked to user
    app.use(function(err, req, res, next) {
      res.status(err.status || 500);
      res.render('error', {
        message: err.message,
        error: {}
      });
    });
    
    
    module.exports = app;
    
    /models/User.js

    var mysql      = require('mysql');
    var connection = mysql.createConnection({
        connectionLimit : 100,
        host     : 'localhost',
        user     : 'root',
        password : '',
        database : 'ajs02'
    });
    
    connection.connect();
    
    connection.query('SELECT * from post', function(err, rows, fields) {
      if (!err)
        console.log('The solution is: ', rows);
      else
        console.log('Error while performing Query.');
    });
    
    connection.end();
    
    /路由器/index.js

    var express = require('express');
    var router = express.Router();
    
    var mysql = require('mysql');
    
    
    /* GET home page. */
    
    router.get('/', function(req, res, next) {
      res.render('index', { title: 'Express' });
    });
    
    router.get('/match', function(req, res) {
        mysql.query('SELECT * FROM ' + req.params.table + ' ORDER BY id DESC LIMIT 20', req.params.id, function(err, rows, fields) {
            var user = new User(req.postId);
    
    
            res.send(user)
            connection.release();
        });
    });
    router.get('/hw', function(req, res) {
      res.send('hello world');
    });
    
    module.exports = router;
    

    RESTful API的工作原理与您的数据库已经支持的CRUD(创建、读取、更新、删除)操作相同。您只需要将这些SQL操作转换为RESTful(HTTP请求)动词,如GET、PUT、POST和DELETE

    考虑:

    // a GET request = a database READ or (a.k.a SELECT)
    app.get('/path', function(req, res) {
        connection.query('SELECT * FROM ' + req.params.table + ' ORDER BY id DESC LIMIT 20', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object .. ')
            connection.release();
        });
    });
    
    // a POST request = a database CREATE (a.k.a INSERT)
    app.post('/path', function(req, res) {
        connection.query('INSERT INTO ' + req.params.table + ' SOME OTHER PARTS OF YOUR SQL QUERY', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object again .. ')
            connection.release();
        });
    });
    
    // a PUT request = a database UPDATE
    app.put('/path', function(req, res) {
        connection.query('UPDATE ' + req.params.id + ' SOME OTHER PARTS OF YOUR SQL QUERY', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object yet again .. ')
            connection.release();
        });
    });
    
    // a DELETE request = a database DELETE
    app.delete('/path', function(req, res) {
        connection.query('DELETE FROM ' + req.params.table + ' SOME OTHER PARTS OF YOUR SQL QUERY', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object once again .. ')
            connection.release();
        });
    });
    

    至于路线,请从。在基本级别,定义的路由(例如
    /path
    )对应于请求URI:
    http://yourserver.com/path
    )。它还分别支持通配符、命名参数和正则表达式,如:
    /path/:id
    /path/*
    /path/id.*$

    RESTful API的工作原理与数据库已经支持的CRUD(创建、读取、更新、删除)操作相同。您只需要将这些SQL操作转换为RESTful(HTTP请求)动词,如GET、PUT、POST和DELETE

    考虑:

    // a GET request = a database READ or (a.k.a SELECT)
    app.get('/path', function(req, res) {
        connection.query('SELECT * FROM ' + req.params.table + ' ORDER BY id DESC LIMIT 20', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object .. ')
            connection.release();
        });
    });
    
    // a POST request = a database CREATE (a.k.a INSERT)
    app.post('/path', function(req, res) {
        connection.query('INSERT INTO ' + req.params.table + ' SOME OTHER PARTS OF YOUR SQL QUERY', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object again .. ')
            connection.release();
        });
    });
    
    // a PUT request = a database UPDATE
    app.put('/path', function(req, res) {
        connection.query('UPDATE ' + req.params.id + ' SOME OTHER PARTS OF YOUR SQL QUERY', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object yet again .. ')
            connection.release();
        });
    });
    
    // a DELETE request = a database DELETE
    app.delete('/path', function(req, res) {
        connection.query('DELETE FROM ' + req.params.table + ' SOME OTHER PARTS OF YOUR SQL QUERY', req.params.id, function(err, rows, fields) {
            res.json('.. assume you translated your database response a javascript object once again .. ')
            connection.release();
        });
    });
    

    至于路线,请从。在基本级别,定义的路由(例如
    /path
    )对应于请求URI:
    http://yourserver.com/path
    )。它还分别支持通配符、命名参数和正则表达式,如:
    /path/:id
    /path/*
    /path/id.*$

    我刚刚更新了我的问题,很抱歉我没有解释清楚。好的,我的答案是正确的。我不会为您写出数据库查询,但这是一个很好的起点。@remus我喜欢您在我的末尾添加+1的链接。我刚刚更新了我的问题,很抱歉我没有解释清楚。好的,我的答案是正确的。我不打算为您写出数据库查询,但这是一个很好的起点。@remus我喜欢您在我的末尾添加+1的链接