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

}

测试查询

相关推荐
wuhen_n10 分钟前
Pinia状态管理原理:从响应式核心到源码实现
前端·javascript·vue.js
陆枫Larry27 分钟前
小程序 scroll-view 设置 padding 右侧不生效?用一层包裹解决
前端
晴殇i42 分钟前
CommonJS 与 ES6 模块引入的区别详解
前端·javascript·面试
Selicens44 分钟前
git批量删除本地多余分支
前端·git·后端
wuhen_n1 小时前
KeepAlive:组件缓存实现深度解析
前端·javascript·vue.js
前端付豪1 小时前
Nest 项目小实践之图书展示和搜索
前端·node.js·nestjs
wuhen_n1 小时前
Vue Router与响应式系统的集成
前端·javascript·vue.js
青青家的小灰灰1 小时前
金三银四面试官最想听的 React 答案:虚拟 DOM、Hooks 陷阱与大型列表优化
前端·react.js·面试
HelloReader1 小时前
深入理解 Tauri 架构与应用体积优化实战指南
前端
lemon_yyds1 小时前
vue 2 升级vue3 : ref 和 v-model 命名为同名
前端·vue.js