이제 사용자 위치를 저장할 "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()
});
});
});
게시글 목록
| 번호 | 제목 |
|---|---|
| 12281 |
JavaScript
팝업창을 브라우저 해상도 구분없이 항상 중앙에 띄우기 입니다.
1
|
| 20386 | |
| 12280 |
jQuery
간단한 셀렉트 드롭다운 제이쿼리
|
| 12279 |
JavaScript
우클릭해제 소스 보기 자바스크립트 입니다.
|
| 12278 |
JavaScript
미리보기 소스 입니다.
|
| 12277 |
JavaScript
움직임이 자연스러운 자바시계 입니다.
|
| 12276 |
JavaScript
특정사람에게 메일 보내기 입니다.
|
| 12275 |
JavaScript
DirectX의 와이프 기능을 사용한 이미지 스와핑 효과 내기 입니다.
|
| 12274 |
JavaScript
iframe 써서 노 프레임 효과 내기 입니다.
|
| 12273 |
jQuery
이미지 없이 구현하는 간단한 별점 기능 제이쿼리
|
| 12272 | |
| 12260 |
node.js
Node.js - 실시간 위치 추적 (1)
11
|
| 360 | |
| 12258 | |
| 12257 | |
| 12256 | |
| 12255 | |
| 12253 | |
| 12252 | |
| 12251 | |
| 12250 | |
| 12249 | |
| 12248 | |
| 12247 | |
| 12246 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기