<span style="font-size:18px;">//按要求把html标签替换
function replace_html($html){
//替换成空的字符串
$emp_tag=array('ul','table','tr','br');
//不替换的字符串
$no_tag=array('img','script');
//去掉该去掉的标签(br,img,script除外),其他标签都替换成p标签
$html=preg_replace_callback('/<(\/)?(([a-zA-Z]+)(\s*)([^<>]*)(\s*))>/is', function ($matchs)use($emp_tag,$no_tag){
if(in_array($matchs[3], $emp_tag)){//根据设置的替换成空的标签进行操作
return '';
}elseif(in_array($matchs[3], $no_tag)){//根据设置的不替换的标签进行操作
return $matchs[0];
}else {
$str_1=str_replace($matchs[2], 'p', $matchs[0]);//其余标签全部替换成p标签
return $str_1;
}
}, $html);
//去掉换行,空格
$replace_arr=array('<p>','</p>');
$html=str_replace($replace_arr, ' mytag ', $html);//p标签替换成设置的标记,
// $html=str_replace('<p>', ' mytag ', $html);//p标签替换成设置的标记,
// $html=str_replace(, ' mytag ', $html);//p标签替换成设置的标记,
$html=preg_replace('/\s+/', ' ', $html);//去掉多余的空格
$temp_str='';//存放复制进来的字符串的变量
$replace_arr_tag=array(' ','<br/>','mytag ',' ');//要替换掉的字符串
foreach ((explode(' mytag ', $html)) as $key => $value) {
if ($value==' '||$value=='mytag') {//如果是这个则跳出这次循环(不计入替换后的字符串中)
continue;
}
$value=str_replace($replace_arr_tag, '', $value);//去掉空设置好的字符串
$value=trim($value);//去掉前后空格
if(strlen($value)||$value==='false'){//判断字符串是否合格,不合格不计入
$temp_str.='<p>'.$value.'</p>';
}
};
//去掉img标签里面除了src之外的内容
//先找出img标签里面的所有属性
$temp_str=preg_replace_callback('/<img(\s+)([^<>]+)(\s*)\/>/i', function($matchs){
//找到src属性
preg_match('/src="(\s*)([^<>\s]+)(\s*)"/i', $matchs[2], $temp);
if (!count($temp)) {
preg_match("/src='(\s*)([^<>\s]+)(\s*)'/i", $matchs[2], $temp);
}
//对返回值赋值
$img_src='<img src="'.$temp[2].'"/>';
//下载ueditor没有下载的图片
if(preg_match('/^http.*/i', $temp[2])){
$filename="./Public/image/at/".(string)time().(string)(rand(1,1000)*rand(1,1000)*rand(1,1000)+rand(1,1000)+rand(1,1000)+rand(1,1000));
$temp=curl_download($temp[2],$filename);
$img_src='<img src="'.$temp.'"/>';
}
return $img_src;
}, $temp_str);
return $temp_str;
}</span>
html替换把多有标签替换成p标签
最新推荐文章于 2023-03-07 11:00:04 发布