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