您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“如何為網(wǎng)站構(gòu)建自己的Aleax查詢(xún)服務(wù)”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“如何為網(wǎng)站構(gòu)建自己的Aleax查詢(xún)服務(wù)”這篇文章吧。
1. Alexa介紹
Alexa (http://www.alexa.com/)是一家發(fā)布世界網(wǎng)站排名的網(wǎng)站,以搜索引擎起家的Alexa創(chuàng)建于1996年4月(美國(guó)),目的是讓互聯(lián)網(wǎng)網(wǎng)友在分享虛擬世界資源的同時(shí),更多地參與互聯(lián)網(wǎng)資源的組織。Alexa每天在網(wǎng)上搜集超過(guò)1TB的信息,不僅給出多達(dá)幾十億的網(wǎng)址鏈接,而且為其中的每一個(gè)網(wǎng)站進(jìn)行了排名??梢哉f(shuō),Alexa是當(dāng)前擁有URL數(shù)量最龐大,排名信息發(fā)布最詳盡的網(wǎng)站。
1999年,Alexa被美國(guó)電子商務(wù)旗艦企業(yè)“亞馬遜”收購(gòu),成為后者的全資子公司。2002年春,Alexa放棄了自己的搜索引擎,轉(zhuǎn)而與Google合作。
Alexa提供了網(wǎng)站流量統(tǒng)計(jì)的服務(wù),對(duì)全球有域名的網(wǎng)站進(jìn)行流量記錄。也就是說(shuō),只要你申請(qǐng)了域名,在Alexa中就可以查詢(xún)到你的網(wǎng)站的排名。Alexa的網(wǎng)站排名是按照每個(gè)特定網(wǎng)站的被瀏覽率進(jìn)行排名的。瀏覽率越大,排名越靠前。
通常情況,如果你的域名剛剛注冊(cè),排名在1千萬(wàn)以上;接下來(lái),你每天都經(jīng)心運(yùn)營(yíng)網(wǎng)站,小有起色時(shí),排名會(huì)進(jìn)入前1百萬(wàn);然后,你繼續(xù)發(fā)布優(yōu)質(zhì)內(nèi)容,堅(jiān)持了一段時(shí)間,排名會(huì)升至前50萬(wàn);當(dāng)你的網(wǎng)站在某一領(lǐng)域小有名氣時(shí),排名可以到達(dá)10萬(wàn),如粉絲日志122616(2015-10-25),這時(shí)就會(huì)有廣告主愿意來(lái)投放廣告了;如果你做的是以盈利為目的的網(wǎng)站,那么你需要再加油,進(jìn)入到前1萬(wàn),這個(gè)時(shí)候你的流量已經(jīng)可以為你帶來(lái)生意了;如果能做的更好,排名進(jìn)入前2000,像雪球排名到2109(2015-10-25),那么你將會(huì)有一個(gè)很高的估值了;如果能趕上一個(gè)天大的機(jī)遇,你的網(wǎng)站排名到了前100,那么你的網(wǎng)站將給你帶來(lái)上市公司的價(jià)值,如京東105(2015-10-25);如果你是天才型的CEO,網(wǎng)站進(jìn)了前10名,那么你將會(huì)成為一個(gè)產(chǎn)業(yè)的***,甚至是某個(gè)區(qū)域的首富,如百度4(2015-10-25)。
站長(zhǎng)們,加油!
2. 用Node開(kāi)發(fā)Alexa服務(wù)
2.1 Alexa開(kāi)放API
Alexa網(wǎng)站排名被業(yè)界普通的認(rèn)可,排名數(shù)據(jù)會(huì)經(jīng)常地被引用,每次都在網(wǎng)站上查詢(xún)就會(huì)顯得不方便。Amazon提供的Alexa的API,讓開(kāi)發(fā)者可以構(gòu)建自己的Alexa查詢(xún)的應(yīng)用。
Alexa有2個(gè)主要的數(shù)據(jù)API服務(wù)。
• Alexa Web Information Service,查詢(xún)單個(gè)網(wǎng)站的排名信息
• Alexa Top Sites,查詢(xún)網(wǎng)站的綜合排名
通常情況,只需要調(diào)用UrlInfo數(shù)據(jù)接口,就可以獲得網(wǎng)站的流量數(shù)據(jù)了。當(dāng)然,這個(gè)接口的定義,并不像我之前想象的那么好用,而且開(kāi)放出來(lái)的數(shù)據(jù)有限。
UrlInfo接口的API,如下圖所示。
官方提供了多語(yǔ)言的SDK工具包,我覺(jué)得還是Node.js最方便。我構(gòu)建的一個(gè)Alexa數(shù)據(jù)查詢(xún)服務(wù),http://fens.me/alexa
2.2 創(chuàng)建AWS的API密鑰
我們?cè)谑褂肁WS的API之前,需要先創(chuàng)建密鑰,類(lèi)似于OAuth3的訪問(wèn)的機(jī)制。
1. 注冊(cè)AWS賬號(hào),請(qǐng)大家自己完成。注冊(cè)
2. 進(jìn)入AWS賬號(hào)管理控制臺(tái),控制臺(tái)
3. 從控制臺(tái)選擇“安全證書(shū)”
4. 創(chuàng)建訪問(wèn)密鑰(訪問(wèn)密鑰 ID 和私有訪問(wèn)密鑰)
我們一會(huì)寫(xiě)程序的時(shí)候,需要輸入創(chuàng)建的訪問(wèn)密鑰 ID 和私有訪問(wèn)密鑰。
2.3 用Node開(kāi)發(fā)Alexa服務(wù)
接下來(lái),介紹用Node構(gòu)建一個(gè)Alexa的項(xiàng)目。
我的系統(tǒng)環(huán)境
• Win10 64bit
• Node v0.12.3
• NPM 2.9.1
創(chuàng)建項(xiàng)目
~ D:\workspace\nodejs>mkdir nodejs-alexa && cd nodejs-alexa
新建Node項(xiàng)目配置文件:package.json
~ vi package.json { "name": "alexa-demo", "version": "0.0.1", "description": "alexa web demo", "license": "MIT", "dependencies": { "awis": "0.0.8" } }
安裝awis包
~ D:\workspace\nodejs\nodejs-alexa>npm install npm WARN package.json alexa-demo@0.0.1 No repository field. npm WARN package.json alexa-demo@0.0.1 No README data alexarank@0.1.1 node_modules\alexarank ├── xml2js@0.4.13 (sax@1.1.4, xmlbuilder@3.1.0) └── request@2.30.0 (forever-agent@0.5.2, aws-sign2@0.5.0, qs@0.6.6, tunnel-agent@0.3.0, oauth-sign@0.3.0, json-stringify-safe@5.0.1, mime@1.2.11, node-uuid@1.4.3, tough-cookie@0.9.15, form-data@0.1.4, hawk@1.0.0, http-signature@0.10.1) awis@0.0.8 node_modules\awis ├── xml2js@0.4.13 (sax@1.1.4, xmlbuilder@3.1.0) ├── lodash@3.10.1 └── request@2.65.0 (aws-sign2@0.6.0, forever-agent@0.6.1, caseless@0.11.0, stringstream@0.0.4, oauth-sign@0.8.0, tunnel-agent@0.4.1, isstream@0.1.2, json-stringify-safe@5.0.1, extend@3.0.0, node-uuid@1.4.3, qs@5.2.0, tough-cookie@2.2.0, combined-stream@1.0.5, mime-types@2.1.7, form-data@1.0.0-rc3, http-signature@0.11.0, hawk@3.1.0, bl@1.0.0, har-validator@2.0.2)
新建文件alexa.js,調(diào)用AWS Alexa網(wǎng)站排名API。
~ vi alexa.js // 定義AWS密鑰 var key = 'xxxxxxxxxxxxxxx'; var sercet = 'xxxxxxxxxxxxxxx'; // 創(chuàng)建awis實(shí)例化對(duì)象 var awis = require('awis'); var client = awis({ key: key, secret: sercet }); // 調(diào)用UrlInfo接口 console.log("=============UrlInfo================="); client({ 'Action': 'UrlInfo', //UrlInfo接口 'Url': 'fens.me', //查詢(xún)的網(wǎng)站 'ResponseGroup': 'TrafficData,ContentData' //需要的數(shù)據(jù)組 }, function (err, data) { if(err) console.log(err); console.log(data); });
運(yùn)行程序node alexa.js
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============UrlInfo================= { contentData: { dataUrl: 'fens.me', siteData: { title: '粉絲日志', description: '跨界的IT博客|Hadoop家族, R, RHadoop, Nodejs, AngularJS, NoSQL, IT金融' }, speed: { medianLoadTime: '982', percentile: '70' }, adultContent: '', language: '', linksInCount: '198', keywords: '', ownedDomains: '' }, trafficData: { dataUrl: 'fens.me', rank: '122616', usageStatistics: { usageStatistic: [Object] }, contributingSubdomains: { contributingSubdomain: [Object] } } }
簡(jiǎn)簡(jiǎn)單單地幾行代碼,都獲得了Alexa的排名信息。后臺(tái)打印時(shí)Object沒(méi)有轉(zhuǎn)到成對(duì)象,我做了一個(gè)服務(wù),可以通過(guò)HTTP輸出查看完整的返回。http://api.fens.me/alexa/fens.me
我們查檢一下awis包的源代碼可以發(fā)現(xiàn),其實(shí)AWS Alexa服務(wù)返回是XML,awis的自動(dòng)幫我們做了JSON的轉(zhuǎn)型處理,如果想查看原始的返回值,可以修改awis包中index.js文件parse()函數(shù)。
function parse(xml, req, cb) { console.log(xml); //打印 .... }
運(yùn)行程序
D:\workspace\nodejs\nodejs-alexa>node alexa.js =============UrlInfo================= <?xml version="1.0"?> <aws:UrlInfoResponse xmlns:aws="http://alexa.amazonaws.com/doc/2005-10-05/"><aws:Response xmlns:aws="http://awis.amazonaws.com/doc/2005-07-11"><aws:OperationRequest><aws:RequestId>1e7d8406-4b62-3460-27fb-325fc3dc3e85</aws:RequestId></aws:OperationRequest><aws:UrlInfoResult><aws:Alexa> <aws:ContentData> <aws:DataUrl type="canonical">fens.me</aws:DataUrl> <aws:SiteData> <aws:Title>粉絲日志</aws:Title> <aws:Description>跨界的IT博客|Hadoop家族, R, RHadoop, Nodejs, AngularJS, NoSQL, IT金融</aws:Description> </aws:SiteData> <aws:Speed> <aws:MedianLoadTime>982</aws:MedianLoadTime> <aws:Percentile>70</aws:Percentile> </aws:Speed> <aws:AdultContent/> <aws:Language/> <aws:LinksInCount>198</aws:LinksInCount> <aws:Keywords/> <aws:OwnedDomains/> </aws:ContentData> <aws:TrafficData> <aws:DataUrl type="canonical">fens.me</aws:DataUrl> <aws:Rank>122616</aws:Rank> <aws:UsageStatistics> <aws:UsageStatistic> <aws:TimeRange> <aws:Months>3</aws:Months> </aws:TimeRange> <aws:Rank> <aws:Value>122616</aws:Value> <aws:Delta>+28849</aws:Delta> </aws:Rank> <aws:Reach> <aws:Rank> <aws:Value>110056</aws:Value> <aws:Delta>+25785</aws:Delta> </aws:Rank> <aws:PerMillion> <aws:Value>12.5</aws:Value> <aws:Delta>-24.68%</aws:Delta> </aws:PerMillion> </aws:Reach> <aws:PageViews> <aws:PerMillion> <aws:Value>0.27</aws:Value> <aws:Delta>-24.84%</aws:Delta> </aws:PerMillion> <aws:Rank> <aws:Value>194189</aws:Value> <aws:Delta>43945</aws:Delta> </aws:Rank> <aws:PerUser> <aws:Value>1.9</aws:Value> <aws:Delta>0%</aws:Delta> </aws:PerUser> </aws:PageViews> </aws:UsageStatistic> <aws:UsageStatistic> <aws:TimeRange> <aws:Months>1</aws:Months> </aws:TimeRange> <aws:Rank> <aws:Value>102621</aws:Value> <aws:Delta>-30257</aws:Delta> </aws:Rank> <aws:Reach> <aws:Rank> <aws:Value>95663</aws:Value> <aws:Delta>-20326</aws:Delta> </aws:Rank> <aws:PerMillion> <aws:Value>15</aws:Value> <aws:Delta>+20%</aws:Delta> </aws:PerMillion> </aws:Reach> <aws:PageViews> <aws:PerMillion> <aws:Value>0.37</aws:Value> <aws:Delta>+60%</aws:Delta> </aws:PerMillion> <aws:Rank> <aws:Value>153976</aws:Value> <aws:Delta>-69981</aws:Delta> </aws:Rank> <aws:PerUser> <aws:Value>2.2</aws:Value> <aws:Delta>+30%</aws:Delta> </aws:PerUser> </aws:PageViews> </aws:UsageStatistic> <aws:UsageStatistic> <aws:TimeRange> <aws:Days>7</aws:Days> </aws:TimeRange> <aws:Rank> <aws:Value>114709</aws:Value> <aws:Delta>+32390</aws:Delta> </aws:Rank> <aws:Reach> <aws:Rank> <aws:Value>103552</aws:Value> <aws:Delta>+27312</aws:Delta> </aws:Rank> <aws:PerMillion> <aws:Value>14</aws:Value> <aws:Delta>-28.59%</aws:Delta> </aws:PerMillion> </aws:Reach> <aws:PageViews> <aws:PerMillion> <aws:Value>0.3</aws:Value> <aws:Delta>-37.28%</aws:Delta> </aws:PerMillion> <aws:Rank> <aws:Value>188124</aws:Value> <aws:Delta>58655</aws:Delta> </aws:Rank> <aws:PerUser> <aws:Value>2.0</aws:Value> <aws:Delta>-12.11%</aws:Delta> </aws:PerUser> </aws:PageViews> </aws:UsageStatistic> <aws:UsageStatistic> <aws:TimeRange> <aws:Days>1</aws:Days> </aws:TimeRange> <aws:Rank> <aws:Value>74860</aws:Value> <aws:Delta>-93163</aws:Delta> </aws:Rank> <aws:Reach> <aws:Rank> <aws:Value>70563</aws:Value> <aws:Delta>-54001</aws:Delta> </aws:Rank> <aws:PerMillion> <aws:Value>20</aws:Value> <aws:Delta>+60%</aws:Delta> </aws:PerMillion> </aws:Reach> <aws:PageViews> <aws:PerMillion> <aws:Value>0.6</aws:Value> <aws:Delta>+300%</aws:Delta> </aws:PerMillion> <aws:Rank> <aws:Value>111541</aws:Value> <aws:Delta>-210757</aws:Delta> </aws:Rank> <aws:PerUser> <aws:Value>2</aws:Value> <aws:Delta>+100%</aws:Delta> </aws:PerUser> </aws:PageViews> </aws:UsageStatistic> </aws:UsageStatistics> <aws:ContributingSubdomains> <aws:ContributingSubdomain> <aws:DataUrl>blog.fens.me</aws:DataUrl> <aws:TimeRange> <aws:Months>1</aws:Months> </aws:TimeRange> <aws:Reach> <aws:Percentage>99.19%</aws:Percentage> </aws:Reach> <aws:PageViews> <aws:Percentage>99.64%</aws:Percentage> <aws:PerUser>2.2</aws:PerUser> </aws:PageViews> </aws:ContributingSubdomain> <aws:ContributingSubdomain> <aws:DataUrl>OTHER</aws:DataUrl> <aws:TimeRange> <aws:Months>1</aws:Months> </aws:TimeRange> <aws:Reach> <aws:Percentage>0</aws:Percentage> </aws:Reach> <aws:PageViews> <aws:Percentage>0.36%</aws:Percentage> <aws:PerUser>0</aws:PerUser> </aws:PageViews> </aws:ContributingSubdomain> </aws:ContributingSubdomains> </aws:TrafficData> </aws:Alexa></aws:UrlInfoResult><aws:ResponseStatus xmlns:aws="http://alexa.amazonaws.com/doc/2005-10-05/"><aws:StatusCode>Success</aws:StatusCode></aws:ResponseStatus></aws:Response></aws:UrlInfoResponse>
除了UrlInfo接口還有幾個(gè)接口可以使用。
TrafficHistory接口
console.log("=============TrafficHistory================="); client({ 'Action': 'TrafficHistory', 'Url': 'fens.me', 'ResponseGroup': 'History' }, function (err, res) { if(err) console.log(err); console.log(res.trafficHistory); console.log(res.trafficHistory.range); console.log(res.trafficHistory.site); console.log(res.trafficHistory.start); console.log(res.trafficHistory.historicalData); console.log(res.trafficHistory.historicalData.data); console.log(res.trafficHistory.historicalData.data.length); res.trafficHistory.historicalData.data.forEach(function (item) { console.log(item.date); console.log(item.pageViews); console.log(item.rank); console.log(item.reach); }); });
運(yùn)行程序
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============TrafficHistory================= { range: '31', site: 'fens.me', start: '2015-09-23', historicalData: { data: [ [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object] ] } } // 省略輸出
SitesLinkingIn接口
console.log("=============SitesLinkingIn================="); client({ 'Action': 'SitesLinkingIn', 'Url': 'fens.me', 'ResponseGroup': 'SitesLinkingIn' }, function (err, data) { if(err) console.log(err); console.log(data); });
運(yùn)行程序
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============SitesLinkingIn================= { sitesLinkingIn: { site: [ [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object], [Object] ] } }
CategoryBrowse接口
console.log("=============CategoryBrowse================="); client({ 'Action': 'CategoryBrowse', 'Url': 'fens.me', 'Path': 'Top/china', 'ResponseGroup': 'LanguageCategories' }, function (err, data) { if(err) console.log(err); console.log(data); });
運(yùn)行程序
~ D:\workspace\nodejs\nodejs-alexa>node alexa.js =============CategoryBrowse================= { categoryBrowse: { languageCategories: '' } }
以上是“如何為網(wǎng)站構(gòu)建自己的Aleax查詢(xún)服務(wù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。