当前位置: 首页 > news >正文

网络编程7.17

练习:

服务器:

 

#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <pthread.h>
#include <semaphore.h>
#include <wait.h>
#include <signal.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <semaphore.h>
#include <sys/msg.h>
#include <sys/shm.h>
#include <sys/un.h>
#include <head.h>
#include <sqlite3.h>
typedef struct sockaddr_in addr_in_t;
typedef struct sockaddr addr_t;
typedef struct sockaddr_un addr_un_t;enum Type {TYPE_REGIST = 1,TYPE_LOGIN
};enum Operation {SUCCESS = 1,ERR
};typedef struct Pack {enum Type type;enum Operation op;char name[20];char pswd[20];
} pack_t;void client_regist(sqlite3* db, pack_t pack, int client) {char* sql = "insert into stu(name,pswd) values(?,?)";sqlite3_stmt* stmt = NULL;sqlite3_prepare_v2(db, sql, -1, &stmt, 0);sqlite3_bind_text(stmt, 1, pack.name, -1, 0);sqlite3_bind_text(stmt, 2, pack.pswd, -1, 0);int res = sqlite3_step(stmt);if (res != SQLITE_DONE && res != SQLITE_ROW) {pack.op = ERR;} else {pack.op = SUCCESS;}write(client, &pack, sizeof(pack));sqlite3_finalize(stmt); 
}void client_login(sqlite3* db, pack_t pack, int client) {char* sql = "select pswd from stu where name = ?";sqlite3_stmt* stmt = NULL;sqlite3_prepare_v2(db, sql, -1, &stmt, 0);sqlite3_bind_text(stmt, 1, pack.name, -1, 0);int res = sqlite3_step(stmt);if (res == SQLITE_DONE) {pack.op = ERR;} else if (res == SQLITE_ROW) {const char* db_pswd = sqlite3_column_text(stmt, 0);if (strcmp(db_pswd, pack.pswd) == 0) {pack.op = SUCCESS;} else {pack.op = ERR;}}write(client, &pack, sizeof(pack));sqlite3_finalize(stmt); 
}int main(int argc, const char *argv[]) {if (argc < 2) {printf("请输入端口号\n");return 1;}int port = atoi(argv[1]);sqlite3* db = NULL;sqlite3_open("./stu.db", &db);int server = socket(AF_INET, SOCK_STREAM, 0);struct sockaddr_in addr = {0};addr.sin_family = AF_INET;addr.sin_port = htons(port);addr.sin_addr.s_addr = inet_addr("0.0.0.0");if (bind(server, (struct sockaddr*)&addr, sizeof(addr)) == -1) {perror("bind");return 1;}listen(server, 50);int epfd = epoll_create1(EPOLL_CLOEXEC);int count = 0;struct epoll_event server_ev = {0};server_ev.events = EPOLLIN;server_ev.data.fd = server;epoll_ctl(epfd, EPOLL_CTL_ADD, server, &server_ev);count++;struct epoll_event stdin_ev = {0};stdin_ev.events = EPOLLIN;stdin_ev.data.fd = 0;epoll_ctl(epfd, EPOLL_CTL_ADD, 0, &stdin_ev);count++;while (1) {struct epoll_event list[count];memset(list, 0, sizeof(list));int res = epoll_wait(epfd, list, count, -1);for (int i = 0; i < res; i++) {int fd = list[i].data.fd;if (fd == server) {int client = accept(server, 0, 0);printf("有新客户端连接\n");struct epoll_event client_ev = {0};client_ev.events = EPOLLIN | EPOLLET;client_ev.data.fd = client;epoll_ctl(epfd, EPOLL_CTL_ADD, client, &client_ev);count++;} else if (fd == 0) {char buf[64] = "";scanf("%s", buf);getchar();printf("键盘输入数据:%s\n", buf);} else {pack_t pack = {0};int client = fd;int res = read(client, &pack, sizeof(pack));if (res == 0) {printf("客户端断开连接\n");epoll_ctl(epfd, EPOLL_CTL_DEL, fd, 0);close(fd);break;}if (pack.type == TYPE_REGIST) {client_regist(db, pack, client);} else if (pack.type == TYPE_LOGIN) {client_login(db, pack, client);}}}}sqlite3_close(db);return 0;
}

客户端

#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <pthread.h>
#include <semaphore.h>
#include <wait.h>
#include <signal.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <semaphore.h>
#include <sys/msg.h>
#include <sys/shm.h>
#include <sys/un.h>
#include <head.h>
#include <sqlite3.h>
typedef struct sockaddr_in addr_in_t;
typedef struct sockaddr addr_t;
typedef struct sockaddr_un addr_un_t;enum Type {TYPE_REGIST = 1,TYPE_LOGIN
};enum Operation {SUCCESS = 1,ERR
};typedef struct Pack {enum Type type;enum Operation op;char name[20];char pswd[20];
} pack_t;void* thread_main(void* arg) {int client = *(int*)arg;while (1) {pack_t pack = {0};int res = read(client, &pack, sizeof(pack));if (res == 0) break;printf("接收到服务器回包\n");if (pack.type == TYPE_REGIST) {if (pack.op == ERR) {printf("该账号已存在\n");} else {printf("注册成功\n");}} else if (pack.type == TYPE_LOGIN) {if (pack.op == ERR) {printf("账号或密码错误\n");} else {printf("登录成功\n");}}}return NULL;
}int main(int argc, const char *argv[]) {if (argc < 2) {printf("请输入端口号\n");return 1;}int port = atoi(argv[1]);int client = socket(AF_INET, SOCK_STREAM, 0);struct sockaddr_in addr = {0};addr.sin_family = AF_INET;addr.sin_port = htons(port);addr.sin_addr.s_addr = inet_addr("127.0.0.1"); if (connect(client, (struct sockaddr*)&addr, sizeof(addr)) == -1) {perror("connect");return 1;}pthread_t id;pthread_create(&id, 0, thread_main, &client);pthread_detach(id);while (1) {int ch = 0;pack_t pack = {0};printf("1:注册\n");printf("2:登录\n");printf("请选择:");scanf("%d", &ch);getchar();if (ch == 1) {pack.type = TYPE_REGIST;} else if (ch == 2) {pack.type = TYPE_LOGIN;}printf("请输入账号:");scanf("%s", pack.name);getchar();printf("请输入密码:");scanf("%s", pack.pswd);getchar();write(client, &pack, sizeof(pack));}return 0;
}

 

http://www.dtcms.com/a/283823.html

相关文章:

  • cors跨域资源共享
  • Python 网络爬虫 —— 代理服务器
  • 阿里云-通义灵码:隐私保护机制—为数据安全筑起铜墙铁壁
  • Web3.0 实战项目、简历打造、精准投递+面试准备
  • MongoDB 与MySQL 及es的区别
  • 黑客知识-攻击
  • 数据仓库分层经典架构:ODS、DWD、DWS
  • 安卓 GoFasting(间歇性断食)v1.03.35.0708
  • python-字典、集合、序列切片、字符串操作(笔记)
  • cdh6.3.2的hive使用apache paimon格式只能创建不能写报错的问题
  • Thymeleaf 表单绑定与验证详解
  • Rabbitmq direct 模式与 finout区别
  • Apache Ignite 的 Pages Writes Throttling(页面写入节流)
  • C++ - 仿 RabbitMQ 实现消息队列--C++11 异步操作实现线程池
  • InfluxDB 3与Apache Parquet:打造高性能时序数据存储与分析解决方案
  • Apache DolphinScheduler介绍与部署
  • UE5 Nanite使用
  • 下班倒计时
  • 链路聚合实训
  • 管家婆价格折扣跟踪管理:查询、新增、修改、删除
  • JAVA中的Map集合
  • 【01背包】P1466 [USACO2.2] 集合 Subset Sums
  • 华为云容器产品分析
  • HTML表格基础
  • 【Linux】第一个小程序—进度条
  • HikariCP数据库连接池高性能优化实战指南
  • Spring Boot 参数校验:@Valid 与 @Validated
  • 线上协同办公时代:以开源AI大模型等工具培养网感,拥抱职业变革
  • 【前沿技术动态】【AI总结】Spring Boot 4.0 预览版深度解析:云原生时代的新里程碑
  • Fair-code介绍(Fair code)(一套新型软件模型:旨在“开源”“商业可持续性”中找到平衡)