天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

利用Yahoo! Search API開(kāi)發(fā)自已的搜索引擎-php版

    美國(guó)東部時(shí)間3月1日,雅虎公司聯(lián)合創(chuàng)始人之一的楊致遠(yuǎn)將宣布公司的搜索網(wǎng)絡(luò)將進(jìn)入Web服務(wù)。雅虎公司在www.developer.yahoo.com網(wǎng)站建立了Yahoo Search Developer NETwork,公司計(jì)劃在此紐約舉行的搜索引擎戰(zhàn)略大會(huì)(Search Engine Strategies Conference)上推出這一計(jì)劃。該網(wǎng)絡(luò)將允許開(kāi)發(fā)者在雅虎搜索之上建立新的應(yīng)用程序,其中包括圖像、視頻、新聞以及地區(qū)搜索等內(nèi)容。想要使用這項(xiàng)服務(wù)的會(huì)員必須先去http://api.search.yahoo.com/webservices/register_application  申請(qǐng)一個(gè)自已的ID號(hào),注:每個(gè)ID號(hào)每天只能搜索5000次。

    下面我們看一下,如何用php腳本調(diào)用Yahoo! Search API實(shí)現(xiàn)搜索的效果,全部腳本如下:
  

<?php
// Yahoo Web Services php Example Code
// Rasmus Lerdorf
// www.knowsky.com

$appid = 'YahooDemo';
// 在這輸入你申請(qǐng)的ID號(hào)

$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');
?>
<html>
<head><title>php Yahoo Web Service Example Code</title></head>
<body>
<form action="YahooSearchExample.php" method="GET">
Search Term: <input type="text" name="query" /><br />
Zip Code: <input type="text" name="zip" /> (for local search)<br />
<input type="submit" value=" Go! " />
<select name="type">
<?php foreach($service as $name => $val) {
    if(!empty($_REQUEST['type']) && $name == $_REQUEST['type'])
      echo "<option SELECTED>$name</option>/n";
    else echo "<option>$name</option>/n";
} ?>
</select>
</form>
<?php
function done() {?>
</body></html>
<?php
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 error/n";
  foreach ($error as $errorline) {
  /* For production use this should obviously be logged to a file instead */
    echo $errorline['errormessage']."<br />/n";
    echo " Node  : " . $errorline['nodename'] . "<br />/n";
    echo " Line  : " . $errorline['line'] . "<br />/n";
    echo " Column : " . $errorline['col'] . "<br />/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 "<p>Matched ${res[totalResultsAvailable]}, showing $first to $last</p>/n";
if(!empty($res['ResultSetMapUrl'])) {
  echo "<p>Result Set Map: <a href=/"${res[ResultSetMapUrl]}/">${res[ResultSetMapUrl]}</a></p>/n";
}
for($i=0; $i<$res['totalResultsReturned']; $i++) {
  foreach($res[$i] as $key=>$value) {
    switch($key) {
      case 'Thumbnail':
        echo "<img src=/"${value[Url]}/" height=/"${value[Height]}/" width=/"${value[Width]}/" />/n";
        break;
      case 'Cache':
        echo "Cache: <a href=/"${value[Url]}/">${value[Url]}</a> [${value[Size]}]<br />/n";
        break;
      case 'PublishDate':
        echo "<b>$key:</b> ".strftime('%X %x',$value);
        break;
      default:
        if(stristr($key,'url')) echo "<a href=/"$value/">$value</a><br />/n";
        else echo "<b>$key:</b> $value<br />";
        break;
    }
  }
  echo "<hr />/n";
}

// Create Previous/Next Page links
if($start > 1)
  echo '<a href="/YahooSearchExample.php'.
                       '?query='.rawurlencode($_REQUEST['query']).
                         '&zip='.rawurlencode($_REQUEST['zip']).
                        '&type='.rawurlencode($_REQUEST['type']).
                       '&start='.($start-10).'"><-Previous Page</a>   ';
if($last < $res['totalResultsAvailable'])
  echo '<a href="/YahooSearchExample.php'.
                       '?query='.rawurlencode($_REQUEST['query']).
                         '&zip='.rawurlencode($_REQUEST['zip']).
                        '&type='.rawurlencode($_REQUEST['type']).
                       '&start='.($last+1).'">Next Page-></a>';
done();
?>

有興趣的朋友還可以看一下由[動(dòng)態(tài)網(wǎng)站制作指南]所制作的ASP版本:http://www.knowsky.com/yahoo/

php技術(shù)利用Yahoo! Search API開(kāi)發(fā)自已的搜索引擎-php版,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 97碰成视频免费 | 超碰免费视频caopoom9 | videos gratis欧美另类 | 999人在线精品播放视频 | 久久香蕉国产线看观看首页 | 亚洲AV久久无码精品九号 | free性中国hd护士高清 | 人妻无码AV中文系统久久免费 | 国产精品99久久久久久AV色戒 | 成人免费看片又大又黄 | 亚洲 欧美 中文 日韩 视频 | 日本亚洲中文字幕无码区 | 精品国产在线手机在线 | 国产精品18久久久久久白浆. | 乌克兰美女x?x?y?y | 国内精品免费视频精选在线观看 | 麻豆一区二区免费播放网站 | 亚洲男人天堂2018av | 中文字幕一区在线观看视频 | 国产二级一片内射视频播放 | 色就色 综合偷拍区欧美 | 久久在精品线影院 | 成人公开免费视频 | 世界上第一个得抑郁症的人是谁 | wwwwxxxx欧美| 狠狠婷婷综合久久久久久 | 国产欧美一区二区三区免费 | 艺术片 快播 | 青草国产在线视频免费 | 杨幂视频在线观看1分30秒 | z00兽200俄罗斯| 寂寞夜晚视频高清观看免费 | 仓井空torrent | 99久久免费国产精品特黄 | 在线视频久久只有精品第一日韩 | 99久久国产综合色 | 在教室做啊好大用力 | 国产综合无码一区二区色蜜蜜 | 口内射精颜射极品合集 | 国产午夜精品不卡观看 | 中文字幕在线久热精品 |