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);

}

测试查询

相关推荐
Jinuss5 分钟前
Vue3源码reactivity响应式篇之computed计算属性
前端·vue3
落日沉溺于海5 分钟前
React From表单使用Formik和yup进行校验
开发语言·前端·javascript
知识分享小能手7 分钟前
React学习教程,从入门到精通, React 新创建组件语法知识点及案例代码(11)
前端·javascript·学习·react.js·架构·前端框架·react
会豪10 分钟前
工业仿真(simulation)--前端(五)--标尺,刻度尺
前端
会豪11 分钟前
工业仿真(simulation)--前端(四)--画布编辑(2)
前端
an__ya__13 分钟前
Vue数据响应式reactive
前端·javascript·vue.js
苦逼的搬砖工16 分钟前
Flutter UI Components:闲来无事,设计整理了这几年来使用的UI组件库
前端·flutter
想买Rolex和Supra的凯美瑞车主18 分钟前
Taro + Vite 开发中 fs.allow 配置问题分析与解决
前端
ruanCat19 分钟前
使用 vite 的 base 命令行参数来解决项目部署在 github page 的路径问题
前端·github
Codebee24 分钟前
使用Qoder 改造前端UI/UE升级改造实践:从传统界面到现代化体验的华丽蜕变
前端·人工智能