电子词典项目(有借鉴)

服务器

#include<myy.h>
#include<sqlite3.h>#define err(msg) do{printf("__%d__",__LINE__);perror(msg);return -1;}while(0)
#define PORT 8888
#define IP "192.168.125.51"
typedef void (*sighandler_t)(int);
typedef struct
{char flag;char name[20];char text[128];
}msg;
char mean[32]="";
int do_register(msg *usr,int afd,sqlite3* db)
{ char sql[256] = "" ;sprintf(sql,"insert into usr values('%s','%s');",usr->name,usr->text);char* errmsg = NULL;if(sqlite3_exec(db,sql,NULL,NULL,&errmsg) != SQLITE_OK)fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__, errmsg);strcpy(usr->text,"usr name already exist");printf("usr name already exist\n");}else{printf("registeration is ok\n");strcpy(usr->text,"usr name registeration successed");	}if(send(afd,usr,sizeof(msg),0)<0)err("send");if(recv(afd,usr,sizeof(msg),0)<0)err("recv");return 0;
}
int do_login(msg *usr,int afd,sqlite3* db)
{sqlite3* db_delete= NULL;char sql[256] ="";char* errmsg = NULL;char **pres=NULL;int row,column;sprintf(sql,"select * from usr where name='%s' and password='%s';",usr->name,usr->text);if(sqlite3_get_table(db, sql,&pres,&row,&column, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_get_table:%s\n", __LINE__, errmsg);return -1;}if(row==1) {printf("login is ok\n");bzero(usr->text,sizeof(usr->text));strcpy(usr->text,"ok");}else{printf("login is failed\n");strcpy(usr->text,"usr name or password inputs error!");	}if(send(afd,usr,sizeof(msg),0)<0)err("send");if(recv(afd,usr,sizeof(msg),0)<0)err("recv");	return 0;
}
int callback_s(void* arg ,int columns, char** column_text, char** column_name)
{for(int i=1; i<columns; i+=2){strcpy(mean,*(column_text+i));}printf("\n");return 0; }int do_search(msg *usr,int afd,sqlite3* db)
{char sql[256] ="",sql_h[256]="",word[64]="",TIME[32]="";time_t t;struct tm *info = NULL;	int flag=0;strcpy(word,usr->text);	t =time(NULL);info =localtime(&t);sprintf(TIME,"%d-%02d-%02d %02d:%02d:%02d",info->tm_year+1900, info->tm_mon+1, info->tm_mday,info->tm_hour, info->tm_min, info->tm_sec);sprintf(sql,"select * from dict where word='%s';",usr->text);char* errmsg = NULL;if(sqlite3_exec(db, sql,callback_s,&flag, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__, errmsg);return -1;}bzero(usr->text,sizeof(usr->text));	strcpy(usr->text,mean);sprintf(sql_h,"insert into history values('%s','%s','%s',\'%s\');",usr->name,word,mean,TIME);bzero(mean,sizeof(mean));bzero(word,sizeof(word));if(sqlite3_exec(db,sql_h,NULL,NULL,&errmsg) != SQLITE_OK)	{fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__, errmsg);		}if(send(afd,usr,sizeof(msg),0)<0)err("send");if(recv(afd,usr,sizeof(msg),0)<0)err("recv");	return 0;
}
int callback_h(void* arg ,int columns, char** column_text, char** column_name)
{int afd=*(int *)arg;msg usr;char word[64]="",TIME[32]="";bzero(usr.text,sizeof(usr.text));bzero(usr.name,sizeof(usr.name));	for(int i=0; i<columns; i++){switch(i){case 0:	{strcpy(usr.name,*(column_text));}break;case 1:	{strcpy(word,*(column_text+1));}break;case 2:	{strcpy(mean,*(column_text+2));}break;case 3:	{strcpy(TIME,*(column_text+3));}break;	}}sprintf(usr.text,"%s:%s\t%s\t%s",usr.name,word,mean,TIME);printf("%s\n",usr.text);if(s waitpidend(afd,&usr,sizeof(msg),0)<0)err("send");return 0; }int do_history(msg* usr,int afd,sqlite3* db)
{char sql[256]="";sprintf(sql,"select * from history where name='%s';",usr->name);char* errmsg = NULL;if(sqlite3_exec(db, sql,callback_h,&afd, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_get_table:%s\n", __LINE__, errmsg);return -1;}	printf("this is all\n");usr->text[0]='\0';if(send(afd,usr,sizeof(msg),0)<0)err("send");exit(0);
}
void handler(int sig)
{while(waitpid(-1,NULL,WNOHANG)>0);
}
int main(int argc, const char *argv[])
{int afd,sfd=socket(AF_INET,SOCK_STREAM,0);if(sfd<0)err("socket");int reuse = 1;if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)err("setsockopt");struct sockaddr_in sin;sin.sin_family=AF_INET;sin.sin_port=htons(PORT);sin.sin_addr.s_addr=inet_addr(IP);if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0)err("bind");if(listen(sfd,10)<0)err("listen");struct sockaddr_in cin;socklen_t addrlen=sizeof(cin);if(SIG_ERR==signal(SIGCHLD,handler))err("signal");sqlite3* db = NULL;if(sqlite3_open("./my.db", &db) != SQLITE_OK){printf("err_code:%d\n", sqlite3_errcode(db));printf("errmsg:%s\n", sqlite3_errmsg(db));fprintf(stderr, "__%d__ sqlite3_open failed\n", __LINE__);return -1;}char* sql_dict = "create table if not exists dict (word char,mean char);" ;char* sql_usr = "create table if not exists usr (name char primary key,password char);" ;char* sql_history = "create table if not exists history (name char,word char,mean char,time char);" ;char* errmsg = NULL;if(sqlite3_exec(db, sql_usr, NULL, NULL, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__, errmsg);return -1;}if(sqlite3_exec(db, sql_history, NULL, NULL, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__, errmsg);return -1;}if(sqlite3_exec(db, sql_dict, NULL, NULL, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__, errmsg);return -1;}msg usr;char choose = 0;int res=0,pid;while(1){if((afd=accept(sfd,(struct sockaddr*)&sin,&addrlen))<0)err("accept");pid=fork();if(pid>0){close(afd);}else if(pid==0){memset(&usr,0,sizeof(msg));res=recv(afd,&usr,sizeof(usr),0);if(res<0)err("recv");printf("flag=%c\n",usr.flag);while(res>0){switch(usr.flag){case 'R':do_register(&usr,afd,db);break;case 'L':do_login(&usr,afd,db);break;case 'S':do_search(&usr,afd,db);break;case 'H':do_history(&usr,afd,db);break;default:printf("error\t261\n");}}}}return 0;
}

客户端

#include <sqlite3.h>
#include<myy.h>#define err(msg) do{printf("__%d__",__LINE__);perror(msg);return -1;}while(0)
#define PORT 8888
#define IP "192.168.125.51"
typedef struct 
{char flag;char name[20];char text[128];//密码或单词
}msg;
int do_register(msg *usr,int sfd)
{ printf("注册中\n");ssize_t res;usr->flag='R';printf("用户名:");scanf("%s",usr->name);printf("密码:");scanf("%s",usr->text);if(send(sfd,usr,sizeof(msg),0)<0)err("send");res = recv(sfd,usr, sizeof(msg), 0);if(res < 0)err("recv");else if(0 == res){printf("server is off-line\n");}printf("%s\n",usr->text);return 0;
}
int do_login(msg *usr,int sfd)
{	printf("登录...\n");ssize_t res;usr->flag='L';   printf("用户名:");scanf("%s",usr->name);printf("密码:");scanf("%s",usr->text);if(send(sfd,usr,sizeof(msg),0)<0)err("send");		res = recv(sfd,usr,sizeof(msg),0);if(res < 0)err("recv");if(strncmp(usr->text,"ok",3)==0){printf("%s : log_in successfully\n",usr->name);return 1;} else{printf("%s\n",usr->text);}return 0;
}int do_search(msg *usr,int sfd)
{printf("#退出\n");ssize_t res;usr->flag='S';while(1){printf("查询的单词:");scanf("%s",usr->text);if(strcmp(usr->text,"#")==0)break;if(send(sfd,usr,sizeof(msg),0)<0)err("send");res=recv(sfd,usr, sizeof(msg), 0);if(res<0)err("recv");printf("mean:%s\n",usr->text);}
}
int do_history(msg *usr,int sfd)
{usr->flag='H';ssize_t res;if(send(sfd,usr,sizeof(msg),0)<0)err("send");printf("the following is history:\n");while(1){res = recv(sfd,usr, sizeof(msg), 0);if(res<0)err("recv");else if(res>0){printf("%s\n",usr->text);}else {printf("this is all history\n");break;}}return 0;	
}
int main(int argc, const char *argv[])
{	int sfd=socket(AF_INET,SOCK_STREAM,0);	if(sfd<0)err("msg");int reuse = 1;if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)err("setsockopt");struct sockaddr_in sin;sin.sin_family=AF_INET;sin.sin_port=htons(PORT);sin.sin_addr.s_addr=inet_addr(IP);if(connect(sfd,(struct sockaddr*)&sin,sizeof(sin))<0)err("connect");msg usr;char choose = 0;int choice=0;//不初始化while(1){memset(&usr,0,sizeof(msg));system("clear");puts("1. 注册");puts("2. 登录");puts("3. 退出");printf("请输入选项>>>");scanf("%c",&choose);	switch(choose){case '1':do_register(&usr,sfd);break;case '2':if(do_login(&usr,sfd)>0){goto log_in;}break;case '3':close(sfd);exit(0);break;default:printf("错误,重新输入\n");}printf("清屏>>>\n");while(getchar()!=10);}log_in:while(1){printf("1.查询单词");printf("2. 历史记录");printf("3. 退出");printf("输入选项>>>");scanf("%d",&choice);getchar();switch(choice){case 1:do_search(&usr,sfd);break;case 2:	do_history(&usr,sfd);break;	case 3:	close(sfd);exit(0);break;	default:printf("输入错误,请重新输入\n");}}return 0;
}

导入

#include <stdio.h>
#include <sqlite3.h>
#include <string.h>int main(int argc, const char *argv[])
{//打开数据库sqlite3* db = NULL;if(sqlite3_open("./my.db", &db) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_open:%s\n", __LINE__, sqlite3_errmsg(db));return -1;}char sql[400] = "create table if not exists dict (word char, mean char)";char* errmsg = NULL;if(sqlite3_exec(db, sql, NULL, NULL, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__,errmsg);return -1;}FILE* fp = fopen("./dict.txt", "r");if(NULL == fp){perror("fopen");return -1;}char buf[300] = "";char word[50]="", mean[300]="";int i = 0;while(fgets(buf, sizeof(buf), fp) != NULL){buf[strlen(buf)-1] = 0;for(i=0; i<strlen(buf)-2; i++){if(buf[i]!=' ' && buf[i+1]==' ' && buf[i+2]==' '){strncpy(word, buf, i+1);}else if(buf[i]==' '&& buf[i+1]==' ' && buf[i+2]!=' '){strcpy(mean, (buf+i+2));break;}}sprintf(sql, "insert into dict values(\"%s\", \"%s\");", word, mean);if(sqlite3_exec(db, sql, NULL, NULL, &errmsg) != SQLITE_OK){fprintf(stderr, "__%d__ sqlite3_exec:%s\n", __LINE__,errmsg);return -1;}bzero(word, sizeof(word));bzero(mean, sizeof(mean));}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/19896.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL实践——参数SQL_SLAVE_SKIP_COUNTER的奥秘

每次数据库复制冲突之后&#xff0c;经常使用的一个命令如下。 SET GLOBAL SQL_SLAVE_SKIP_COUNTER 1;一般会认为&#xff0c;现在出现冲突错误&#xff0c;那就将上面参数值设置为1&#xff0c;跳过出错的这个event就可以解决了。重新启动复制&#xff0c;发现问题果然解决&…

点击编辑变完成

<template><div><button click"dialogshowtrue">添加部门</button><div>部门列表</div><el-table ref"multipleTable" :data"form" tooltip-effect"dark" style"width: 100%">&l…

无人机管控平台,推动电力巡检管理水平提升

各地区无人机作业水平和管理水平存在参差不齐&#xff0c;电力巡检管理要求与业务发展水平不匹配的问题。同时&#xff0c;巡检数据的存储和管理分散&#xff0c;缺乏有效的整合与共享手段&#xff0c;使得内外业脱节&#xff0c;没有形成统一应用和闭环管理。这就导致巡检数据…

springBoot多数据源使用tdengine(3.0.7.1)+MySQL+mybatisPlus+druid连接池

一、安装部署 1、我这里使用的 3.0.7.1版本&#xff0c;因为我看3.x版本已经发布了一年了&#xff0c;增加了很多新的功能&#xff0c;而且3.x官方推荐&#xff0c;对于2.x的版本&#xff0c;官网都已经推荐进行升级到3.x&#xff0c;所以考虑到项目以后的发展&#xff0c;决定…

K8s影响Pod调度和Deployment

5.应用升级回滚和弹性伸缩

数学学习——最优化问题引入、凸集、凸函数、凸优化、梯度、Jacobi矩阵、Hessian矩阵

文章目录 最优化问题引入凸集凸函数凸优化梯度Jacobi矩阵Hessian矩阵 最优化问题引入 例如&#xff1a;有一根绳子&#xff0c;长度一定的情况下&#xff0c;需要如何围成一个面积最大的图像&#xff1f;这就是一个最优化的问题。就是我们高中数学中最常见的最值问题。 最优化…

【深度学习】Transformer,Self-Attention,Multi-Head Attention

必读文章&#xff1a; https://blog.csdn.net/qq_37541097/article/details/117691873 论文名&#xff1a;Attention Is All You Need 文章目录 1、Self-Attention 自注意力机制2、Multi-Head Attention 1、Self-Attention 自注意力机制 Query&#xff08;Q&#xff09;表示当…

企业服务器中了Locked勒索病毒后怎么办,如何解决问题并提高防范意识

科学技术的发展给我们的生活带来了极大便利&#xff0c;但也为企业带来了安全威胁。近期&#xff0c;我们收到很多企业的求助&#xff0c;企业的服务器中了locked后缀勒索病毒&#xff0c;计算机上的所有文件都被加密&#xff0c;无法被正常调取&#xff0c;严重影响了企业的正…

C# 委托、事件、特性程序

委托和事件 public partial class Form1 : Form { public Form1() { InitializeComponent(); Man man new Man("小明"); Roommate[] roommates { new Roommate("小张"), new Roommate("小朱"), …

KepwareEX配置API REST接口

服务端Kepware设置 API允许连接设置 创建通道 请求地址(POST)&#xff1a; https://<主机名_或_ip>:<端口>/config/v1/project/channels 以下示例使用postman工具访问API创建了一个名为Channel1 的通道&#xff0c;其使用在本地主机运行的服务器中的Simulator …

UE5 c++ 的文件操作(记录备忘)

函数库.h // Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h" #include "Kismet/BlueprintFunctionLibrary.h" #include "Microsoft/AllowMicrosoftPlatformTypes.h" #incl…

在 React 中渲染大型数据集的 3 种方法

随着 Web 应用程序变得越来越复杂&#xff0c;我们需要找到有效的方法来优化性能和渲染大型数据集。在 React 应用程序中处理大型数据集时&#xff0c;一次呈现所有数据可能会导致性能不佳和加载时间变慢。 虚拟化是一种通过一次仅呈现数据集的一部分来解决此问题的技术&#…

1. C++面向过程

一、C简介 1.1 C的产生及其特点 从C语言发展演变而来&#xff0c;解决了C语言中存在的一些问题&#xff0c;并增加了对面向对象程序设计方法的支持 与其他高级语言相比&#xff0c;C语言可以直接访问物理地址&#xff1b;与汇编相比它具有良好的可读性和可移植性 C于1980年由…

【MySQL】使用C/C++连接MySQL数据库

【MySQL】使用C/C连接MySQL数据库 验证使用select特殊点 本文目的&#xff1a;使用MySQL提供的CAPI完成对数据库的操作 验证 #include <iostream> #include <mysql/mysql.h>int main() {std::cout<<"mysql cilent version: "<<mysql_get_cl…

uniapp h5支付宝支付后端返回Form表单,前端如何处理

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言1.调取接口拿到后端返回的form表单 前言 uniapp h5 支付宝支付&#xff0c;后端返回一串form表单&#xff0c;前端如何拿到支付串并且调用支付 1.调取接口拿到…

面试热题(接雨水问题)

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 我们看到题的第一步&#xff0c;永远是对入参进行判断 public int trap(int[] height) {if (height null) {return 0;}...} 但是我们想想看&#xff0c;接…

【数据结构】单链表

&#x1f525;博客主页&#xff1a;小王又困了 &#x1f4da;系列专栏&#xff1a;数据结构 &#x1f31f;人之为学&#xff0c;不日近则日退 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 目录 一、什么是链表 1.1链表的概念及结构 1.2单链表的结构 二、链表的实现 …

macOS install redis遇到的bug(tar包,homebrew安装,守护进程redis.conf配置)

官网下载tar包再make install 首先是sudo make test的时候一直报 !!! WARNING The following tests failed: *** [err]: trim on SET with big value in tests/unit/type/string.tcl Expected [r memory usage key] < 42000 (context: type source line 478 file /usr/loca…

Qt项目---简单的计算器

在这篇技术博客中&#xff0c;我们将介绍如何使用Qt框架实现一个简单的计算器应用。我们将使用C编程语言和Qt的图形用户界面库来开发这个应用&#xff0c;并展示如何实现基本的算术操作。 项目设置 首先&#xff0c;我们需要在Qt Creator中创建一个新的Qt Widgets应用程序项目…

使用 github 同步谷歌浏览器书签

想必使用谷歌浏览器Chrome的用户一定非常头疼的一件事就是&#xff1a;账户不能登录&#xff0c;书签收藏夹不能同步&#xff0c;换一台电脑书签收藏夹没有了&#xff01; 下面教大家一招亲测有效适用的方法解决书签同步问题&#xff0c;在任何电脑都可以同步了 1、去下载谷歌…