Heim >Web-Frontend >js-Tutorial >Express erstellt einen Abfrageserver
In diesem Artikel wird hauptsächlich die Verwendung von Express zum Erstellen eines einfachen Abfrageservers vorgestellt. Jetzt teile ich ihn mit Ihnen und gebe ihn als Referenz.
In diesem Artikel wird die Methode zum Erstellen eines einfachen Abfrageservers mit Express vorgestellt und mit allen geteilt. Die Details lauten wie folgt:
Der verwendete Technologie-Stack umfasst Express und MySQL.
Projektstruktur:
service --node_modules --app.js --query.js
app.js unterstützt das Aufrufen von Diensten und verwendet Body-Parser, um Anfragen zu verarbeiten.
query.js implementiert die Funktionen der Verknüpfung mit der Datenbank und der Abfrage der Datenbank.
app Der .js-Code lautet wie folgt:
var express = require('express'); var query = require('./query') var bodyParser = require('body-parser'); var cookieParser = require('cookie-parser'); var app = express(); app.use(bodyParser.urlencoded({ extended: false }))//返回的对象是一个键值对,当extended为false的时候,键值对中的值就为'String'或'Array'形式,为true的时候,则可为任何数据类型。 app.use(bodyParser.json()) //跨域支持 app.all('*', function(req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header('Access-Control-Allow-Methods', 'PUT, GET, POST, DELETE, OPTIONS'); res.header("Access-Control-Allow-Headers", "X-Requested-With"); res.header('Access-Control-Allow-Headers', 'Content-Type'); next(); }); //登录 app.post('/login',(req,res)=>{ var opts = req.body; query(" SELECT *FROM `v_users` WHERE userAcount = ?",opts.userName).then((result)=>{ var response = result[0]; if(opts.password !== response.u_password){ return res.send({ errorCode:'404', errorMsg:'登录密码错误' }) } //模拟生成loginToken var loginToken = response.userAcount + Math.random()*Math.pow(10,16) res.send({ loginToken:loginToken }) }) }) var server = app.listen(3000,()=>{ console.log('success') })
Der query.js-Code lautet wie folgt:
(function() { var mysql = require('mysql'); // var session = require('cookie-session'); var query = (sql,key) => { var connection = mysql.createConnection({ host: 'localhost', user: 'root', password: 'root123', database: 'm_users' }); connection.connect() var promise = new Promise((resolve,reject)=>{ connection.query(sql,[key], function(error, results, fields) { if(error){ reject(error) }else{ resolve(results); } }); connection.end(); }); return promise; } module.exports = query; })()
Praktische Zusammenfassung:
1 -Niveau-Nutzung von Express sowie die Verwendung von Body-Parser und MySQL-Plug-Ins.
2. Versuchen Sie, Inspector zum Debuggen des Knotenprogramms zu verwenden und den Debugger zu implementieren.
3 Wenn der Client das verwendet Nach dem Aufruf der Schnittstelle muss unterschieden werden: Content-Type-Unterschied:
Content-Type: application/json;charset=UTF-8-Parameter wird in requestPayload platziert
Content-Type: nicht festgelegt oder Anwendung /x-www-form-urlencoded Parameter Ich habe ihn über Formulardaten
eingefügt und für alle zusammengestellt. Ich hoffe, dass er in Zukunft für alle hilfreich sein wird.
Verwandte Artikel:
Mit Cheerio einen einfachen Webcrawler in Node.js erstellen (ausführliche Anleitung)
Das obige ist der detaillierte Inhalt vonExpress erstellt einen Abfrageserver. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!