C语言-写一个简单的Web服务器(四)

经过以上几次的构建,我们基本上已经构建出来了一个简易的Web服务器,接下来将使用查询从文本中查询我们的问题。

查询结果

在这里我设置了一个page全局参数用来记录是哪个页面,避免和登录页面进行冲突重复查询(大家可以自行优化)。

将html中的头拼接到之前写的html页面上去,由于要使用打字机效果使用了typed.js插件,从网络上连接效率太低,我采用启动一个tomcat将插件放入本地使用。

tips:尝试直接放入本地,但是浏览器拒绝这样使用。

c 复制代码
if (strcmp("9", page) != 0) {
    char ans[1024*5];
    memset(ans,0, sizeof(ans));
    read_answer(ans, question);
    strcat(body, "<div class='box'></div>");
    strcat(body, "<script src='http://localhost:8090/cc/typed.min.js'></script>");
    strcat(body, "<script>let typed = new Typed('.box', {strings: ['");
    strcat(body, ans);
    strcat(body, "'],typeSpeed: 120,});</script>");
}
send(client_socket, headers, strlen(headers), 0);
send(client_socket, html_header, strlen(html_header), 0);
send(client_socket, body, strlen(body), 0);
printf("[服务器] 响应完成......\n");

close(client_socket);
printf("[服务器] ---------------断开与客户端(浏览器的连接)------------------\n\n");
c 复制代码
void read_answer(char *line, char *key) {


    FILE *fp = NULL;
    char ans_line[100];
    fp = fopen("D:/cprojects/ai_x/data.txt", "r");
    int step = 0;
    int c = 0;
    while ((c = fgetc(fp)) != EOF) {
        if (c == '\r' || c == '\n') {
            ans_line[step++] = '!';
            continue;
        }
        ans_line[step + 1] = '\0';
        ans_line[step++] = (char) c;
    }

    fclose(fp);

    char *x = strtok(ans_line, "!");

    int index =0;
    while (x != NULL) {
        printf("第%d行--->%s\n", index++,x);
        if(strstr(x,key)){
            strcpy(line,x);
            break;
        }
        x = strtok(NULL, "!");
    }
    printf("查询到的结果===>%s\n", line);

}

测试查询

相关推荐
用户2215204427800几秒前
vue3组件间的通讯方式
前端·vue.js
三十_A18 分钟前
【实录】使用 patch-package 修复第三方 npm 包中的 Bug
前端·npm·bug
下位子26 分钟前
『AI 编程』用 Claude Code 从零到一开发全栈减脂追踪应用
前端·ai编程·claude
tyro曹仓舒26 分钟前
Vue单文件组件到底需不需要写name
前端·vue.js
用户479492835691527 分钟前
面试官:讲讲2FA 双因素认证原理
前端·后端·安全
乐影27 分钟前
TS 模板字符串类型:从基础到进阶的类型编程魔法
前端·typescript
龙在天29 分钟前
CSS 属性值的计算与过程
前端
云鹤_29 分钟前
【Amis源码阅读】组件注册方法远比预想的多!
前端·低代码
xinfei31 分钟前
ES6 新特性 从 ECMAScript 2015(ES6)到 ECMAScript 2025
前端
GBVFtou34 分钟前
vue响应式 track 和trigger 过程
前端