$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));