首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
PHP WindSearch站内搜索功能配置安装教程

PHP WindSearch站内搜索功能配置安装教程

热心网友
66
转载
2026-05-07

WindSearch:一个能为PHP项目“零负担”提速的纯PHP全文检索引擎

想为你的PHP网站加一个站内搜索,但又对复杂的配置、吃内存的守护进程望而却步?这事儿,还真有更“清爽”的解法。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

今天要聊的WindSearch,就是一个基于中文分词、纯PHP开发的全文检索引擎。它最大的特点就是“无感集成”:没有繁琐的安装配置,不需要额外的维护调优,更不占用服务器的常驻内存。你可以把它想象成项目里的一个普通库,却能瞬间赋予你强大的搜索能力,与现有PHP代码完美融合。

项目地址放在这儿,有兴趣可以随时看看:github.com/rock365/windsearch

必须极速安装~

说到安装,WindSearch提供了几种接地气的方式,总有一款适合你。

最推荐的是使用Composer,一行命令搞定:

composer require rock365/windsearch

如果你习惯Git,克隆项目仓库也一样方便:

git clone git@github.com:rock365/windsearch.git

或者,直接动动手指,前往GitHub页面手动下载:github.com/rock365/windsearch

还配置啥,立即开始用吧!

工具到手,怎么用?WindSearch很贴心地准备了两种模式:“即用模式”和“专业模式”。前者主打开箱即用,适合快速上马的简单场景;后者则提供了更多精细化的控制,应对复杂搜索需求。

即用模式

“即用模式”,顾名思义,追求的就是一个“快”字。它允许你立即导入数据,无需任何额外配置,并且同时支持整型主键和UUID主键。这个模式下的所有API方法名都带有fast关键字,非常好认。

它的工作原理很直白:对文本进行ngram分词,搜索结果直接返回匹配到的主键集合。拿到这些主键后,你再去MySQL这样的数据库里查询完整的原始数据即可,相当于给数据库查询加了一个高效的“导航”。

引入文件:

安装完成后,首先引入自动加载文件,注意根据你的实际项目调整路径:

require_once 'yourdirname/vendor/autoload.php';

导入数据

// 实例化对象,'test'是你为当前搜索内容起的索引库名称
$Wind = new \WindSearch\Index\Wind('test');

// 如果是首次使用可以跳过,但若之前用即用模式导入过数据,最好先清空一下
$Wind->deleteFastIndex();

// 接下来批次导入数据
// 假设 $res 是你从数据库查询出来的数据集
foreach($res as $v){
    $text = $v['title']; // $text是需要被搜索的内容,比如文章标题
    $primarykey = $v['id']; // $primarykey是这条数据的主键值
    $Wind->fastIndexer($text, $primarykey);
}
// 每导入完一批数据,记得调用这个方法保存到磁盘
$Wind->fastBatchWrite();

// 所有数据全部导入完成后,最后一步:构建索引
// 这个方法不一定要紧接着调用,也可以在所有数据准备就绪后单独执行
$Wind->fastBuildIndex();

开始搜索

// 重新实例化搜索对象
$Wind = new \WindSearch\Index\Wind('test');

// 调用快速搜索方法
// $page 是页码,$listRows 是每页条数
$res = $Wind->fastSearch($text, $page, $listRows);

// $res 返回的就是主键(比如id)的集合,用它们去数据库查详细数据吧

有几个细节需要注意:每个索引库都可以独立使用即用模式,数据也是单独存放的,不会和专业模式的数据混在一起。不过,正因为即用模式隶属于某个索引库,所以当你删除整个索引库时,它的数据也会被一并清理。因此,一个建议是:一个索引库名称尽量只固定使用一种模式,避免管理上的混乱。

当然,天下没有免费的午餐。即用模式追求极简和速度,在搜索的精准度和功能丰富性上,可能会略逊于可深度定制的专业模式。如何选择,就看你的实际应用场景了。

专业模式

(想要玩转专业模式,配合官方文档一起食用,效果更佳哦)

引入文件:

第一步和即用模式一样,引入自动加载文件:

require_once 'yourdirname/vendor/autoload.php';

建索引库:

这个过程,有点像在MySQL里建表,通过一个数组来定义结构,复制修改起来很方便:

$mapping = [
    // 设置索引库的名称,通常对应你的业务表名
    'name' => 'test',
    // 字段配置,这是核心
    'field' => [
        [
            'name' => 'id',
            'type' => 'primarykey', // 必须设置主键字段
            'primarykey_type' => 'Int_Incremental', // 主键类型,这里是自增整数
        ],
        [
            'name' => 'title',
            'index' => true, // 这个字段需要被索引
            'type' => 'text',
            'analyzer' => 'segment', // 配置使用分词器
        ],
        [
            'name' => 'tags',
            'index' => true,
            'type' => 'keyword', // 关键字类型,适合标签这种不分词的数据
        ],
        [
            'name' => 'score',
            'type' => 'numeric', // 数值类型,用于范围查询等
        ],
        [
            'name' => 'time',
            'type' => 'date' // 日期类型
        ],
        [
            'name' => 'descr',
            'type' => 'text', // 文本类型,可能不像title那样需要强分词
        ],
    ]
];

// 实例化对象
$Wind = new \WindSearch\Index\Wind('test');

// 检查一下这个索引库是否已经存在
$is_index = $Wind->checkIndex();

// 如果存在,可以先删除旧的(请谨慎操作)
if ($is_index) {
    $Wind->delIndex();
}

// 创建全新的索引库
$Wind->createIndex($mapping);

导入数据:

// 实例化引擎
$Wind = new \WindSearch\Index\Wind('test');

// 初始化索引构建流程
$Wind->buildIndexInit();

// 开启分词功能,导入数据时传入true参数可以提升速度
$Wind->loadAnalyzer(true);

// 如果数据量不大(比如不到一万条),可以一次性全部查询出来导入
// $result = selectAll...
foreach ($result as $v) {
    $Wind->indexer($v); // 逐条添加数据
}

// 批量将数据写入文件保存
$Wind->batchWrite();

构建索引:

// 所有数据导入结束后,执行这一步来构建最终可用的索引
// 提醒一下:数据量非常大的时候,这个过程可能会比较耗时
$Wind->buildIndex();

开始搜索:

// 实例化引擎
$Wind = new \WindSearch\Index\Wind('test');

// 搜索前别忘记开启分词功能
$Wind->loadAnalyzer();

// 构造搜索查询语句,这里演示搜索单个字段
$query = [
    'match' => [
        'field' => [
            'name' => 'title', // 指定要搜索的字段名
            'query' => $text,  // 搜索关键词
        ],
        'list_rows' => $listRows, // 每页多少条数据
        'page' => $page,         // 第几页
    ]
];

// 调用搜索接口
$res = $Wind->search($query, $page, $listRows);

// 最终,$res['result']['_source'] 里就是可以直接渲染到前台的搜索结果数据了
$resArr = $res['result']['_source'];

以上就是关于PHP WindSearch实现站内搜索功能的一个详细梳理。从极速即用到专业定制,它提供了一套足够灵活且对PHP开发者非常友好的解决方案。如果你的项目正需要一个轻量、高效的搜索能力,不妨试试看。

来源:https://www.jb51.net/program/336330p5r.htm
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

MONIE价格下跌至0.0066美元 Infiblue销毁8000万代币推动通缩预期
web3.0
MONIE价格下跌至0.0066美元 Infiblue销毁8000万代币推动通缩预期

Infiblue World 销毁8000万枚MONIE:Web3项目如何通过通缩机制重建市场信任? 在Web3与区块链游戏领域,代币经济模型的健康度直接决定了项目的生命力。近期,知名区块链游戏生态系统Infiblue World完成了一项关键操作:于5月2日宣布,已成功销毁八千万枚其原生代币MON

热心网友
05.07
Riftbound玩家为何在Vex上线前就对她产生反感
游戏攻略
Riftbound玩家为何在Vex上线前就对她产生反感

距离《Riftbound》最新扩展系列《Unleashed》正式上线仅剩一天。经过一周的预发布期,以及在中国服务器长达一个月的实战检验,哪些新卡将成为环境霸主,玩家心中早已有了答案。 其中,一张名为“Vex, Apathetic”的4费紫色单位卡,因其过于强势的表现,甚至在正式上线前就引发了社区热议

热心网友
05.07
三国杀赵襄觉醒技能详解与实战培养攻略
游戏攻略
三国杀赵襄觉醒技能详解与实战培养攻略

在《三国杀:武将觉醒》中,武将“赵襄”的实战强度与玩法上限,与装备配置和体系构建深度绑定。这份深度培养攻略将为你解析赵襄的核心养成逻辑,提供从入门到精通的实战进阶思路。 三国杀武将觉醒赵襄全面培养攻略 一套契合的装备是赵襄立足战场的根本。游戏前期,【金兰剑】能有效补充伤害缺口;进入后期,追求爆发输出

热心网友
05.07
美证监会主席称加密货币法律框架亟待完善与监管明确
web3.0
美证监会主席称加密货币法律框架亟待完善与监管明确

SEC释放重磅信号:加密货币监管新框架呼之欲出 近日,美国证券交易委员会(SEC)主席保罗·阿特金斯在参议院听证会上的一番表态,在Web3与加密领域投下了一枚“震撼弹”。他明确指出,基于上世纪三十年代的传统证券法律框架,在监管日新月异的加密货币市场时已显“力不从心”。这强烈预示着,SEC或将启动一项

热心网友
05.07
Xbox Series主机全新开机动画将于5月13日正式更新
游戏资讯
Xbox Series主机全新开机动画将于5月13日正式更新

XboxSeriesX|S主机将于5月13日更新开机动画与音效,标志性Logo回归绿色且质感更佳。新任CEO夏尔马上任后推动多项品牌变革,包括更新功能、调整营销策略、下调订阅价格及更换管理层,旨在为Xbox注入新活力。

热心网友
05.07