代码:
// 内容:$detail['content']
//img的url,width,height
$img = array();
$matches = array();
$regeImg = '/<img.+src=\"?(.+(jpg|gif|bmp|bnp|png))\"?.+width=\"?(\d*)\"?.+height=\"?(\d*)\"?.+>/i';
if(preg_match_all($regeImg, $detail['content'], $matches)){
//$matches[1] url ;$matches[3] width ;$matches[4] height
foreach($matches[1] as $k=>$v){
$img[$k]['ref'] = "<!--IMG#".$k."-->";
$img[$k]['src'] = $v;
$img[$k]['alt'] = '';
$img[$k]['width'] = $matches[3][$k];
$img[$k]['height'] = $matches[4][$k];
}
}
//a标签
$link = array();
$regA= '/<a.*href="(.*)".*>(.*)</isU';
$aList = array();
if(preg_match_all($regA, $detail['content'], $aList)){
//$aList[1] url ;$aList[2] content
foreach($aList[1] as $k=>$v){
$link[$k]['ref'] = "<!--link".$k."-->".$aList[2][$k];
$link[$k]['title'] = $aList[2][$k];
$link[$k]['url'] = $v;
}
}
//替换img标签
$str = "";
$regReplaceImg = '/<img.+src=\"?(.+(jpg|gif|bmp|bnp|png))\"?.+width=\"?(\d*)\"?.+height=\"?(\d*)\"?.+?(?=\/)?(>)?/i';
foreach($img as $k=>$v){
if($k == 0){
$content = $detail['content'];
$str = $this->replace($regReplaceImg,"<!--IMG#".$k."-->",$content);
}else{
$str = $this->replace($regReplaceImg,"<!--IMG#".$k."-->",$str);
}
}
//替换a标签
$body = '';
$regPeplaceA = '/<a.*href="(.*)".*>(.*)<\/a>/isU';
foreach($link as $k=>$v){
if($k == 0){
$body = $this->replace($regPeplaceA,$v['ref'],$str);
}else{
$body = $this->replace($regPeplaceA,$v['ref'],$body);
}
} //替换
public function replace($reg,$replace,$con){
$str = preg_replace($reg,$replace, $con,1);
return $str;
} 打印出来的json数据:


  

正则:img的url,width,height 和 a标签的url以及替换的更多相关文章

  1. client/scroll/offset width/height/top/left ---记第一篇博客

    client/scroll/offset width/height/top/left (盒模型为contentBox,定位原点是元素左上角边框最外层的交点) clientWidth  width+左p ...

  2. as3:sprite作为容器使用时,最好不要指定width,height

    除 TextField 和 Video 对象以外,没有内容的显示对象(如一个空的 Sprite)的高度为 0,即使您尝试将 height 设置为其它值,也是这样. 如果您设置了 height 属性,则 ...

  3. offset[Parent/Width/Height/Top/Left] 、 client[Width/Height/Top/Left] 、 Element.getBoundingClientRect()

    开篇提示:以下内容都经个人测试,参考API文档总结,但还是不能保证完全正确,若有错误,还请留言指出___________________________________________________ ...

  4. ffmpeg按比例缩放--"width / height not divisible by 2" 解决方法

    最近在处理视频的时候,有这么一个需求 如果视频的分辨率宽度大于960的话,就把宽度设为960,而高度按其比例进行缩放 如果视频的分辨率高度大于540的话,就把高度设为540,而宽度按其比例进行缩放 之 ...

  5. 如何理解VB窗体中的scale类属性及width height属性之间的关系

    如何理解VB窗体中的scale类属性及width height属性之间的关系 VB中的SCALEHIEGT,SCALEWIDTH,与窗体中的WIDTH,HEIGHT的区别及关系是许多VB初学者难以理解 ...

  6. css 行内元素 块元素 替换元素 非替换元素 以及这些元素的width height margin padding 特性

    一.各种元素的width height margin padding 特性(具体css元素的分来参看二) 1.块级元素 width. height. margin的四个方向. padding的四个方向 ...

  7. struts2 标签 --<<s:url >

    Struts2中的链接标签 <s:url>和<s:a> 普通链接 Web程序中最普通的应用是链接到其他页面,下面看Welcome.jsp. <%@ page conten ...

  8. Struts2中的链接标签 <s:url>和<s:a>---在action中获取jsp表单提交的参数(转)

    转自:http://sgl124764903.iteye.com/blog/444183 1.普通链接 Web程序中最普通的应用是链接到其他页面,下面看Welcome.jsp. <%@ page ...

  9. URL传值问题,不同浏览器对URL的长度要求

    通过URL传值的问题,所以对url字符串进行encodeURIComponent对url字符串内容进行编码,问题解决,但是有时候会出现 The request filtering module is ...

随机推荐

  1. Vue.use源码分析

    我想有过vue开发经验的,对于vue.use并不陌生.当使用vue-resource或vue-router等全局组件时,必须通过Vue.use方法引入,才起作用.那么vue.use在组件引入之前到底做 ...

  2. sql server 学习笔记 ( backup 备份方案 )

    做个记入就好 USE [master] SELECT bs.database_name AS 'Database Name', bs.backup_start_date AS 'Backup Star ...

  3. Java操作Kafka

    java操作kafka非常的简单,然后kafka也提供了很多缺省值,一般情况下我们不需要修改太多的参数就能使用.下面我贴出代码. pom.xml <dependency> <grou ...

  4. hadoop挂载多硬盘,ZZ-- multiple disks per node

    hadoop挂载多硬盘 ...multiple disks per node  multiple disks per node Read more at: http://www.queryhome.c ...

  5. day11 - 15(装饰器、生成器、迭代器、内置函数、推导式)

    day11:装饰器(装饰器形成.装饰器作用.@语法糖.原则.固定模式) 装饰器形成:最简单的.有返回值的.有一个参数的.万能参数 函数起的作用:装饰器用于在已经完成的函数前后增加功能 语法糖:使代码变 ...

  6. Artem and Array CodeForces - 442C (贪心)

    大意: 给定序列$a$, 每次任选$a_i$删除, 得分$min(a_{i-1},a_{i+1})$(无前驱后继时不得分), 求最大得分. 若一个数$x$的两边都比$x$大直接将$x$删除, 最后剩余 ...

  7. Ugly Number II leetcode java

    问题描述: Write a program to find the n-th ugly number. Ugly numbers are positive numbers whose prime fa ...

  8. climbing stairs leetcode java

    问题描述: You are climbing a stair case. It takes n steps to reach to the top. Each time you can either ...

  9. 关于react16.4——高阶组件(HOC)

    高阶组件是react中用于重用组件逻辑的高级技术.可以说是一种模式.具体来说呢,高阶组件是一个函数,它接收一个组件并返回一个新的组件. 就像这样, const EnhancedComponent = ...

  10. react中直接调用子组件的方法(非props方式)

    我们都知道在 react中,若要在父组件调用子组件的方法,通常我们会采用在父组件定义一个方法,作为props转给子组件,然后执行该方法,可以获取到子组件传回的参数以得到我们的目的. 显而易见,这个执行 ...