169人参与 • 2024-08-02 • Ajax
这个模块是一个基于c++的简单搜索引擎服务程序,我们整合了http服务器和搜索功能。我们首先初始化一个搜索器对象,使用预先处理好的文档数据(来自第一个模块)来建立索引。然后,我们设置了一个http服务器,并为服务器定义了一个get请求的处理函数,该函数响应客户端对"/s"路径的访问。
当客户端发送包含搜索关键字的请求时,服务器会验证请求中是否包含关键字参数。如果没有关键字,服务器会返回错误信息。如果有关键字,服务器将调用搜索器的搜索方法,传入关键字,并获取搜索结果,这些结果被封装为json字符串返回给客户端。
我们要先在linux机器上安装cpp-httplib库相关介绍文章链接:🔴c++ http 库 cpp-httplib 使用
🚨注意:cpp-httplib
库在使用的时候需要使用较新版本的gcc
// 引入所需的头文件
#include "httplib.hpp"
#include "searcher.hpp"
// 定义输入文件的路径和web服务器的根目录
const std::string input = "data/raw_html/raw.txt";
const std::string root_path = "./wwwroot";
// 主函数,程序的入口点
int main() {
// 创建searcher类的实例并初始化
ns_searcher::searcher search;
search.initsearcher(input);
// 创建httplib::server类的实例,用于处理http请求
httplib::server svr;
// 设置服务器的根目录为root_path
svr.set_base_dir(root_path.c_str());
// 为服务器添加一个get请求的处理函数
svr.get("/s", [&search](const httplib::request &req, httplib::response &rsp) {
// 检查请求中是否包含搜索关键字参数"word"
if (!req.has_param("word")) {
// 如果没有搜索关键字,返回错误信息
rsp.set_content("必须要有搜索关键字!", "text/plain; charset=utf-8");
return;
}
// 从请求中获取搜索关键字
std::string word = req.get_param_value("word");
// 记录日志,输出用户搜索的关键字
log(normal, "用户搜索的: " + word);
// 定义用于存储搜索结果的字符串
std::string json_string;
// 调用search实例的search方法进行搜索,并将结果存储在json_string中
search.search(word, &json_string);
// 设置响应内容为搜索结果,并指定内容类型为json
rsp.set_content(json_string, "application/json");
});
// 记录日志,表示服务器启动成功
log(normal, "服务器启动成功...");
// 服务器开始监听所有ip的8081端口
svr.listen("0.0.0.0", 8081);
// 返回0,表示程序正常结束
return 0;
}
配置文件路径和服务器根目录:
input
用于指定搜索引擎的数据输入文件路径,root_path
用于指定web服务器的根目录。初始化搜索组件:
main
函数中,创建了一个ns_searcher::searcher
类的实例,并调用其initsearcher
方法来初始化搜索索引。这通常涉及加载数据文件和构建搜索所需的数据结构。设置http服务器:
httplib::server
创建一个http服务器实例。set_base_dir
方法设置服务器的根目录,这样服务器就可以提供静态文件服务。/s
。处理搜索请求:
word
的查询参数,这是用户输入的搜索关键字。searcher
实例的search
方法,传入关键字,并获取搜索结果。发送搜索结果:
启动服务器:
listen
方法使服务器开始监听指定端口(8081)上的所有ip地址,准备接收客户端的请求。整体来说,http_server
展示了如何使用c++和现代库来创建一个简单的web搜索引擎。它处理http请求,执行搜索查询,并将结果以json格式返回给用户。这种设计模式适用于创建轻量级的搜索引擎或其他web服务应用程序。
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="x-ua-compatible" content="ie=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
<title>boost 搜索引擎</title>
<style>
/* 去掉网页中的所有的默认内外边距,html的盒子模型 */
* {
/* 设置外边距 */
margin: 0;
/* 设置内边距 */
padding: 0;
}
/* 将我们的body内的内容100%和html的呈现吻合 */
html,
body {
height: 100%;
}
/* 类选择器.container */
.container {
/* 设置div的宽度 */
width: 800px;
/* 通过设置外边距达到居中对齐的目的 */
margin: 0px auto;
/* 设置外边距的上边距,保持元素和网页的上部距离 */
margin-top: 20px;
}
/* 复合选择器,选中container 下的 search */
.container .search {
/* 宽度与父标签保持一致 */
width: 100%;
/* 高度设置为52px */
height: 52px;
}
/* 先选中input标签, 直接设置标签的属性,先要选中, input:标签选择器*/
/* input在进行高度设置的时候,没有考虑边框的问题 */
.container .search input {
/* 设置left浮动 */
float: left;
width: 600px;
height: 50px;
/* 设置边框属性:边框的宽度,样式,颜色 */
border: 1px solid black;
/* 去掉input输入框的有边框 */
border-right: none;
/* 设置内边距,默认文字不要和左侧边框紧挨着 */
padding-left: 10px;
/* 设置input内部的字体的颜色和样式 */
color: #ccc;
font-size: 14px;
}
/* 先选中button标签, 直接设置标签的属性,先要选中, button:标签选择器*/
.container .search button {
/* 设置left浮动 */
float: left;
width: 150px;
height: 52px;
/* 设置button的背景颜色,#4e6ef2 */
background-color: #4e6ef2;
/* 设置button中的字体颜色 */
color: #fff;
/* 设置字体的大小 */
font-size: 19px;
font-family:georgia, 'times new roman', times, serif;
}
.container .result {
width: 100%;
}
.container .result .item {
margin-top: 20px;
}
.container .result .item a {
/* 设置为块级元素,单独站一行 */
display: block;
/* a标签的下划线去掉 */
text-decoration: none;
/* 设置a标签中的文字的字体大小 */
font-size: 20px;
/* 设置字体的颜色 */
color: #4e6ef2;
}
.container .result .item a:hover {
text-decoration: underline;
}
.container .result .item p {
margin-top: 5px;
font-size: 16px;
font-family:'lucida sans', 'lucida sans regular', 'lucida grande', 'lucida sans unicode', geneva, verdana, sans-serif;
}
.container .result .item i{
/* 设置为块级元素,单独站一行 */
display: block;
/* 取消斜体风格 */
font-style: normal;
color: green;
}
</style>
</head>
<body>
<div class="container">
<div class="search">
<input type="text" value="请输入搜索关键字">
<button onclick="search()">搜索一下</button>
</div>
<div class="result">
</div>
</div>
<script>
function search(){
// 是浏览器的一个弹出框
// alert("hello js!");
// 1. 提取数据, $可以理解成就是jquery的别称
let query = $(".container .search input").val();
console.log("query = " + query); //console是浏览器的对话框,可以用来进行查看js数据
//2. 发起http请求,ajax: 属于一个和后端进行数据交互的函数,jquery中的
$.ajax({
type: "get",
url: "/s?word=" + query,
success: function(data){
console.log(data);
buildhtml(data);
}
});
}
function buildhtml(data){
if(data == '' || data == null){
document.write("对不起,您搜索的内容不存在,404, 刷新页面即可重新搜索")
}
// 获取html中的result标签
let result_lable = $(".container .result");
// 清空历史搜索结果
result_lable.empty();
for( let elem of data){
// console.log(elem.title);
// console.log(elem.url);
let a_lable = $("<a>", {
text: elem.title,
href: elem.url,
// 跳转到新的页面
target: "_blank"
});
let p_lable = $("<p>", {
text: elem.desc
});
let i_lable = $("<i>", {
text: elem.url
});
let div_lable = $("<div>", {
class: "item"
});
a_lable.appendto(div_lable);
p_lable.appendto(div_lable);
i_lable.appendto(div_lable);
div_lable.appendto(result_lable);
}
}
</script>
</body>
</html>
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论