>  기사  >  백엔드 개발  >  기본적인 nodejs 작업 방법에 대한 자세한 설명

기본적인 nodejs 작업 방법에 대한 자세한 설명

小云云
小云云원래의
2018-03-20 11:08:243345검색


이전 프로젝트에서는 고주파 수집 및 정산을 위해 PHP를 사용하여 PHP의 효율성이 크게 저하되었으며 PHP 차단으로 인해 웹 페이지가 정상적으로 실행되지 않았습니다. 따라서 데이터베이스 운영 및 수집을 위해 PHP를 대체하고 PHP와 완벽하게 통합할 수 있는 언어를 찾으십시오.

Node.js는 Chrome V8 엔진을 기반으로 하는 JavaScript 런타임 환경입니다. Node.js는 이벤트 중심의 비차단 I/O 모델을 사용하여 가볍고 효율적입니다. Node.js의 패키지 관리자 npm은 세계 최대의 오픈 소스 라이브러리 생태계입니다.

처음으로 nodejs를 알게 되었습니다

nodejs는 우리의 PHP 작곡가처럼 npm 명령을 사용하여 nodejs 관련 플러그인을 다운로드할 수 있습니다.
프론트엔드 자바스크립트를 이용해 기본적인 기능만 조작할 수 있어 학습 비용이 대폭 절감됩니다.

정상 작업

nodejs 링크 데이터베이스

이번에는 npm을 사용하여 mysql 모듈을 다운로드하겠습니다.
우리 프로젝트로 전환하고 npm install mysql -save
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();

실행 Node.js에서는 데이터 수집을 포함하여 PHP의 압력을 공유하는 정기 결제 기능을 포함하여 대부분의 기능을 구현할 수 있습니다

1680210개의 복권을 수집하여 데이터베이스에 저장하는 nodejs의 예를 만들어 보세요

pacong.js 만들기

var 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();

where var iconv = require('iconv-lite'); 중국어 왜곡 문제를 해결하려면 npm에서 이 모듈을 다운로드하여 도입해야 합니다.

결과는 다음과 같습니다.

{ 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 } } }

더 복잡한 데이터를 수집하고 처리하는 Cherio 모듈을 도입합니다. , 크롤러 웹사이트

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');
});

nodejs SQL 연산과 결합 데이터베이스에 데이터를 삽입하거나 기타 관련 연산을 할 수 있습니다

nodejs를 사용하여 웹 페이지를 만들어 라우팅 기능을 구현합니다

npm을 사용하여 express 도입

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)

})

127.0.0.1:8081을 방문하여 응답 페이지에 접속하거나, 데이터베이스 관련 작업의

패키지를 운영할 수 있습니다

패키지 파일을 다운로드하려면 클릭하세요

사용 방법을 먼저 살펴보세요

        db.select({            table: '数据表',            where: '字段名称='查询条件',
            success: function (result) {
                   //查询成功之后相关操作
                }
                ,})

선택 선택 예를 들어
Create 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);
};

Execute 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();
}

패키지 js 파일 인용 방법

    var db = require('db'),

요약: 데이터베이스 작업은 비동기 프로세스입니다. nodejs의 작업 효율성을 크게 향상시키는 동시에 비동기 예제를 분석할 수 있습니다

//代码示例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); // => 3

nodejs가 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)
}

를 통해 PHP로 데이터를 보내는 방법 php 측에서는 nodejs가 전송한 정보를 수신합니다

    public function nodejs_get_data(){
        $data= json_decode(file_get_contents('php://input'),true);        //对$data数据的相关操作
    }

요약

nodejs가 여전히 노출되어 있습니다. 빙산에 한 구석에 배울 것이 많습니다.

nidejs 컬렉션 API 데모

nodejs 마스터 블로그 튜토리얼

위 내용은 기본적인 nodejs 작업 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.