$str= '垃圾的弗拉斯柯达卡<img src="bbs.chinahrd.net" alt="kkkkkkk ddd" title="kdkkdkdkdkkdkd" />上的肌肤拉萨的肌<img src="" />肤了撒旦<img src="bbs.chinahrd.net" />法及阿斯兰<img src="bbs.chinahrd.net" />';
/*
* 取html中的所有img出来
*/
function html2imgs ($html) {
$imgs = array();
if (empty($html)) return $imgs;
preg_match_all("/<img[^>]+>/i",$html,$img);
if (empty($img)) return $imgs;
$img = $img[0];
foreach ($img as $g) {
$g = preg_replace("/^<img|>$/i", '',$g);//移除二头字符
preg_match("/\ssrc\s*\=\s*\"([^\"]+)|\ssrc\s*\=\s*'([^']+)|\ssrc\s*\=\s*([^\"'\s]+)/i", $g, $src);//空格 src 可能空格 = 可能空格 "非"" 或 '非'' 或 非空白 这几种可能,下同
$src= empty($src) ? '': $src[count($src) - 1];//匹配到,总会放在最后
if (empty($src) ) {//空的src? 没用,跳过
continue ;
}
preg_match("/\salt\s*\=\s*\"([^\"]+)|\salt\s*\=\s*'([^']+)|\salt\s*\=\s*(\S+)/i", $g, $alt);
$alt = empty($alt) ? $src : $alt[count($alt) - 1];//alt没值?用src
preg_match("/\stitle\s*\=\s*\"([^\"]+)|\stitle\s*\=\s*'([^']+)|\stitle\s*\=\s*(\S+)/i", $g, $title);
$title= empty($title) ? $src : $title[count($title) - 1];//title没值?用src
$imgs[] = array('title' => $title, 'alt' => $alt, 'src' => $src);
}
return $imgs;
}
var_dump(html2imgs($str));
php代码从html代码中提取出所有的图片返回数组
最新推荐文章于 2023-03-17 17:25:02 发布