php实现获取文章内容第一张图片的方法
web PHP 2017-07-12 2309 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

6443296 2613 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

网站前端显示新闻列表的时候,有图片,但是,给每条新闻单独上传一张图片比较麻烦。最简便的方法就是,如果文章里面有图片的话,把第一张图片调出来显示。以下代码来自网络:


$obj=M("News");
 $info=$obj->where('id=1')->find();
 //方法1*********
 $soContent = $info['content'];
 $soImages = '~<img [^>]* />~';
 preg_match_all( $soImages, $soContent, $thePics );
 $allPics = count($thePics[0]);
 preg_match('/<img.+src=\"?(.+\.(jpg|gif|bmp|bnp|png))\"?.+>/i',$thePics[0][0],$match);
 dump($thePics);
 if( $allPics> 0 ){
     echo "<img src='".$match[1]."' title='".$match[1]."'>";//获取的图片名称
 } else {
     echo "没有图片";
 }
我是用thinkphp做的网站,按上述方法实现了需求,代码如下:



$pages = $this->pageQuery($sql,$pcurr,5);
		//每条新闻获取文章内第一张图片	
		foreach($pages['root'] as $k=>$v){
			if($v['articleImg'] == ''){			
				$soContent = $v['articleContent'];
				 $soImages = '~<img [^>]* />~';
				 preg_match_all( $soImages, $soContent, $thePics );
				 $allPics = count($thePics[0]);
				 preg_match('/<img.+src=\"?(.+\.(jpg|gif|bmp|bnp|png))\"?.+>/i',$thePics[0][0],$match);
				 //dump($thePics);
				 if( $allPics> 0 ){
					 $pic1 = $match[1];//获取的图片名称
					 $pages['root'][$k]['articleImg'] = substr($pic1,1 );
				 }
			}
		}
		
		$rs["pages"] = $pages;		
		return $rs;

补充:

由于图片在文章内容中保存的格式是html实体格式,如下

&lt;img src=&quot;/Upload/image/20170421/20170421112533_90697.jpg&quot; alt'...

导致正则匹配的时候匹配不到图片,所以在检索articleContent前,先利用htmlspecialchars_decode() 函数把文章内容中的预定义的 HTML 实体转换为字符,然后就可以了

$soContent = htmlspecialchars_decode($v['articleContent']);



版权声明:本篇文章来源于网络。 来源链接

相关推荐
php实现ZIP压缩文件解压缩,中文乱码解决方法(重要)
PHP | 2019-04-30 5628
直接上代码,具体代码里面都有注释。直接中文压缩文件解压到中文文件夹。 <?php // 需开启配置 php_zip.dll // phpinfo(); header("Content-type:text/html;charset=utf-8"); /* * $filename 被解压文件名 * $path 解压...
openssl_private_decrypt解密失败
PHP | 2019-01-16 5598
复制别人的解密程序,原程序可以解密,复制过来就不可以 一步步尝试发现,秘钥换行符有区别, 原秘钥有换行符,复制过来不知道什么时候把换行符清空了,成了一行字符串了。
评论:0条
评论加载中...
发表评论