小編給大家分享一下laravel中如何使用simple_html_dom爬取顯示整本小說,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)公司是一家以網(wǎng)絡(luò)技術(shù)公司,為中小企業(yè)提供網(wǎng)站維護(hù)、網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、網(wǎng)站備案、服務(wù)器租用、域名與空間、軟件開發(fā)、小程序定制開發(fā)等企業(yè)互聯(lián)網(wǎng)相關(guān)業(yè)務(wù),是一家有著豐富的互聯(lián)網(wǎng)運(yùn)營(yíng)推廣經(jīng)驗(yàn)的科技公司,有著多年的網(wǎng)站建站經(jīng)驗(yàn),致力于幫助中小企業(yè)在互聯(lián)網(wǎng)讓打出自已的品牌和口碑,讓企業(yè)在互聯(lián)網(wǎng)上打開一個(gè)面向全國(guó)乃至全球的業(yè)務(wù)窗口:建站服務(wù)熱線:028-86922220
一、在laravel引入第三方類
1.在項(xiàng)目根目錄下app目錄中新建一個(gè)文件夾命名為L(zhǎng)ib(自定義名稱)
2.如果引入第三方庫(kù)多的話可以在Lib下再新建幾個(gè)目錄分類,由于只引入了一個(gè)類,這里沒有新建文件夾。(根據(jù)引入類的多少自己定義)
將simple_html_dom.php復(fù)制到Lib下
3.找到項(xiàng)目根目錄下的composer.json文件,將第三方類的路勁寫入autoload下的classmap中,這樣才能自動(dòng)加載
"autoload": {
"classmap": [
"database/seeds",
"database/factories",
"app/Lib/simple_html_dom.php"
]
},
4.在cmd控制臺(tái)中切換到項(xiàng)目根目錄,執(zhí)行命令:
composer dumpautoload
5.在控制器中use這個(gè)類即可
use simple_html_dom;
$html = new simple_html_dom(); 使用
二、創(chuàng)建路由
Route::get('/novel_list','index\Spnovel@index');
三、創(chuàng)建控制器Spnovel.php
load($list_html); $list = $html->find('#list dd a'); foreach ($list as $k=>$v) { $arr1=$arr2=[]; $p1 = '/(.*?)<\/a>/i'; $p2 = '/.*?<\/a>/i'; preg_match($p1,$v->outertext,$arr1); preg_match($p2,$v->outertext,$arr2); $content[$k][0]=$arr1[1]; $content[$k][1]=$arr2[1]; } array_splice($content,0,12); return $content; } } class mySpClass{ // 向服務(wù)器發(fā)送最簡(jiǎn)單的get請(qǐng)求 public static function getCurl($url,$header=null){ // 1.初始化 $ch = curl_init($url); //請(qǐng)求的地址 // 2.設(shè)置選項(xiàng) curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);//獲取的信息以字符串返回,而不是直接輸出(必須) curl_setopt($ch,CURLOPT_TIMEOUT,10);//超時(shí)時(shí)間(必須) curl_setopt($ch, CURLOPT_HEADER,0);// 啟用時(shí)會(huì)將頭文件的信息作為數(shù)據(jù)流輸出。 //參數(shù)為1表示輸出信息頭,為0表示不輸出 curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false); //不驗(yàn)證證書 curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,false); //不驗(yàn)證證書 if(!empty($header)){ curl_setopt($ch,CURLOPT_HTTPHEADER,$header);//設(shè)置頭信息 }else{ $_head = [ 'User-Agent:Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:70.0) Gecko/20100101 Firefox/70.0' ]; curl_setopt($ch,CURLOPT_HTTPHEADER,$_head); } // 3.執(zhí)行 $res = curl_exec($ch); // 4.關(guān)閉 curl_close($ch); return $res; } }
以上代碼的解釋:首先要對(duì)laravel框架了解,對(duì)php類要有所了解
訪問了以上路由,運(yùn)行的是Spnovel.php控制器中的index方法,$url是某一本小說的章節(jié)列表的地址,將其作為參數(shù)運(yùn)行自定義類mySpClass中的getcurl方法,返回這個(gè)頁(yè)面的html文檔字符串。運(yùn)行此類中的getList方法,參數(shù)是需要解析的html字符串。將這個(gè)方法私有化,使用simple_html_dom解析,配置正則提取出每章的url地址和章節(jié)名稱。并返回這個(gè)數(shù)組,通過return view('index.spnovel.index',$data);將打開index/spnovel/index.blade.php,請(qǐng)看index.blade.php
四、創(chuàng)建視圖index.blade.php
爬取的小說列表 @foreach($List as $item)
- {{$item[0]}}
@endforeach
以上代碼的解釋:css就簡(jiǎn)單的寫到這里,img是作為背景圖片的。ul里面循環(huán)li,{{$item[1]}}是獲得的地址參數(shù),{{$item[0]}}是獲得的章節(jié)名稱??匆幌聰?shù)組和最后的效果。
五、運(yùn)行
接下來就是每一章節(jié)的內(nèi)容了
先看路由:
Route::get('/novel_con/{a}//{c}','index\Spnovel@get_nContent');
這與每一章的url參數(shù)相對(duì)應(yīng),比如某一章的參數(shù)為:novel_con/85/85445/27248645.html
寫get_nContent方法:
public function get_nContent(Request $req){ $url1 = $req->a.'/'.$req->b.'/'.$req->c; $url = "https://www.7kzw.com/".$url1; $res = mySpClass::getCurl($url);//獲得 // 開始解析 $data['artic']= self::getContent($res); $next = (int)$req->c; $next = $next+1; $data['artic']['next']="/novel_con/".$req->a.'/'.$req->b.'/'.$next.'.html'; return view('index.spnovel.ncontent',$data); } private static function getContent($get_html){ $html = new simple_html_dom(); @$html->load($get_html); $h2 = $html->find('.bookname h2'); foreach ($h2 as $k=>$v) { $artic['title'] = $v->innertext; } // 查找小說的具體內(nèi)容 $divs = $html->find('#content'); foreach ($divs as $k=>$v) { $content = $v->innertext; } // 正則替換去除多余部分 $pattern = "/(.*?<\/p>)|(
.*?<\/div>)/"; $artic['content'] = preg_replace($pattern,'',$content); return $artic; }解釋:$req->a,$req->b,$req->c,分別是三個(gè)參數(shù),然后將其合并為一個(gè)完整的請(qǐng)求某一章的地址,然后還是通過mySpClass::getCurl獲得某一章的html字符串。然后使用本類中的getContent解析這個(gè)頁(yè)面,先看解析方法,和上篇文章一章解析出章節(jié)的標(biāo)題和內(nèi)容,寫到數(shù)組中,并且去掉了多余的文字廣告部分。$next則是存放的下一章的地址,用于在章節(jié)詳情頁(yè)面跳轉(zhuǎn)。
視圖ncontent.blade.php
{{$artic['title']}} {{$artic['title']}}
下一章{!!$artic['content']!!}解釋:因?yàn)橹挥挟?dāng)前一篇所以不需要循環(huán),{{$artic['title']}}就是標(biāo)題,也可以寫到title中。{!!$artic['content']!!}的寫法就是不需要轉(zhuǎn)義文章的內(nèi)容,否則就會(huì)有很多其他字符了,如
等。下一章的按鈕的地址直接就用傳遞過來的即可,position:fixed固定定位按鈕,隨時(shí)可以下一章。運(yùn)行:
以上是“l(fā)aravel中如何使用simple_html_dom爬取顯示整本小說”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)站標(biāo)題:laravel中如何使用simple_html_dom爬取顯示整本小說
當(dāng)前URL:http://weahome.cn/article/gegoci.html