国庆作业day6

服务器

cs 复制代码
#include <my_head.h>
#define IP "192.168.101.66"
#define PORT 6666
int main(int argc, const char *argv[])
{
	//创建套接字
	int fd = socket(AF_INET, SOCK_STREAM, 0);
	if(fd < 0){
		ERR_MSG("socket");
		return -1;
	}

	struct sockaddr_in sin;
	sin.sin_family = AF_INET;
	sin.sin_port = htons(PORT);
	sin.sin_addr.s_addr = inet_addr(IP);

	int reuse = 1;
    if(setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
    {   
        ERR_MSG("setsockopt");
        return -1; 
    }
	//绑定IP和端口
	if(bind(fd, (struct sockaddr *)&sin, sizeof(sin)) < 0){
		ERR_MSG("bind");
		return -1;
	}

	//将套接变成被动监听状态
	if(listen(fd, 64) < 0){
		ERR_MSG("listen");
		return -1;
	}

	//接收连接后的套接字
	struct sockaddr_in cin;
	socklen_t len = sizeof(cin);
	int newfd = accept(fd, (struct sockaddr *)&sin, &len);
	if(newfd < 0){
		ERR_MSG("accept");
		return -1;
	}

	sqlite3 *pdb;
	//打开函数库
	if(sqlite3_open("./sq.db", &pdb) != SQLITE_OK){
		fprintf(stderr, "sqlite3_open __%d__\n", __LINE__);
		return -1;
	}
	printf("sqlite3_open success\n");

	char sql[128] = "CREATE TABLE IF NOT EXISTS passwd (name char primary key, passwd char);";
	char *errmsg = NULL;
	//创建表格
	if(sqlite3_exec(pdb, sql, NULL, NULL, &errmsg) != SQLITE_OK){
		fprintf(stderr, "sqlite3_exec __%d__\n", __LINE__);
		return -1;
	}

	char buf[128] = "";
	ssize_t res = 0;
	char name[64] = "";
	char pwd[64] = "";
	char *p = NULL;
	int i = 0;
	while(1){
		//接收
		res = recv(newfd, buf, sizeof(buf), 0);
		if(res < 0){
			ERR_MSG("recv");
			return -1;
		}else if(0 == res){
			printf("读取完毕\n");
			break;
		}
		printf("%s __%d__\n",buf, __LINE__);

		i = 0;
		while(buf[i] != ' '){
			i++;
		}

		bzero(name, sizeof(name));
		bzero(pwd, sizeof(pwd));
		strcpy(name, buf);
		name[i] = 0;

		p = &buf[i+1];
		strcpy(pwd, p);

		//将账号密码写入数据库
		bzero(sql, sizeof(sql));
		sprintf(sql, "insert into passwd values(\"%s\", %s);", name, pwd);
		printf("%s\n", sql);
		char *emsg;
		if(sqlite3_exec(pdb, sql, NULL, NULL, &emsg) != SQLITE_OK){
			fprintf(stderr, "sqlite3_exec __%d__\n", __LINE__);
			return -1;
		}
		printf("注册成功\n");
	}
	//关闭函数库
	if(sqlite3_close(pdb) != SQLITE_OK){
		fprintf(stderr, "sqlite3_close __%d__\n", __LINE__);
		return -1;
	}

	//关闭套接字
	close(fd);
	close(newfd);
	return 0;
}

客户端

cs 复制代码
#include <my_head.h>
#define IP "192.168.101.66"
#define PORT 6666
int main(int argc, const char *argv[])
{
	//创建套接字
	int fd = socket(AF_INET, SOCK_STREAM, 0);
	if(fd < 0){
		ERR_MSG("socket");
		return -1;
	}
	//连接服务器
	struct sockaddr_in sin;
	sin.sin_family = AF_INET;
	sin.sin_port = htons(PORT);
	sin.sin_addr.s_addr = inet_addr(IP);

	if(connect(fd, (struct sockaddr *)&sin, sizeof(sin)) < 0){
		ERR_MSG("connect");
		return -1;
	}
	char s[128] = "";
	while(1){
		//发送
		printf("请输入:账户 密码 >>>");
		bzero(s, sizeof(s));
		fgets(s, sizeof(s), stdin);
		s[strlen(s)-1] = 0;
		if(0 == strcmp(s, "quit")){
			printf("客户端退出\n");
			break;
		}
		if(send(fd, s, sizeof(s), 0) < 0){
			ERR_MSG("send");
			return -1;
		}
	}
	//关闭套接字
	close(fd);
	return 0;
}
相关推荐
笨笨马甲20 分钟前
Qt QSS使用指南
开发语言·qt
cur1es1 小时前
【JVM类加载&双亲委派模型&垃圾回收机制】
java·jvm·gc·垃圾回收·类加载·双亲委派模型
Mr.朱鹏1 小时前
JVM-GC垃圾回收案例
java·jvm·spring boot·算法·spring·spring cloud·java-ee
焦糖玛奇朵婷1 小时前
实测扭蛋机小程序:开发简单,互动有趣
java·大数据·程序人生·小程序·软件需求
Nan_Shu_6141 小时前
学习: 尚硅谷Java项目之小谷充电宝(3)
java·后端·学习
wzqllwy1 小时前
8 大经典排序算法(Java 实现):原理 + Demo + 核心分析
java·算法·排序算法
智能工业品检测-奇妙智能1 小时前
AIFlowy如何实现与现有Spring Boot项目的无缝集成?
java·spring boot·后端
We་ct1 小时前
LeetCode 77. 组合:DFS回溯+剪枝,高效求解组合问题
开发语言·前端·算法·leetcode·typescript·深度优先·剪枝
從南走到北1 小时前
JAVA无人共享无人健身房物联网结合系统源码支持小程序+公众号+APP+H5
java·物联网·小程序
格林威1 小时前
工业相机图像高速存储(C#版):内存映射文件方法,附Basler相机C#实战代码!
开发语言·人工智能·数码相机·c#·机器视觉·工业相机·堡盟相机