-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathserver.js
92 lines (78 loc) · 2.24 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
const express = require('express');
const multer = require('multer');
const fs = require('fs');
const path = require('path');
const app = express();
const http = require('http');
const socketIo = require('socket.io');
const uploadsDir = path.join(__dirname, 'uploads');
if (!fs.existsSync(uploadsDir)) {
fs.mkdirSync(uploadsDir);
}
// Multer 설정
const storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, 'uploads/');
},
filename: function (req, file, cb) {
cb(null, file.fieldname + '-' + Date.now() + path.extname(file.originalname));
},
});
const upload = multer({ storage: storage });
const mysql = require('mysql');
// MariaDB 연결 설정
const db = mysql.createConnection({
host: 'mariadb.default', // 쿠버네티스 서비스 이름 사용
user: 'root',
password: 'root',
database: 'krampoline',
port: 3306,
});
db.connect((err) => {
if (err) {
console.error('Database connection failed: ' + err.stack);
return;
}
console.log('Connected to database.');
});
// 데이터베이스에서 데이터 조회 라우트
app.get('/data', (req, res) => {
db.query('SELECT * FROM sample_data', (err, result) => {
if (err) {
res.status(500).send('Error in database operation');
} else {
res.json(result);
}
});
});
// 서버 및 Socket.IO 설정
const server = http.createServer(app);
const io = socketIo(server);
io.on('connection', (socket) => {
console.log('A user connected');
socket.on('buttonClicked', (message) => {
console.log(message);
});
socket.on('disconnect', () => {
console.log('user disconnected');
});
});
// 파일 목록 조회 라우트
app.get('/files', (req, res) => {
fs.readdir(path.join(__dirname, 'uploads'), (err, files) => {
if (err) {
res.status(500).send('Error reading files');
} else {
res.json(files);
}
});
});
// 파일 업로드 라우트
app.post('/upload', upload.single('file'), (req, res) => {
console.log('File uploaded');
res.redirect('/files');
});
app.use(express.static(path.join(__dirname)));
server.listen(3000, () => {
console.log('Listening on *:3000');
});