97 lines
2.6 KiB
C
97 lines
2.6 KiB
C
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
#include <ssocket.h>
|
|
#include <tthread.h>
|
|
#include <iini.h>
|
|
#include <llog.h>
|
|
#define BUFFER_SIZE 128
|
|
|
|
SOCKET cfd;
|
|
MUTEX std_mutex;
|
|
char buf[BUFFER_SIZE];
|
|
const log_mask_t g_mask = LOG_MASK_BASE_DEFAULT;
|
|
|
|
#define _STR(str) #str
|
|
#define STR(str) _STR(str)
|
|
|
|
void receive_message(void* param)
|
|
{
|
|
log_head_info_ex(buf, BUFFER_SIZE, "recv", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "recv start...\n");
|
|
int res = 0;
|
|
char Buf[1024] = { 0 };
|
|
while (1) {
|
|
res = recv(cfd, Buf, sizeof(Buf), 0);
|
|
if (res > 0 && res <= 1024) {
|
|
log_head_info_ex(buf, BUFFER_SIZE, "recv", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "[Recv]:%d,%s", res, Buf);
|
|
}
|
|
else {
|
|
break;
|
|
}
|
|
}
|
|
log_head_info_ex(buf, BUFFER_SIZE, "recv", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "server close connect, Close in three seconds\n");
|
|
sleeps(3);
|
|
exit(-1);
|
|
// return NULL;
|
|
}
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
int res;
|
|
char param[2][BUFFER_SIZE] = { 0 };
|
|
char local_buf[BUFFER_SIZE] = { 0 };
|
|
int szlocal_buf = 0;
|
|
ini_get_str("client.ini", "base", "server_ip", _SOCKET_TEST_IP4, param[0], BUFFER_SIZE);
|
|
ini_get_str("client.ini", "base", "server_port", STR(_SOCKET_TEST_PORT), param[1], BUFFER_SIZE);
|
|
thread_mutex_init(&std_mutex);
|
|
|
|
res = make_client_sock_ex(&cfd, param[0], param[1], NULL);
|
|
|
|
if (res != 0) {
|
|
log_head_fatal_ex(buf, BUFFER_SIZE, "ssocket", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "error client sock, error code:%d, press enter to continue\n", res);
|
|
if(getchar());
|
|
exit(-1);
|
|
}
|
|
log_head_info_ex(buf, BUFFER_SIZE, "ssocket", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "conncet server success... [%s:%s]\n", param[0], param[1]);
|
|
thread_create(NULL, receive_message, NULL);
|
|
|
|
while (1) {
|
|
fgets(local_buf, BUFFER_SIZE, stdin);
|
|
if (strncasecmp(local_buf, "exit", strlen("exit")) == 0) {
|
|
log_head_info_ex(buf, BUFFER_SIZE, "command", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "client exit... press enter to continue\n");
|
|
if(getchar());
|
|
exit(-1);
|
|
}
|
|
szlocal_buf = strlen(local_buf);
|
|
if (local_buf[szlocal_buf-1] == '\n') {
|
|
local_buf[szlocal_buf-1] = '\0';
|
|
}
|
|
else {
|
|
szlocal_buf += 1;
|
|
}
|
|
res = send(cfd, local_buf, szlocal_buf, 0);
|
|
if (res == -1) {
|
|
log_head_info_ex(buf, BUFFER_SIZE, "send", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "send error %s, press enter to continue\n", local_buf);
|
|
if(getchar());
|
|
exit(-1);
|
|
}
|
|
log_head_info_ex(buf, BUFFER_SIZE, "send", g_mask);
|
|
tprintf(&std_mutex, buf);
|
|
tprintf(&std_mutex, "[send]=%d,\"%s\"\n", szlocal_buf, local_buf);
|
|
}
|
|
return 0;
|
|
} |