Maison >développement back-end >tutoriel php >Explication détaillée des méthodes de fonctionnement de base de nodejs
Les projets précédents utilisaient PHP pour la collecte et le règlement à haute fréquence, ce qui réduisait considérablement l'efficacité de notre PHP, et le blocage de PHP empêchait nos pages Web de fonctionner normalement. Trouvez donc un langage qui puisse remplacer PHP pour les opérations et la collecte de bases de données, et s'intégrer parfaitement à PHP.
Node.js est un environnement d'exécution JavaScript basé sur le moteur Chrome V8. Node.js utilise un modèle d'E/S non bloquant et piloté par les événements, ce qui le rend léger et efficace. Le gestionnaire de packages npm de Node.js est le plus grand écosystème de bibliothèques open source au monde.
nodejs, tout comme notre compositeur PHP, vous pouvez utiliser la commande npm pour télécharger les plug-ins liés à nodejs.
Vous ne pouvez utiliser que le javascript frontal pour faire fonctionner les fonctions de base, et le coût de l'apprentissage est considérablement réduit.
base de données de liens nodejs
À ce stade, nous compterons sur npm pour télécharger le module mysql
Basculez vers notre projet, npm install mysql -save
Créez un fichier qui exécute sql mysql.js
//连接数据库var mysql = require('mysql');var connection = mysql.createConnection({ host: 'localhost', user: 'root', password: 'root', database:'carbird'}); connection.connect();//查询connection.query('select * from `think_order`', function(err, rows, fields) { if (err) throw err; console.log('查询结果为: ', rows); });//关闭连接connection.end();
Exécutez le js À l'heure actuelle, la plupart des fonctions peuvent être implémentées, y compris les fonctions de règlement régulières, partageant la pression de php, y compris la collecte de données
Créez un exemple de nodejs collectant 1680210 billets de loterie et les stockant dans la base de donnéesCréez pacong.jsvar http = require("http");var iconv = require('iconv-lite');var option = { hostname: "api.api68.com", path: "/klsf/getLotteryInfo.do?issue=&lotCode=10005"}; var req = http.request(option, function(res) {res.on("data", function(chunk) {console.log(JSON.parse( iconv.decode(chunk, "utf-8") )); }); }).on("error", function(e) {console.log(e.message); }); req.end();où var iconv = require('iconv-lite') ; Ce module nécessite le téléchargement de npm Introduit pour résoudre le problème chinois tronquéLe résultat est :
{ errorCode: 0, message: '操作成功', result: { businessCode: 0, message: '操作成功', data: { preDrawIssue: 2018030717, preDrawCode: '03,13,10,11,01,18,07,12', drawIssue: 2018030718, drawTime: '2018-03-07 12:01:20', preDrawTime: '2018-03-07 11:51:20', drawCount: 17, firstDragonTiger: 1, lastBigSmall: 0, sumBigSmall: 1, sumNum: 75, sumSingleDouble: 0, fourthDragonTiger: 0, secondDragonTiger: 0, thirdDragonTiger: 1, frequency: '', lotCode: 10005, iconUrl: 'http://webapp.1680180.com/images/icon/3x/gdkl@3x.png', shelves: 0, groupCode: 3, lotName: '广东快乐十分', totalCount: 84, serverTime: '2018-03-07 11:53:50', index: 100 } } }Introduction du module cheerio pour collecter et traiter des données plus complexes, site Web d'exploration
var express = require('express');var app = express();var request = require('request');var cheerio = require('cheerio'); app.get('/', function(req, res) { request('http://www.zhongjiantang.com/index.php?c=detail&id=57', function(error, response, body) { if (!error && response.statusCode == 200) { $ = cheerio.load(body); res.json({ cat: $('h1').text() }); } }) });var server = app.listen(3000, function() { console.log('listening at 3000'); });Combiné avec nodejs sql L'opération peut insérer des données dans la base de données, ou d'autres opérations connexes Utiliser nodejs pour créer des pages Web et implémenter des fonctions de routageUtiliser npm pour introduire expressCréer un web.js
var express = require('express');var app = express();// 主页输出 "Hello World"app.get('/', function (req, res) { console.log("主页 GET 请求"); res.send('Hello GET'); })// POST 请求app.post('/', function (req, res) { console.log("主页 POST 请求"); res.send('Hello POST'); })// /del_user 页面响应app.get('/del_user', function (req, res) { console.log("/del_user 响应 DELETE 请求"); res.send('删除页面'); })// /list_user 页面 GET 请求app.get('/list_user', function (req, res) { console.log("/list_user GET 请求"); res.send('用户列表页面'); })// 对页面 abcd, abxcd, ab123cd, 等响应 GET 请求app.get('/ab*cd', function(req, res) { console.log("/ab*cd GET 请求"); res.send('正则匹配'); })var server = app.listen(8081, function () { var host = server.address().address var port = server.address().port console.log("应用实例,访问地址为 http://%s:%s", host, port) })Nous pouvons accéder à la page de réponse en accédant à 127.0.0.1:8081, ou opérer
Application des opérations associées de la base de données
Cliquez pour télécharger le fichier d'encapsulation Voyons d'abord comment utiliserdb.select({ table: '数据表', where: '字段名称='查询条件', success: function (result) { //查询成功之后相关操作 } ,})Prenons select comme exemple
Créez SQL :
exports.select = function(obj){ if(!obj){ log('对象不存在'); return; } if(!obj.hasOwnProperty('field')){ obj.field ="*"; } var Sql = 'SELECT '+obj.field+' FROM '+obj.table ; if(obj.hasOwnProperty('where')){ Sql+=' WHERE '+obj.where; } if(obj.hasOwnProperty('limit')){ Sql+=' LIMIT '+obj.limit; } // console.log(Sql); db_query(Sql,obj); };Exécuter SQL :
function db_query(Sql,obj){ var db_client=mysql.createClient(config.dbinfo); db_client.query(Sql,function(err,data){ if(err){ if(obj.error){ if(obj.hasOwnProperty('error')){ obj.error(err); } }else{ log('数据库出错:' + err.message); } }else{ if(obj.hasOwnProperty('success')){ obj.success(data); } } if(obj.hasOwnProperty('callback')){ obj.callback(err,data); } }); db_client.end(); }
Comment référencer un fichier js packagé
var db = require('db'),Résumé : le fonctionnement de la base de données est un processus asynchrone. Cela peut grandement améliorer l'efficacité du travail de nodejs, tout en analyser un exemple asynchrone
//代码示例3//注意还是那个Add,精髓也在这里,随后说到function Add(a, b){ return a+b; }//LazyAdd改变了,多了一个参数cbfunction LazyAdd(a, cb){ return function(b){ cb(a, b); } }//将Add传给形参cbvar result = LazyAdd(1, Add)// 这个时候去做一些其他的程序,等条件成立之后再去执行result = result(2); // => 3Comment nodejs envoie des données à php via http
function requestKj(number) { var postData = JSON.stringify(number); var option = { host: 网址, path: 地址, method: 'POST', headers: { "Content-Type": 'application/json', "Content-Length": Buffer.byteLength(postData) } }; var req = http.request(option, function (res) { res.on('data', function () { }); res.on('end', function () { console.log('成功前端给php'); }); }); req.write(postData); req.end(); setTimeout(function () { yuegengxin(number); },1000) }côté php Recevoir informations fournies par nodejs
public function nodejs_get_data(){ $data= json_decode(file_get_contents('php://input'),true); //对$data数据的相关操作 }Résumé Nodejs n'est encore que la pointe de l'iceberg, et il y a beaucoup à apprendre.
Démo Api de la collection nidejs
Tutoriel du blog maître nodejs
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!