C语言小项目之基于sqlite3数据库的电子词典项目

电子词典小项目

本人其他项目链接基于linux的智能仓储项目
基于Qt的人脸识别
基于STM32的智能家居
移植人脸识别到Linux开发板上
基于正点原子的IMX6ULL开发板的智能车载系统(Qt)

该项目拥有用户注册和登录验证、历史记录信息,单词在线翻译等功能,服务器采用了fork开辟客户端消息接收和处理线程,支持客户端并发登录

C语言小项目之基于sqlite3数据库的电子词典项目

SQLite介绍
◆SQLite第一个Alpha版本诞生于2000年5月. 至今已经有10个年头了. SQLite也迎来了一个版本 SQLite 3已经发布.

◆SQLite是一款轻型的数据库,是遵守ACID的关系式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl、PHP、Java等,还有ODBC接口,同样比起Mysql,PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。

文章目录

; 前言

提示:这里可以添加本文要记录的大概内容:
该电子词典项目主要有如下功能:
1、用户注册和登录验证
2、服务器端将用户信息和历史记录保存在数据库中。客户端输入用户名和密码,服务器端在数据库中查找、匹配,返回结果
3、单词在线翻译
4、根据客户端输入的单词在字典文件中搜索
5、历史记录查询

提示:以下是本篇文章正文内容,下面案例可供参考

一、服务器流程图

C语言小项目之基于sqlite3数据库的电子词典项目
流程简介:服务器先打开数据库,创建套接字并监听客户端的连接,然后通过fork创建子进程,子进程负责与客户端进行通信,父进程负责接收客户端的连接请求。子进程接收到消息之后,对客户端发送过来的MSG结构体数据进行解析,通过switch语句判断MSG结构体中的type类型,然后不同的类型执行相应的函数。最后将服务器的反馈信息写入到MSG结构体中,并发送给客户端。

; 二、客户端流程图

C语言小项目之基于sqlite3数据库的电子词典项目
流程简介:首先客户端创建流式套接字,以此达到与服务器的通信。然后通过打印在终端的提示来输入相应的数字,从而跳转到对应的功能函数中。在对应的功能函数中,对MSG结构体中的成员变量进行赋值,然后将MSG结构体通过 send函数发送给服务器,同时使用 recv函数接收来自服务器的信息,并对其进行解析。这样就达到了客户端与服务器通信的目的。

三、.client 客户端代码

代码如下(示例):

#include
#include
#include
#include
#include
#include
#include

#define   N  32

#define  R  1
#define  L  2
#define  Q  3
#define  H  4

typedef struct {
    int type;
    char name[N];
    char data[256];
}MSG;

int  do_register(int sockfd, MSG *msg)
{
    msg->type = R;

    printf("Input name:");
    scanf("%s", msg->name);
    getchar();

    printf("Input passwd:");
    scanf("%s", msg->data);

    if(send(sockfd, msg, sizeof(MSG),0) < 0)
    {
        printf("fail to send.\n");
        return -1;
    }

    if(recv(sockfd, msg, sizeof(MSG), 0) < 0)
    {
        printf("Fail to recv.\n");
        return -1;
    }

    printf("%s\n", msg->data);

    return 0;
}

int do_login(int sockfd, MSG *msg)
{
    msg->type = L;

    printf("Input name:");
    scanf("%s", msg->name);
    getchar();

    printf("Input passwd:");
    scanf("%s", msg->data);

    if(send(sockfd, msg, sizeof(MSG),0) < 0)
    {
        printf("fail to send.\n");
        return -1;
    }

    if(recv(sockfd, msg, sizeof(MSG), 0) < 0)
    {
        printf("Fail to recv.\n");
        return -1;
    }

    if(strncmp(msg->data, "OK", 3) == 0)
    {
        printf("Login ok!\n");
        return 1;
    }
    else
    {
        printf("%s\n", msg->data);
    }

    return 0;
}

int do_query(int sockfd, MSG *msg)
{
    msg->type = Q;
    puts("--------------");

    while(1)
    {
        printf("Input word:");
        scanf("%s", msg->data);
        getchar();

        if(strncmp(msg->data, "#", 1) == 0)
            break;

        if(send(sockfd,msg, sizeof(MSG), 0) < 0)
        {
            printf("Fail to send.\n");
            return -1;
        }

        if(recv(sockfd, msg,sizeof(MSG), 0) < 0)
        {
            printf("Fail to recv.\n");
            return -1;
        }
        printf("%s\n", msg->data);
    }

    return 0;
}

int do_history(int sockfd, MSG *msg)
{

    msg->type = H;

    send(sockfd, msg, sizeof(MSG), 0);

    while(1)
    {
        recv(sockfd, msg, sizeof(MSG), 0);

        if(msg->data[0] == '\0')
            break;

        printf("%s\n", msg->data);
    }

    return 0;
}

int main(int argc, const char *argv[])
{

    int sockfd;
    struct sockaddr_in  serveraddr;
    int n;
    MSG  msg;

    if(argc != 3)
    {
        printf("Usage:%s serverip  port.\n", argv[0]);
        return -1;
    }

    if((sockfd = socket(AF_INET, SOCK_STREAM,0)) < 0)
    {
        perror("fail to socket.\n");
        return -1;
    }

    bzero(&serveraddr, sizeof(serveraddr));
    serveraddr.sin_family = AF_INET;
    serveraddr.sin_addr.s_addr = inet_addr(argv[1]);
    serveraddr.sin_port = htons(atoi(argv[2]));

    if(connect(sockfd, (struct sockaddr *)&serveraddr, sizeof(serveraddr)) < 0)
    {
        perror("fail to connect");
        return -1;
    }

    while(1)
    {
        printf("*****************************************************************\n");
        printf("* 1.register          2.login              3.quit               *\n");
        printf("*****************************************************************\n");
        printf("Please choose:");

        scanf("%d", &n);
        getchar();

        switch(n)
        {
        case 1:
            do_register(sockfd, &msg);
            break;
        case 2:
            if(do_login(sockfd, &msg) == 1)
            {
                goto next;
            }
            break;
        case 3:
            close(sockfd);
            exit(0);
            break;
        default:
            printf("Invalid data cmd.\n");
        }

    }

next:
    while(1)
    {
        printf("*****************************************************\n");
        printf("* 1.query_word   2.history_record   3.quit          *\n");
        printf("*****************************************************\n");
        printf("Please choose:");
        scanf("%d", &n);
        getchar();

        switch(n)
        {
            case 1:
                do_query(sockfd, &msg);
                break;
            case 2:
                do_history(sockfd, &msg);
                break;
            case 3:
                close(sockfd);
                exit(0);
                break;
            default :
                printf("Invalid data cmd.\n");
        }

    }

    return 0;
}

四、.server服务器代码

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include

#define   N  32

#define  R  1
#define  L  2
#define  Q  3
#define  H  4

#define  DATABASE  "my.db"

typedef struct {
    int type;
    char name[N];
    char data[256];
}MSG;

int do_client(int acceptfd, sqlite3 *db);
void do_register(int acceptfd, MSG *msg, sqlite3 *db);
int do_login(int acceptfd, MSG *msg, sqlite3 *db);
int do_query(int acceptfd, MSG *msg, sqlite3 *db);
int do_history(int acceptfd, MSG *msg, sqlite3 *db);
int history_callback(void* arg,int f_num,char** f_value,char** f_name);
int do_searchword(int acceptfd, MSG *msg, char word[]);
int get_date(char *date);

int main(int argc, const char *argv[])
{

    int sockfd;
    struct sockaddr_in  serveraddr;
    int n;
    MSG  msg;
    sqlite3 *db;
    int acceptfd;
    pid_t pid;

    if(argc != 3)
    {
        printf("Usage:%s serverip  port.\n", argv[0]);
        return -1;
    }

    if(sqlite3_open(DATABASE, &db) != SQLITE_OK)
    {
        printf("%s\n", sqlite3_errmsg(db));
        return -1;
    }
    else
    {
        printf("open DATABASE success.\n");
    }

    if((sockfd = socket(AF_INET, SOCK_STREAM,0)) < 0)
    {
        perror("fail to socket.\n");
        return -1;
    }

    bzero(&serveraddr, sizeof(serveraddr));
    serveraddr.sin_family = AF_INET;
    serveraddr.sin_addr.s_addr = inet_addr(argv[1]);
    serveraddr.sin_port = htons(atoi(argv[2]));

    if(bind(sockfd, (struct sockaddr *)&serveraddr, sizeof(serveraddr)) < 0)
    {
        perror("fail to bind.\n");
        return -1;
    }

    if(listen(sockfd, 5) < 0)
    {
        printf("fail to listen.\n");
        return -1;
    }

    signal(SIGCHLD, SIG_IGN);

    while(1)
    {
        if((acceptfd = accept(sockfd, NULL, NULL)) < 0)
        {
            perror("fail to accept");
            return -1;
        }

        if((pid = fork()) < 0)
        {
            perror("fail to fork");
            return -1;
        }
        else if(pid == 0)
        {

            close(sockfd);
            do_client(acceptfd, db);

        }
        else
        {
            close(acceptfd);
        }
    }

    return 0;
}

int do_client(int acceptfd, sqlite3 *db)
{
    MSG msg;
    while(recv(acceptfd, &msg, sizeof(msg), 0) > 0)
    {
      printf("type:%d\n", msg.type);
       switch(msg.type)
       {
         case R:
             do_register(acceptfd, &msg, db);
             break;
         case L:
             do_login(acceptfd, &msg, db);
             break;
         case Q:
             do_query(acceptfd, &msg, db);
             break;
         case H:
             do_history(acceptfd, &msg, db);
             break;
         default:
             printf("Invalid data msg.\n");
       }

    }

    printf("client exit.\n");
    close(acceptfd);
    exit(0);

    return 0;
}

void do_register(int acceptfd, MSG *msg, sqlite3 *db)
{
    char * errmsg;
    char sql[128];

    sprintf(sql, "insert into usr values('%s', %s);", msg->name, msg->data);
    printf("%s\n", sql);

    if(sqlite3_exec(db,sql, NULL, NULL, &errmsg) != SQLITE_OK)
    {
        printf("%s\n", errmsg);
        strcpy(msg->data, "usr name already exist.");
    }
    else
    {
        printf("client  register ok!\n");
        strcpy(msg->data, "OK!");
    }

    if(send(acceptfd, msg, sizeof(MSG), 0) < 0)
    {
        perror("fail to send");
        return ;
    }

    return ;
}

int do_login(int acceptfd, MSG *msg , sqlite3 *db)
{
    char sql[128] = {};
    char *errmsg;
    int nrow;
    int ncloumn;
    char **resultp;

    sprintf(sql, "select * from usr where name = '%s' and pass = '%s';", msg->name, msg->data);
    printf("%s\n", sql);

    if(sqlite3_get_table(db, sql, &resultp, &nrow, &ncloumn, &errmsg)!= SQLITE_OK)
    {
        printf("%s\n", errmsg);
        return -1;
    }
    else
    {
        printf("get_table ok!\n");
    }

    if(nrow == 1)
    {
        strcpy(msg->data, "OK");
        send(acceptfd, msg, sizeof(MSG), 0);
        return 1;
    }

    if(nrow == 0)
    {
        strcpy(msg->data,"usr/passwd wrong.");
        send(acceptfd, msg, sizeof(MSG), 0);
    }

    return 0;
}

int do_searchword(int acceptfd, MSG *msg, char word[])
{
    FILE * fp;
    int len = 0;
    char temp[512] = {};
    int result;
    char *p;

    if((fp = fopen("dict.txt", "r")) == NULL)
    {
        perror("fail to fopen.\n");
        strcpy(msg->data, "Failed to open dict.txt");
        send(acceptfd, msg, sizeof(MSG), 0);
        return -1;
    }

    len = strlen(word);
    printf("%s , len = %d\n", word, len);

    while(fgets(temp, 512, fp) != NULL)
    {

        result = strncmp(temp,word,len);

        if(result < 0)
        {
            continue;
        }
        if(result > 0 || ((result == 0) && (temp[len]!=' ')))
        {
            break;
        }

        p = temp + len;

        while(*p == ' ')
        {
            p++;
        }

        strcpy(msg->data, p);
        printf("found word:%s\n", msg->data);

        fclose(fp);
        return 1;
    }

    fclose(fp);

    return 0;
}

int get_date(char *date)
{
    time_t t;
    struct tm *tp;

    time(&t);

    tp = localtime(&t);

    sprintf(date, "%d-%d-%d %d:%d:%d", tp->tm_year + 1900, tp->tm_mon+1, tp->tm_mday,
            tp->tm_hour, tp->tm_min , tp->tm_sec);
    printf("get date:%s\n", date);

    return 0;
}

int do_query(int acceptfd, MSG *msg , sqlite3 *db)
{
    char word[64];
    int found = 0;
    char date[128] = {};
    char sql[128] = {};
    char *errmsg;

    strcpy(word, msg->data);

    found = do_searchword(acceptfd, msg, word);
    printf("查询一个单词完毕.\n");

    if(found == 1)
    {

        get_date(date);

        sprintf(sql, "insert into record values('%s', '%s', '%s')", msg->name, date, word);

        if(sqlite3_exec(db, sql, NULL, NULL, &errmsg) != SQLITE_OK)
        {
            printf("%s\n", errmsg);
            return -1;
        }
        else
        {
            printf("Insert record done.\n");
        }

    }
    else
    {
        strcpy(msg->data, "Not found!");
    }

    send(acceptfd, msg, sizeof(MSG), 0);

    return 0;
}

int history_callback(void* arg,int f_num,char** f_value,char** f_name)
{

    int acceptfd;
    MSG msg;

    acceptfd = *((int *)arg);

    sprintf(msg.data, "%s , %s", f_value[1], f_value[2]);

    send(acceptfd, &msg, sizeof(MSG), 0);

    return 0;
}

int do_history(int acceptfd, MSG *msg, sqlite3 *db)
{
    char sql[128] = {};
    char *errmsg;

    sprintf(sql, "select * from record where name = '%s'", msg->name);

    if(sqlite3_exec(db, sql, history_callback,(void *)&acceptfd, &errmsg)!= SQLITE_OK)
    {
        printf("%s\n", errmsg);
    }
    else
    {
        printf("Query record done.\n");
    }

    msg->data[0] = '\0';

    send(acceptfd, msg, sizeof(MSG), 0);

    return 0;
}

总结

&#x63D0;&#x793A;&#xFF1A;&#x8FD9;&#x91CC;&#x5BF9;&#x6587;&#x7AE0;&#x8FDB;&#x884C;&#x603B;&#x7ED3;&#xFF1A;

例如:以上就是今天要讲的内容,本文仅仅简单介绍了C语言中常见函数的使用,涉及到了应用层的编程知识,例如socket编程、数据库编程,文件IO等。

Original: https://blog.csdn.net/m0_57730390/article/details/126749360
Author: Jason~F
Title: C语言小项目之基于sqlite3数据库的电子词典项目

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/816164/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球