当前位置: 首页 > 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.lryc.cn/news/591035.html

相关文章:

  • JAVA中的Collection集合及ArrayList,LinkedLIst,HashSet,TreeSet和其它实现类的常用方法
  • MyBatis延迟加载(Lazy Loading)之“关联查询”深度解析与实践
  • 【44】MFC入门到精通——MFC 通过Button按钮添加控件变量实现:按下 按钮变色 (比如开关 打开关闭状态) MFC更改button控颜色
  • 数据结构-2(链表)
  • 基于STM32闭环步进电机控制系统设计说明
  • Leaflet地图交互:实现图形与点的同时高亮效果
  • PyTorch生成式人工智能(18)——循环神经网络详解与实现
  • 【Linux基础知识系列】第五十一篇 - Linux文件命名规范与格式
  • Mac 安装及使用sdkman指南
  • Java 大视界 -- Java 大数据在智能交通智能公交站台乘客流量预测与服务优化中的应用(349)
  • Flask+LayUI开发手记(十一):选项集合的数据库扩展类
  • Java 集合框架详解:Collection 接口全解析,从基础到实战
  • 【LeetCode 热题 100】108. 将有序数组转换为二叉搜索树
  • 【Redis 】看门狗:分布式锁的自动续期
  • 如何用Kaggle免费GPU
  • [yotroy.cool] Git 历史迁移笔记:将 Git 项目嵌入另一个仓库子目录中(保留提交记录)
  • 语雀编辑器内双击回车插入当前时间js脚本
  • 【WRFDA第六期】WRFDA 输出文件详述
  • R语言基础| 基本图形绘制(条形图、堆积图、分组图、填充条形图、均值条形图)
  • Spring AI之Prompt开发
  • Web攻防-PHP反序列化Phar文件类CLI框架类PHPGGC生成器TPYiiLaravel
  • Cursor开发步骤
  • 【C++指南】C++ list容器完全解读(四):反向迭代器的巧妙实现
  • 113:路径总和 II
  • Java学习--JVM(2)
  • 基于FPGA的IIC控制EEPROM读写(2)
  • AI算法之图像识别与分类
  • 深入理解Java中的Collections.max()方法
  • 贪心算法(排序)
  • GLM(General Language Model,通用语言模型)