登录
首页 >  文章 >  php教程

PHP搜索关键词高亮代码示例

时间:2026-02-08 12:03:38 442浏览 收藏

推广推荐
下载万磁搜索绿色版 ➜
支持 PC / 移动端,安全直达

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习文章相关编程知识。下面本篇文章就来带大家聊聊《PHP搜索高亮实现代码示例》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!

用 preg_replace 实现关键词高亮需先转义用户输入(preg_quote($keyword, '/')),加 i 修饰符不区分大小写,用 '$0' 替换;须先 htmlspecialchars 原文防 XSS,再替换 mark 标签;中文注意全角/半角空格统一处理。

php代码示例怎样实现搜索高亮_php搜索结果高亮代码示例【示例】

preg_replace 实现关键词高亮最直接

核心思路是把搜索词当作正则模式,用 preg_replace 替换为带 HTML 标签的高亮内容。注意必须转义用户输入,否则特殊字符(如 .+[)会破坏正则匹配甚至引发错误。

实操建议:

  • preg_quote($keyword, '/') 转义关键词,斜杠 / 是正则分隔符,必须传入第二个参数
  • i 修饰符实现不区分大小写匹配:/'.preg_quote($keyword, '/').'/'.'i'
  • 替换时用 '$0'$0 表示完整匹配项,比捕获组更安全
  • 若需高亮多个词,逐个循环调用 preg_replace,不要拼成一个正则——容易冲突且难以调试

为什么不用 str_replace 直接替换

str_replace 看似简单,但对大小写敏感、不支持模糊匹配、无法处理重叠关键词(比如搜索 phpphpstorm 同时存在时),而且容易误替换 HTML 标签里的内容(如

中的 php)。

更关键的是:如果用户搜的是 a+bstr_replace 会原样去字符串里找 a+b,而实际想匹配的是字面量 a+b,不是正则含义的“a 后跟一个或多个 b”。这时候不转义就出错,转义又得自己模拟正则逻辑——不如直接上 preg_replace

防止 XSS 的关键一步:输出前必须过滤

高亮后的内容含 标签,如果原始文本来自用户输入(比如数据库读出的评论),直接 echo 会有 XSS 风险。不能只依赖高亮函数做防护。

正确做法:

  • 先用 htmlspecialchars($text, ENT_QUOTES, 'UTF-8') 对原文转义
  • 再对转义后的字符串执行高亮(此时 < 变成 <,不会被解析为标签)
  • 最后用 str_replace<mark></mark> 换回真实标签——仅限这组标签,其他仍保持转义

漏掉这步,攻击者在搜索框输入 就可能触发脚本执行。

中文搜索高亮要注意全角/半角和空格

中文用户常混用全角空格( )、半角空格( )、甚至不间断空格( )。如果关键词含空格,而原文用的是全角空格,preg_replace 默认不匹配。

解决方法:

  • 预处理关键词和原文:用 str_replace([' ', "\xc2\xa0"], ' ', $str) 统一为空格(\xc2\xa0 是 UTF-8 下   的字节)
  • 或改用 mb_ereg_replace(需开启 mbstring)配合 u 修饰符,但性能略低,且 PHP 8.2+ 已废弃 mb_ereg_* 系列
  • 更稳妥的是前端限制输入:用 JS 过滤掉全角符号,或提示“请使用英文标点与空格”

真正难处理的是拼音缩写、同音词、繁简混输——那已超出高亮范畴,得上分词或 NLP 库了。

以上就是《PHP搜索关键词高亮代码示例》的详细内容,更多关于的资料请关注golang学习网公众号!

前往漫画官网入口并下载 ➜
最新阅读
更多>
课程推荐
更多>
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    立即学习 543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    立即学习 516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    立即学习 500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    立即学习 487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    立即学习 485次学习