Rumah > php教程 > php手册 > php实现专业获取网站SEO信息类实例,seo实例

php实现专业获取网站SEO信息类实例,seo实例

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Lepaskan: 2016-06-13 09:07:56
asal
1689 orang telah melayarinya

php实现专业获取网站SEO信息类实例,seo实例

本文实例讲述了php实现专业获取网站SEO信息类。分享给大家供大家参考。具体如下:

这个seo类的功能包括:
- 检查指定的网站响应
- 获取从该网站主页的语言和其他meta标签数据的
- 获取网站的导入链接,从Alexa的流量排名
- 获取网站的导入链接,由谷歌索引的网页数量
- 获取网站的信任,从WOT排名。
- 获取,因为它是第一个注册的网站域名年龄
- 获取的Twitter网站页面的数量
- 获取的Facebook链接的网站页面
- 获取网站谷歌网页速度等级
- 获取网站的谷歌网页排名

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212

213

214

215

216

217

218

219

220

221

222

223

224

225

226

227

228

229

230

231

232

233

234

235

236

237

238

239

240

241

242

243

244

245

246

247

248

249

250

251

252

253

254

255

256

257

258

259

260

261

262

263

264

265

266

267

268

269

270

271

272

273

274

275

276

277

278

279

280

281

282

283

284

285

286

287

288

289

290

291

292

293

294

295

296

297

298

299

300

301

302

303

304

305

306

307

308

309

310

311

312

313

314

315

316

317

318

319

320

321

322

323

324

325

326

<&#63;php

/**

 *

 * SEO report for different metrics

 *

 * @category SEO

 * @author Chema <chema@garridodiaz.com>

 * @copyright (c) 2009-2012 Open Classifieds Team

 * @license GPL v3

 * Based on seo report script http://www.phpeasycode.com && PHP class SEOstats

 *

 */

class seoreport{

  /**

   *

   * check if a url is online/alive

   * @param string $url

   * @return bool

   */

  public static function is_alive($url)

  {

    $ch = curl_init();

    curl_setopt($ch, CURLOPT_URL, $url);

    curl_setopt($ch, CURLOPT_BINARYTRANSFER, 1);

    curl_setopt($ch, CURLOPT_HEADERFUNCTION, 'curlHeaderCallback');

    curl_setopt($ch, CURLOPT_FAILONERROR, 1);

    curl_exec ($ch);

    $int_return_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);

    curl_close ($ch);

    if ($int_return_code != 200 && $int_return_code != 302 && $int_return_code != 304)

    {

      return FALSE;

    }

    else return TRUE;

  }

  /**

   * HTTP GET request with curl.

   *

   * @param string $url String, containing the URL to curl.

   * @return string Returns string, containing the curl result.

   *

   */

  protected static function get_html($url)

  {

    $ch = curl_init($url);

    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);

    curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,5);

    curl_setopt($ch,CURLOPT_FOLLOWLOCATION,1);

    curl_setopt($ch,CURLOPT_MAXREDIRS,2);

    if(strtolower(parse_url($url, PHP_URL_SCHEME)) == 'https')

    {

      curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,1);

      curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,1);

    }

    $str = curl_exec($ch);

    curl_close($ch);

    return ($str)&#63;$str:FALSE;

  }

  /**

   *

   * get the domain from any URL

   * @param string $url

   */

  public static function domain_name($url)

  {

    $nowww = ereg_replace('www\.','',$url);

    $domain = parse_url($nowww);

    if(!empty($domain["host"]))

      return $domain["host"];

    else

      return $domain["path"];

  }

  /**

   *

   * get the metas from a url and the language of the site

   * @param string $url

   * @return array

   */

  public static function meta_info($url)

  {

    //doesn't work at mediatemple

    /*$html = new DOMDocument();

    if(!$html->loadHtmlFile($url))

      return FALSE;*/

    if (!$html_content = self::get_html($url))

        return FALSE;

    $html = new DOMDocument();

    $html->loadHtml($html_content);

        

    $xpath = new DOMXPath( $html );

    $url_info = array();

    $langs = $xpath->query( '//html' );

    foreach ($langs as $lang)

    {

      $url_info['language'] = $lang->getAttribute('lang');

    }

    $metas = $xpath->query( '//meta' );

    foreach ($metas as $meta)

    {

      if ($meta->getAttribute('name'))

      {

        $url_info[$meta->getAttribute('name')] = $meta->getAttribute('content');

      }

    }

    return $url_info;

  }

  /**

   *

   * Alexa rank

   * @param string $url

   * @return integer

   */

  public static function alexa_rank($url)

  {

    $domain   = self::domain_name($url);

    $request   = "http://data.alexa.com/data&#63;cli=10&dat=s&url=" . $domain;

    $data     = self::get_html($request);

    preg_match('/<POPULARITY URL="(.*&#63;)" TEXT="([\d]+)"\/>/si', $data, $p);

    return ($l[2]) &#63; $l[2] : NULL;

  }

  /**

   *

   * Alexa inbounds link

   * @param string $url

   * @return integer

   */

  public static function alexa_links($url)

  {

    $domain   = self::domain_name($url);

    $request   = "http://data.alexa.com/data&#63;cli=10&dat=s&url=" . $domain;

    $data     = self::get_html($request);

    preg_match('/<LINKSIN NUM="([\d]+)"\/>/si', $data, $l);

    return ($l[1]) &#63; $l[1] : NULL;

  }

  /**

   * Returns total amount of results for any Google search,

   * requesting the deprecated Websearch API.

   *

   * @param    string    $query   String, containing the search query.

   * @return    integer          Returns a total count.

   */

  public static function google_pages($url)

  {

    //$query = self::domain_name($url);

    $url = 'http://ajax.googleapis.com/ajax/services/search/web&#63;v=1.0&rsz=1&q='.$url;

    $str = self::get_html($url);

    $data = json_decode($str);

    return (!isset($data->responseData->cursor->estimatedResultCount))

        &#63; '0'

        : intval($data->responseData->cursor->estimatedResultCount);

  }

  /**

   *

   * gets the inbounds links from a site

   * @param string $url

   * @param integer

   */

  public static function google_links($url)

  {

    $request   = "http://www.google.com/search&#63;q=" . urlencode("link:" . $url) . "&hl=en";

    $data     = self::get_html($request);

    preg_match('/<div id=resultStats>(About )&#63;([\d,]+) result/si', $data, $l);

    return ($l[2]) &#63; $l[2] : NULL;

  }

  /**

   *

   * web of trust rating

   * @param string $url

   * @reutn integer

   */

  public static function WOT_rating($url)

  {

    $domain = self::domain_name($url);

    $request = "http://api.mywot.com/0.4/public_query2&#63;target=" . $domain;

    $data   = self::get_html($request);

    preg_match_all('/<application name="(\d+)" r="(\d+)" c="(\d+)"\/>/si', $data, $regs);

    $trustworthiness = ($regs[2][0]) &#63; $regs[2][0] : NULL;

    return (is_numeric($trustworthiness))&#63; $trustworthiness:NULL;

  }

    

  /**

   *

   * how old is the domain&#63;

   * @param string $domain

   * @return integer unixtime

   */

  public static function domain_age($domain)

  {

    $request = "http://reports.internic.net/cgi/whois&#63;whois_nic=" . $domain . "&type=domain";

    $data   = self::get_html($request);

    preg_match('/Creation Date: ([a-z0-9-]+)/si', $data, $p);

    return (!$p[1])&#63;FALSE:strtotime($p[1]);

  }

  /**

   *

   * counts how many tweets about the url

   * @param string $url

   * @return integer

   */

  public static function tweet_count($url)

  {

    $url = urlencode($url);

    $twitterEndpoint = "http://urls.api.twitter.com/1/urls/count.json&#63;url=%s";

    $fileData = file_get_contents(sprintf($twitterEndpoint, $url));

    $json = json_decode($fileData, true);

    unset($fileData);        // free memory

    return (is_numeric($json['count']))&#63; $json['count']:NULL;

  }

  /**

   * Returns the total amount of Facebook Shares for a single page

   *

   * @link     https://graph.facebook.com/

   * @param     string   The URL to check.

   * @return    integer  Returns the total amount of Facebook

   */

  public static function facebook_shares($q)

  {

    //Execution and result of Json

    $str = self::get_html('http://graph.facebook.com/&#63;id='.urlencode($q));

    $data = json_decode($str);

    //Return only number of facebook shares

    $r = $data->shares;

    return ($r != NULL) &#63; $r : intval('0');

  }

  /**

   *

   * get the pagespeed rank over 100

   * @param string $url

   * @return integer

   */

  public static function page_speed($url)

  {

    $url = 'https://developers.google.com/_apps/pagespeed/run_pagespeed&#63;url='.$url.'&format=json';

    $str = self::get_html($url);

    $data = json_decode($str);

    return intval($data->results->score);

  }

  /**

   *

   * get google page rank

   * @param string $url

   * @return integer

   */

  public static function page_rank($url)

  {

     $query = "http://toolbarqueries.google.com/tbr&#63;client=navclient-auto&ch=".self::CheckHash(self::HashURL($url)). "&features=Rank&q=info:".$url."&num=100&filter=0";

      $data = self::get_html($query);//die(print_r($data));

    $pos  = strpos($data, "Rank_");

    if($pos === false)

    {

      return NULL;

    }

    else

    {

      $pagerank = substr($data, $pos + 9);

      return $pagerank;

    }

  }

  // functions for google pagerank

  /**

   * To calculate PR functions

   */

  public static function StrToNum($Str, $Check, $Magic)

  {

    $Int32Unit = 4294967296; // 2^32

    $length = strlen($Str);

    for ($i = 0; $i < $length; $i++) {

      $Check *= $Magic;

      //If the float is beyond the boundaries of integer (usually +/- 2.15e+9 = 2^31),

      // the result of converting to integer is undefined

      // refer to http://www.php.net/manual/en/language.types.integer.php

      if ($Check >= $Int32Unit) {

        $Check = ($Check - $Int32Unit * (int) ($Check / $Int32Unit));

        //if the check less than -2^31

        $Check = ($Check < -2147483648) &#63; ($Check + $Int32Unit) : $Check;

      }

      $Check += ord($Str{$i});

    }

    return $Check;

  }

  /**

   * Genearate a hash for a url

   */

  public static function HashURL($String)

  {

    $Check1 = self::StrToNum($String, 0x1505, 0x21);

    $Check2 = self::StrToNum($String, 0, 0x1003F);

    $Check1 >>= 2;

    $Check1 = (($Check1 >> 4) & 0x3FFFFC0 ) | ($Check1 & 0x3F);

    $Check1 = (($Check1 >> 4) & 0x3FFC00 ) | ($Check1 & 0x3FF);

    $Check1 = (($Check1 >> 4) & 0x3C000 ) | ($Check1 & 0x3FFF);

    $T1 = (((($Check1 & 0x3C0) << 4) | ($Check1 & 0x3C)) <<2 ) | ($Check2 & 0xF0F );

    $T2 = (((($Check1 & 0xFFFFC000) << 4) | ($Check1 & 0x3C00)) << 0xA) | ($Check2 & 0xF0F0000 );

    return ($T1 | $T2);

  }

  /**

   * genearate a checksum for the hash string

   */

  public static function CheckHash($Hashnum)

  {

    $CheckByte = 0;

    $Flag = 0;

    $HashStr = sprintf('%u', $Hashnum) ;

    $length = strlen($HashStr);

    for ($i = $length - 1; $i >= 0; $i --) {

      $Re = $HashStr{$i};

      if (1 === ($Flag % 2)) {

        $Re += $Re;

        $Re = (int)($Re / 10) + ($Re % 10);

      }

      $CheckByte += $Re;

      $Flag ++;

    }

    $CheckByte %= 10;

    if (0 !== $CheckByte) {

      $CheckByte = 10 - $CheckByte;

      if (1 === ($Flag % 2) ) {

        if (1 === ($CheckByte % 2)) {

          $CheckByte += 9;

        }

        $CheckByte >>= 1;

      }

    }

    return '7'.$CheckByte.$HashStr;

  }

}

Salin selepas log masuk

使用范例

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<&#63;php

include 'seoreport.php';

ini_set('max_execution_time', 180);

  $url = (isset($_GET['url']))&#63;$_GET['url']:'http://phpclasses.org';

  $meta_tags = seoreport::meta_info($url);

  //die(var_dump($meta_tags));

  //first check if site online

  if ($meta_tags!==FALSE)

  {

    $stats = array();

    $stats['meta'] = $meta_tags;

    $stats['alexa']['rank'] = seoreport::alexa_rank($url);

    $stats['alexa']['links'] = seoreport::alexa_links($url);

    $stats['domain']['WOT_rating'] = seoreport::WOT_rating($url); 

    $stats['domain']['domain_age'] = seoreport::domain_age($url); 

    $stats['social']['twitter'] = seoreport::tweet_count($url); 

    $stats['social']['facebook'] = seoreport::facebook_shares($url);

    $stats['google']['page_rank'] = seoreport::page_rank($url);

    $stats['google']['page_speed'] = seoreport::page_speed($url);

    $stats['google']['pages'] = seoreport::google_pages($url);

    $stats['google']['links'] = seoreport::google_links($url);

    var_dump($stats);

  }

  else 'Site not online. '.$url;

Salin selepas log masuk

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

Label berkaitan:
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Cadangan popular
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan