亮点: 1、利用php也能实现对页面div的切割处理。这里的做法抛砖引玉,希望读者能够提供更加完美的解决方案。 2、切割处理方法已经封装成一个方法,可以直接引用。 3、顺便加上的截
亮点:
1、利用php也能实现对页面div的切割处理。这里的做法抛砖引玉,希望读者能够提供更加完美的解决方案。
2、切割处理方法已经封装成一个方法,可以直接引用。
3、顺便加上的截取。//getWebDiv('id="taglist"','http://www.cnblogs.com/Zjmainstay/tag/');
View Code
<span>php </span><span>header</span>("Content-type: text/html; charset=utf-8"<span>); </span><span>function</span> getWebDiv(<span>$div_id</span>,<span>$url</span>=<span>false</span>,<span>$data</span>=<span>false</span><span>){ </span><span>if</span>(<span>$url</span> !== <span>false</span><span>){ </span><span>$data</span> = <span>file_get_contents</span>( <span>$url</span><span> ); } </span><span>$charset_pos</span> = <span>stripos</span>(<span>$data</span>,'charset'<span>); </span><span>if</span>(<span>$charset_pos</span><span>) { </span><span>if</span>(<span>stripos</span>(<span>$data</span>,'charset=utf-8',<span>$charset_pos</span><span>)) { </span><span>$data</span> = <span>iconv</span>('utf-8','utf-8',<span>$data</span><span>); }</span><span>else</span> <span>if</span>(<span>stripos</span>(<span>$data</span>,'charset=gb2312',<span>$charset_pos</span><span>)) { </span><span>$data</span> = <span>iconv</span>('gb2312','utf-8',<span>$data</span><span>); }</span><span>else</span> <span>if</span>(<span>stripos</span>(<span>$data</span>,'charset=gbk',<span>$charset_pos</span><span>)) { </span><span>$data</span> = <span>iconv</span>('gbk','utf-8',<span>$data</span><span>); } } </span><span>preg_match_all</span>('/<div>$data,<span>$pre_matches</span>,PREG_OFFSET_CAPTURE); <span>//</span><span>获取所有div前缀</span> <span>preg_match_all</span>('/$data,<span>$suf_matches</span>,PREG_OFFSET_CAPTURE); <span>//</span><span>获取所有div后缀</span> <span>$hit</span> = <span>strpos</span>(<span>$data</span>,<span>$div_id</span><span>); </span><span>if</span>(<span>$hit</span> == -1) <span>return</span> <span>false</span>; <span>//</span><span>未命中</span> <span>$divs</span> = <span>array</span>(); <span>//</span><span>合并所有div</span> <span>foreach</span>(<span>$pre_matches</span>[0] <span>as</span> <span>$index</span>=><span>$pre_div</span><span>){ </span><span>$divs</span>[(int)<span>$pre_div</span>[1]] = 'p'<span>; </span><span>$divs</span>[(int)<span>$suf_matches</span>[0][<span>$index</span>][1]] = 's'<span>; } </span><span>//</span><span>对div进行排序</span> <span>$sort</span> = <span>array_keys</span>(<span>$divs</span><span>); </span><span>asort</span>(<span>$sort</span><span>); </span><span>$count</span> = <span>count</span>(<span>$pre_matches</span>[0<span>]); </span><span>foreach</span>(<span>$pre_matches</span>[0] <span>as</span> <span>$index</span>=><span>$pre_div</span><span>){ </span><span>//</span><span><div> <span>if</span>((<span>$pre_matches</span>[0][<span>$index</span>][1] $hit) && (<span>$hit</span> $pre_matches[0][<span>$index</span>+1][1<span>])){ </span><span>$deeper</span> = 0<span>; </span><span>//</span><span>弹出被命中div前的div</span> <span>while</span>(<span>array_shift</span>(<span>$sort</span>) != <span>$pre_matches</span>[0][<span>$index</span>][1] && (<span>$count</span>--)) <span>continue</span><span>; </span><span>//</span><span>对剩余div进行匹配,若下一个为前缀,则向下一层,$deeper加1, //否则后退一层,$deeper减1,$deeper为0则命中匹配,计算div长度</span> <span>foreach</span>(<span>$sort</span> <span>as</span> <span>$key</span><span>){ </span><span>if</span>(<span>$divs</span>[<span>$key</span>] == 'p') <span>$deeper</span>++<span>; </span><span>else</span> <span>if</span>(<span>$deeper</span> == 0<span>) { </span><span>$length</span> = <span>$key</span>-<span>$pre_matches</span>[0][<span>$index</span>][1<span>]; </span><span>break</span><span>; }</span><span>else</span><span> { </span><span>$deeper</span>--<span>; } } </span><span>$hitDivString</span> = <span>substr</span>(<span>$data</span>,<span>$pre_matches</span>[0][<span>$index</span>][1],<span>$length</span>).'</div>'<span>; </span><span>break</span><span>; } } </span><span>return</span> <span>$hitDivString</span><span>; } </span><span>echo</span> getWebDiv('id="taglist"','http://www.cnblogs.com/Zjmainstay/tag/'<span>); </span><span>//</span><span>End_php</span> <p>考虑到id符号问题,id="u"由用户自己填写。</p> <p>声明:此段php只针对带 id div内容的读取。</p> <p><img src="/static/imghwm/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fimages.cnblogs.com%2FOutliningIndicators%2FContractedBlock.gif&refer=http%3A%2F%2Fwww.cnblogs.com%2FZjmainstay%2Farchive%2F2012%2F08%2F06%2Fphp_getDivContain.html" class="lazy" alt="php获取页面并切割页面div内容" ><img src="/static/imghwm/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fimages.cnblogs.com%2FOutliningIndicators%2FExpandedBlockStart.gif&refer=http%3A%2F%2Fwww.cnblogs.com%2FZjmainstay%2Farchive%2F2012%2F08%2F06%2Fphp_getDivContain.html" class="lazy" alt="php获取页面并切割页面div内容" ><span>View Code </span> </p> <p> </p> <pre class="brush:php;toolbar:false"><span> 1</span> <span>php </span><span> 2</span> <span>header</span>("Content-type: text/html; charset=utf-8"<span>); </span><span> 3</span> <span>function</span> getWebTag(<span>$tag_id</span>,<span>$url</span>=<span>false</span>,<span>$tag</span>='div',<span>$data</span>=<span>false</span><span>){ </span><span> 4</span> <span>if</span>(<span>$url</span> !== <span>false</span><span>){ </span><span> 5</span> <span>$data</span> = <span>file_get_contents</span>( <span>$url</span><span> ); </span><span> 6</span> <span> } </span><span> 7</span> <span>$charset_pos</span> = <span>stripos</span>(<span>$data</span>,'charset'<span>); </span><span> 8</span> <span>if</span>(<span>$charset_pos</span><span>) { </span><span> 9</span> <span>if</span>(<span>stripos</span>(<span>$data</span>,'charset=utf-8',<span>$charset_pos</span><span>)) { </span><span>10</span> <span>$data</span> = <span>iconv</span>('utf-8','utf-8',<span>$data</span><span>); </span><span>11</span> }<span>else</span> <span>if</span>(<span>stripos</span>(<span>$data</span>,'charset=gb2312',<span>$charset_pos</span><span>)) { </span><span>12</span> <span>$data</span> = <span>iconv</span>('gb2312','utf-8',<span>$data</span><span>); </span><span>13</span> }<span>else</span> <span>if</span>(<span>stripos</span>(<span>$data</span>,'charset=gbk',<span>$charset_pos</span><span>)) { </span><span>14</span> <span>$data</span> = <span>iconv</span>('gbk','utf-8',<span>$data</span><span>); </span><span>15</span> <span> } </span><span>16</span> <span> } </span><span>17</span> <span>18</span> <span>preg_match_all</span>('/$tag.'/i',$data,$pre_matches,PREG_OFFSET_CAPTURE); //获取所有div前缀 19 preg_match_all('/$tag.'/i',$data,$suf_matches,PREG_OFFSET_CAPTURE); //获取所有div后缀 20 $hit = strpos($data,$tag_id); 21 if($hit == -1) return false; //未命中 22 $divs = array(); //合并所有div 23 foreach($pre_matches[0] as $index=>$pre_div){ 24 $divs[(int)$pre_div[1]] = 'p'; 25 $divs[(int)$suf_matches[0][$index][1]] = 's'; 26 } 27 28 //对div进行排序 29 $sort = array_keys($divs); 30 asort($sort); 31 32 $count = count($pre_matches[0]); 33 foreach($pre_matches[0] as $index=>$pre_div){ 34 //
修复:stripos($data,'charset=utf-8',$charset_pos) 加入charset=,避免有些gb2312格式的网页中包含utf-8造成错误。或者用户可以自行修改函数传入一个确定的charset参数。
演示地址:parseDiv

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Dreamweaver Mac版
Alat pembangunan web visual

Pelayar Peperiksaan Selamat
Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini