기사에 키워드와 링크를 추가하는 PHP 방법

WBOY
풀어 주다: 2016-07-25 09:11:03
원래의
1481명이 탐색했습니다.
  1. $keywordArray = array(
  2. array('进程', 'http://www.01happy.com/linux-ps-view-process/')
  3. ,array('守护进程', 'http://www.01happy.com/linux-python-daemon/')
  4. );
复制代码

二维数组排序可以使用内置函数usort,代码如下:

  1. usort($keywordArray, function($a, $b) {
  2. $al = strlen($a[0]);
  3. $bl = strlen($b[0]);
  4. if ($al == $bl)
  5. return 0;
  6. return ($al > $bl) ? -1 : 1;
  7. });
复制代码

提取出所有html标签

  1. preg_match_all('/]*>/', $content, $match);
  2. if (isset($match[0])) {
  3. $htmlTagArray = $match[0];
  4. }
复制代码

这边的正则就是将包着的内容都提取出来,笔者认为凡是需要将号当成内容显示的,都应当用转义字符<>来替换,对于一切包着的内容都可以认为是标签。事实上浏览器也是这么干的,很多在线的文本编辑器也会自动转义这些字符。

分割内容,保存到数组 $noTagContentArray = preg_split('/?[a-zA-Z] [^>]*>/', $content);

这边用的正则表达式和上面提取html标签用的正则一致。

循环分割的内容数组,替换关键词链接 这边的处理方式是先将关键词替换成md5值,再将md5值替换成带链接的关键词,之所以这么处理,是为了解决关键词之间包含的情况。另外,笔者曾经考虑将分割的内容数组implode成一个字符串,就不用循环替换了,但是担心implode之后的字符串在拼接处会形成关键词,所以就没这么处理。

组合提取的html标签和处理后的内容 这步就比较简单了,依次拼接就OK了。需要注意的是html标签数组会比分割的内容数组长度小1,所以在取标签时,要用isset来判断下。 以上内容经多次测试没有问题,如有疑问,欢迎进入本站QQ群:161228069 沟通交流。



원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿