PHP自定义函数获取搜索引擎来源关键字的方法
来源: 阅读:1009 次 日期:2016-08-15 16:02:19
温馨提示: 小编为您整理了“PHP自定义函数获取搜索引擎来源关键字的方法”,方便广大网友查阅!

本文实例讲述了PHP自定义函数获取搜索引擎来源关键字的方法。分享给大家供大家参考,具体如下:

获取搜索引擎来源关键字的函数:

function getKeywords() {

  // 搜索引擎关键字映射

  static $host_keyword_map = array(

      'www.baidu.com' => 'wd',

      'v.baidu.com' => 'word',

      'image.baidu.com' => 'word',

      'news.baidu.com' => 'word',

      'www.so.com' => 'q',

      'video.so.com' => 'q',

      'image.so.com' => 'q',

      'news.so.com' => 'q',

      'www.sogou.com' => 'query',

      'pic.sogou.com' => 'query',

      'v.sogou.com' => 'query',

  );

  // 检查来源是否搜索引擎

  if (!isset($_SERVER['HTTP_REFERER'])) {

    return '';

  }

  $urls = parse_url($_SERVER['HTTP_REFERER']);

  if (!array_key_exists($urls['host'], $host_keyword_map)) {

    return '';

  }

  $key = $host_keyword_map[$urls['host']];

  // 检查关键字参数是否存在

  if (!isset($urls['query'])) {

    return '';

  }

  $params = array();

  parse_str($urls['query'], $params);

  if (!isset($params[$key])) {

    return '';

  }

  $keywords = $params[$key];

  // 检查编码

  $encoding = mb_detect_encoding($keywords, 'utf-8,gbk');

  if ($encoding != 'utf-8') {

    $keywords = iconv($encoding, 'utf-8', $keywords);

  }

  return $keywords;

}

函数测试:

<?php

header("Content-Type: text/html; charset=utf-8");

$referers = array(

    'http://www.baidu.com/s?cl=3&wd=%B9%E9%C0%B4&fr=vid1000',

    'http://www.baidu.com/s?tn=92506501_hao_pg&rtt=1&bsst=1&wd=%B9%E9%C0%B4',

    'http://www.baidu.com/link?url=ctBhF7AAau6LwE61pJOEH-ZhgUM7D3YHYMrm6xIXJlDQtMXCiea7gg49s90Q-Qh8wHD8Ano-dPNhUawBBNEEwEbtu8toMF5k1V7Xy850EtlpZyMcS0e_y-SCJp86iM6e&wd=%E5%BD%92%E6%9D%A5&tn=baidu&ie=utf-8&inputT=2980',

    'http://www.baidu.com/link?url=TIn9NR6fwiy6IwwkCcVF8HhHoxVUpHQsyj1YdlQPy2roXKTnSQS_3UxwvyjZ2JPkpxF8-diSoRCSpODUM_jq2K&wd=%E5%BD%92%E6%9D%A5&tn=baidu&ie=utf-8&input', 

    'http://news.baidu.com/ns?cl=2&rn=20&tn=news&word=%E5%BD%92%E6%9D%A5&ie=utf-8',

    'http://image.baidu.com/i?ct=503316480&z=&tn=baiduimagedetail&ipn=d&word=%E5%BD%92%E6%9D%A5&step_word=&ie=utf-8&in=17668&cl=2&lm=-1&st=&pn=6&rn=1&di=70447907090&ln=1994&fr=news&&fmq=1402285886106_R&ic=&s=&se=&sme=0&tab=&width=&height=&face=&is=&istype=&ist=&jit=&objurl=http%3A%2F%2Fpic31.nipic.com%2F20130713%2F1287761_225159187345_2.jpg',

    'http://v.baidu.com/v?ct=301989888&s=25&ie=utf-8&word=%E5%BD%92%E6%9D%A5',

    'http://www.so.com/s?ie=utf-8&shb=1&src=360sou_newhome&q=%E5%BD%92%E6%9D%A5',

    'http://video.so.com/v?q=%E5%BD%92%E6%9D%A5&src=tab_www',

    'http://image.so.com/v?q=%E5%BD%92%E6%9D%A5&src=tab_video&fromurl=http%3A%2F%2Fndent.oeeee.com%2Fhtml%2F201309%2F16%2F258899.html',

    'http://news.so.com/ns?q=%E5%BD%92%E6%9D%A5&src=tab_video',

    'http://www.sogou.com/web?query=%E5%BD%92%E6%9D%A5&_asf=www.sogou.com&_ast=1402284372&w=01019900&p=40040100&ie=utf8&sut=6558&sst0=1402284372272&lkt=0%2C0%2C0',

    'http://www.sogou.com/web?query=%E5%BD%92%E6%9D%A5&_asf=www.sogou.com&_ast=1402284372&w=01019900&p=40040100&ie=utf8&sut=6558&sst0=1402284372272&lkt=0%2C0%2C0',

    'http://pic.sogou.com/d?query=%B9%E9%C0%B4&mood=0&picformat=0&mode=1&di=0&w=03021800&dr=1&did=1',

    'http://v.sogou.com/v?query=%B9%E9%C0%B4&p=&w=',

    'http://www.baidu.com/s?aaa=bbb',

    'http://www.baidu.com/',

    'http://www.jb51.net/',

);

foreach ($referers as $r) {

  $_SERVER['HTTP_REFERER'] = $r;

  echo getKeywords(), "\n";

}

希望本文所述对大家PHP程序设计有所帮助。

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map