-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.c
More file actions
146 lines (122 loc) · 4.12 KB
/
server.c
File metadata and controls
146 lines (122 loc) · 4.12 KB
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sqlite3.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <unistd.h>
#include <json-c/json.h>
#define PORT 8080
#define BUFFER_SIZE 1024
void initialize_database();
void save_to_database(const char *json_data);
void start_server();
int main() {
initialize_database();
start_server();
return 0;
}
// SQLite 데이터베이스 초기화
void initialize_database() {
sqlite3 *db;
char *err_msg = NULL;
int rc = sqlite3_open("sensor_data.db", &db);
if (rc != SQLITE_OK) {
fprintf(stderr, "Cannot open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
exit(1);
}
const char *sql =
"CREATE TABLE IF NOT EXISTS tb_ph ("
"id INTEGER PRIMARY KEY AUTOINCREMENT, "
"timestamp TEXT, "
"sensor_id TEXT, "
"location TEXT, "
"pH_value REAL, "
"voltage REAL);";
rc = sqlite3_exec(db, sql, 0, 0, &err_msg);
if (rc != SQLITE_OK) {
fprintf(stderr, "Failed to create table: %s\n", err_msg);
sqlite3_free(err_msg);
sqlite3_close(db);
exit(1);
}
sqlite3_close(db);
}
// 서버 소켓 설정 및 실행
void start_server() {
int server_fd, new_socket;
struct sockaddr_in address;
int addrlen = sizeof(address);
char buffer[BUFFER_SIZE] = {0};
if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
perror("Socket failed");
exit(1);
}
address.sin_family = AF_INET;
address.sin_addr.s_addr = INADDR_ANY;
address.sin_port = htons(PORT);
if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0) {
perror("Bind failed");
close(server_fd);
exit(1);
}
if (listen(server_fd, 3) < 0) {
perror("Listen failed");
close(server_fd);
exit(1);
}
printf("Server is listening on port %d\n", PORT);
while (1) {
if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t *)&addrlen)) < 0) {
perror("Accept failed");
continue;
}
int bytes_read = read(new_socket, buffer, BUFFER_SIZE);
if (bytes_read > 0) {
printf("Received data: %s\n", buffer);
save_to_database(buffer);
}
close(new_socket);
memset(buffer, 0, BUFFER_SIZE);
}
}
// 데이터베이스에 JSON 데이터 저장
void save_to_database(const char *json_data) {
sqlite3 *db;
char *err_msg = NULL;
int rc = sqlite3_open("sensor_data.db", &db);
if (rc != SQLITE_OK) {
fprintf(stderr, "Cannot open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
return;
}
// JSON 데이터 파싱
struct json_object *parsed_json;
struct json_object *timestamp, *sensor_id, *location, *pH_value, *voltage;
parsed_json = json_tokener_parse(json_data);
json_object_object_get_ex(parsed_json, "timestamp", ×tamp);
json_object_object_get_ex(parsed_json, "sensor_id", &sensor_id);
json_object_object_get_ex(parsed_json, "location", &location);
json_object_object_get_ex(parsed_json, "pH_value", &pH_value);
json_object_object_get_ex(parsed_json, "voltage", &voltage);
// SQL INSERT 명령 실행
const char *sql_template =
"INSERT INTO tb_ph (timestamp, sensor_id, location, pH_value, voltage) "
"VALUES ('%s', '%s', '%s', %.1f, %.2f);";
char sql[512];
snprintf(sql, sizeof(sql), sql_template,
json_object_get_string(timestamp),
json_object_get_string(sensor_id),
json_object_get_string(location),
json_object_get_double(pH_value),
json_object_get_double(voltage));
rc = sqlite3_exec(db, sql, 0, 0, &err_msg);
if (rc != SQLITE_OK) {
fprintf(stderr, "Failed to insert data: %s\n", err_msg);
sqlite3_free(err_msg);
} else {
printf("Data inserted successfully: %s\n", json_data);
}
sqlite3_close(db);
}