COMING SOON 🚀

Node.js - 실시간 위치 추적 (2)

· 10년 전 · 1297

이제 사용자 위치를 저장할 "Location" 데이터베이스를 생성합니다.

 

mysql> CREATE DATABASE Location;

 

mysql> USE Location; 

 

mysql> CREATE TABLE locations ( 

-> id INT AUTO_INCREMENT PRIMARY KEY,

-> name VARCHAR(50) NOT NULL,

-> latitude DOUBLE NOT NULL,

-> longitude DOUBLE NOT NULL,

-> date DATETIME NOT NULL);

 

 

서버 코드 "app.js" 파일 코드를 작성합니다.

 

// 모듈을 추출합니다.

var fs = require('fs');

var http = require('http');

var express = require('express');

 

// 데이터베이스와 연결합니다.

var client = require('mysql').createConnection({

    user: 'root',

    password: '비밀번호',

    database: 'location'

});

 

// 웹 서버를 생성합니다.

var app = express();

var server = http.createServer(app);

 

// GET - /tracker

app.get('/tracker', function (request, response) {

    // Tracker.html 파일을 제공합니다.

    fs.readFile('Tracker.html', function (error, data) {

        response.send(data.toString());

    });

});

 

// GET - /observer

app.get('/observer', function (request, response) {

    // Observer.html 파일을 제공합니다.

    fs.readFile('Observer.html', function (error, data) {

        response.send(data.toString());

    });

});

 

// GET - /ShowData

app.get('/showdata', function (request, response) {

    // 데이터베이스의 데이터를 제공합니다.

    client.query('SELECT * FROM locations WHERE name=?', [request.param('name')], function (error, data) {

        response.send(data);

    });

});

 

// 웹 서버를 실행합니다.

server.listen(52273, function () {

    console.log('Server Running at http://127.0.0.1:52273');

});

 

// 소켓 서버를 생성 및 실행합니다.

var io = require('socket.io').listen(server);

io.sockets.on('connection', function (socket) {

    // join 이벤트

    socket.on('join', function (data) {

        socket.join(data);

    });

 

    // location 이벤트

    socket.on('location', function (data) {

        // 데이터를 삽입합니다.

        client.query('INSERT INTO locations(name, latitude, longitude, date) VALUES (?, ?, ?, NOW())', [data.name, data.latitude, data.longitude]);

 

        // receive 이벤트를 발생시킵니다.            

        io.sockets.in(data.name).emit('receive', {

            latitude: data.latitude,

            longitude: data.longitude,

            date: Date.now()

        });

    }); 

});


|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
10년 전 조회 1,308
10년 전 조회 1,335
10년 전 조회 1,311
10년 전 조회 1,259
10년 전 조회 1,724
10년 전 조회 1,242
10년 전 조회 1,242
10년 전 조회 1,462
10년 전 조회 1,261
10년 전 조회 1,297
10년 전 조회 1,133
10년 전 조회 1,395
10년 전 조회 1,227
10년 전 조회 1,147
10년 전 조회 1,204
10년 전 조회 1,883
10년 전 조회 1,223
10년 전 조회 1,233
10년 전 조회 1,234
10년 전 조회 1,350
10년 전 조회 1,830
10년 전 조회 1,419
10년 전 조회 1,241
10년 전 조회 1,179
10년 전 조회 1,213
10년 전 조회 1,308
10년 전 조회 1,211
10년 전 조회 1,288
10년 전 조회 1,200
10년 전 조회 1,371
10년 전 조회 1,225
10년 전 조회 1,198
10년 전 조회 1,142
10년 전 조회 1,791
10년 전 조회 1,289
10년 전 조회 1,207
10년 전 조회 1,251
10년 전 조회 1,233
10년 전 조회 1,250
10년 전 조회 1,225
10년 전 조회 1,730
10년 전 조회 1,176
10년 전 조회 1,263
10년 전 조회 1,138
10년 전 조회 1,715
10년 전 조회 1,304
10년 전 조회 1,311
10년 전 조회 1,354
10년 전 조회 1,296
10년 전 조회 1,298
10년 전 조회 1,242
10년 전 조회 1,134
10년 전 조회 1,258
10년 전 조회 1,131
10년 전 조회 1,465
10년 전 조회 1,185
10년 전 조회 1,203
10년 전 조회 1,182
10년 전 조회 1,207
10년 전 조회 1,260
10년 전 조회 1,176
10년 전 조회 1,198
10년 전 조회 1,384
10년 전 조회 1,200
10년 전 조회 1,302
10년 전 조회 1,260
10년 전 조회 1,283
10년 전 조회 1,400
10년 전 조회 1,267
10년 전 조회 1,224
10년 전 조회 1,234
10년 전 조회 1,346
10년 전 조회 1,238
10년 전 조회 1,199
10년 전 조회 1,213
10년 전 조회 1,227
10년 전 조회 1,285
10년 전 조회 1,199
10년 전 조회 1,435
10년 전 조회 1,591
10년 전 조회 1,491
10년 전 조회 1,242
10년 전 조회 1,248
10년 전 조회 1,203
10년 전 조회 1,200
10년 전 조회 1,313
10년 전 조회 1,243
10년 전 조회 1,181
10년 전 조회 1,247
10년 전 조회 1,594
10년 전 조회 2,055
10년 전 조회 1,629
10년 전 조회 1,456
10년 전 조회 1,416
10년 전 조회 1,266
10년 전 조회 1,258
10년 전 조회 1,271
10년 전 조회 1,234
10년 전 조회 1,242
10년 전 조회 1,275