免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 797 | 回复: 0
打印 上一主题 下一主题

利用Yahoo! Search API开发自已的搜索引擎-php版 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-10-16 21:14 |只看该作者 |倒序浏览
美国东部时间3月1日,雅虎公司联合创始人之一的杨致远将宣布公司的搜索网络将进入Web服务。雅虎公司在www.developer.yahoo.com网站建立了Yahoo Search Developer Network,公司计划在此纽约举行的搜索引擎战略大会(Search Engine Strategies Conference)上推出这一计划。该网络将允许开发者在雅虎搜索之上建立新的应用程序,其中包括图像、视频、新闻以及地区搜索等内容。想要使用这项服务的会员必须先去http://api.search.yahoo.com/webservices/register_application  申请一个自已的ID号,注:每个ID号每天只能搜索5000次。
    下面我们看一下,如何用PHP脚本调用Yahoo! Search API实现搜索的效果,全部脚本如下:
CODE:
[复制到剪切板]
// Yahoo Web Services PHP Example Code
// Rasmus Lerdorf
// www.knowsky.com
$appid = 'YahooDemo';
// 在这输入你申请的ID号
$service = array('image'=>'http://api.search.yahoo.com/ImageSearchService/V1/imageSearch',
                 
'local'=>'http://api.local.yahoo.com/LocalSearchService/V1/localSearch',
                 
'news'=>'http://api.search.yahoo.com/NewsSearchService/V1/newsSearch',
                 
'video'=>'http://api.search.yahoo.com/VideoSearchService/V1/videoSearch',
                 
'web'=>'http://api.search.yahoo.com/WebSearchService/V1/webSearch');
?>
>
PHP Yahoo Web Service Example Code>
>
>
Search Term: />
Zip Code:  (for local search)/>
/>
>
$val) {
    if(!empty(
$_REQUEST['type']) && $name == $_REQUEST['type'])
      echo
"$namen";
    else echo
"$namen";
} ?>
>
>
php
function done() {?>
>
exit;
}
if(empty(
$_REQUEST['query']) || !in_array($_REQUEST['type'],array_keys($service))) done();
// Ok, here we go, we have the query and the type of search is valid
// First build the query
$q = '?query='.rawurlencode($_REQUEST['query']);
if(!empty(
$_REQUEST['zip'])) $q.="&zip=".$_REQUEST['zip'];
if(!empty(
$_REQUEST['start'])) $q.="&start=".$_REQUEST['start'];
$q .= "&appid=$appid";
// Then send it to the appropriate service
$xml = file_get_contents($service[$_REQUEST['type']].$q);
// Parse the XML and check it for errors
if (!$dom = domxml_open_mem($xml,DOMXML_LOAD_PARSING,$error)) {
  echo
"XML parse errorn";
  foreach (
$error as $errorline) {
  
/* For production use this should obviously be logged to a file instead */
   
echo $errorline['errormessage']."
n"
;
    echo
" Node  : " . $errorline['nodename'] . "
n"
;
    echo
" Line  : " . $errorline['line'] . "
n"
;
    echo
" Column : " . $errorline['col'] . "
n"
;
  }
  
done();
}
// Now traverse the DOM with this function
// It is basically a generic parser that turns limited XML into a PHP array
// with only a couple of hardcoded tags which are common across all the
// result xml from the web services
function xml_to_result($dom) {
  
$root = $dom->document_element();
  
$res['totalResultsAvailable'] = $root->get_attribute('totalResultsAvailable');
  
$res['totalResultsReturned'] = $root->get_attribute('totalResultsReturned');
  
$res['firstResultPosition'] = $root->get_attribute('firstResultPosition');
  
$node = $root->first_child();
  
$i = 0;
  while(
$node) {
    switch(
$node->tagname) {
      case
'Result':
        
$subnode = $node->first_child();
        while(
$subnode) {
         
$subnodes = $subnode->child_nodes();
          if(!empty(
$subnodes)) foreach($subnodes as $k=>$n) {
            if(empty(
$n->tagname)) $res[$i][$subnode->tagname] = trim($n->get_content());
            else
$res[$i][$subnode->tagname][$n->tagname]=trim($n->get_content());
          }
         
$subnode = $subnode->next_sibling();
        }
        break;
      default:
        
$res[$node->tagname] = trim($node->get_content());
        
$i--;
        break;
    }
   
$i++;
   
$node = $node->next_sibling();
  }   
  return
$res;
}
$res = xml_to_result($dom);
// Ok, now that we have the results in an easy to use format,
// display them.  It's quite ugly because I am using a single
// display loop to display every type and I don't really understand HTML
$first = $res['firstResultPosition'];
$last = $first + $res['totalResultsReturned']-1;
echo
"Matched ${res[totalResultsAvailable]}, showing $first to $lastn";
if(!empty(
$res['ResultSetMapUrl'])) {
  echo
"Result Set Map: ${res[ResultSetMapUrl]}n";
}
for(
$i=0; $i++) {
  foreach(
$res[$i] as $key=>$value) {
    switch(
$key) {
      case
'Thumbnail':
        echo
"n";
        break;
      case
'Cache':
        echo
"Cache: ${value} [${value[Size]}]
n"
;
        break;
      case
'PublishDate':
        echo
"$key: ".strftime('%X %x',$value);
        break;
      default:
        if(
stristr($key,'url')) echo "$value
n"
;
        else echo
"$key: $value
"
;
        break;
    }
  }
  echo
"n";
}
// Create Previous/Next Page links
if($start > 1)
  echo
'.
                       
'?query='.rawurlencode($_REQUEST['query']).
                        
'&zip='.rawurlencode($_REQUEST['zip']).
                        
'&type='.rawurlencode($_REQUEST['type']).
                       
'&start='.($start-10).'">   ';
if(
$last ])
  echo
'.
                       
'?query='.rawurlencode($_REQUEST['query']).
                        
'&zip='.rawurlencode($_REQUEST['zip']).
                        
'&type='.rawurlencode($_REQUEST['type']).
                       
'&start='.($last+1).'">Next Page->';
done();
?>



本文来自ChinaUnix博客,如果查看原文请点:[url]http://blog.chinaunix.net/u/24375/showart_185777.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP