php,{dede:field name='body' function='cn_substr(@me,0,200)'/},`,,这段代码表示截取文章内容前200个字符。,,2. 在这段代码前后添加正则表达式匹配图片标签的代码:,,`php,{dede:field name='body' function='preg_replace("/]+>/i", "", @me)'/},`,,这段代码表示去除文章中的图片标签。,,3. 将这两段代码组合在一起,形成完整的代码:,,`php,{dede:field name='body' function='preg_replace("/]+>/i", "", cn_substr(@me,0,200))'/},“,,这样,在列表页中就可以显示内容页的图片了。
在织梦CMS(DedeCMS)中,从列表页获取内容页的图片是一个常见的需求,本文将详细介绍如何实现这一功能,包括步骤、代码示例以及常见问题解答。


使用SQL查询语句获取图片路径
你需要了解如何在列表页通过SQL查询语句获取内容页的图片路径,假设你的数据表名为dede_archives,图片字段为body,你可以使用以下SQL语句来获取图片路径:
SELECT body FROM dede_archives WHERE id = 你的内容ID;
在列表页模板中显示图片
你需要在列表页模板中显示获取到的图片,你可以在list.htm 文件中添加如下代码:
{dede:sql name=getimage query="SELECT body FROM dede_archives WHERE id = '[field:id/]'"}
<img src="[field:body/]" alt="content image" />
{/dede:sql}
上述代码会在每个列表项中插入一个<img> 标签,并显示内容页中的图片。
使用自定义标签实现更复杂的逻辑
如果你需要更复杂的逻辑,比如过滤图片链接或处理多张图片,可以使用自定义标签,以下是一个简单的示例:
1、创建自定义标签
在include/arc.archives.class.php 文件中添加以下代码:
public function GetImage($aid) {
$row = $this>dsql>GetOne("SELECT body FROM dede_archives WHERE id='$aid'");
return $row['body']; // 这里返回的是内容字段,包含图片链接
}
2、在列表模板中使用自定义标签


在list.htm 文件中添加如下代码:
{dede:php}
$aid = $GLOBALS['aid']; // 当前文章的ID
$body = $GLOBALS['dede_arc']>GetImage($aid);
preg_match('/src="(.*?.jpg)"/i', $body, $matches);
echo '<img src="' . $matches[1] . '" alt="content image" />';
{/dede:php}
使用正则表达式提取图片链接
字段中可能包含多张图片链接,这时可以使用正则表达式进行提取,以下是一个示例:
{dede:php}
$pattern = '/<img src="(.*?.jpg)" />/i';
$body = $GLOBALS['dede_arc']>GetImage($aid);
preg_match_all($pattern, $body, $matches);
if (isset($matches[1]) && count($matches[1])) {
foreach ($matches[1] as $match) {
echo '<img src="' . $match . '" alt="content image" />';
}
}
{/dede:php}
注意事项
1、性能优化:频繁查询数据库可能会影响性能,建议对常用查询结果进行缓存。
2、安全性:确保输入的数据经过适当的过滤和验证,避免XSS攻击等安全问题。
3、兼容性:不同的织梦CMS版本可能存在差异,请根据具体情况进行调整。
相关问答FAQs
问题1:如何在列表页显示多张图片?
答:如果内容字段中包含多张图片链接,可以使用正则表达式提取所有图片链接并在列表页中显示,具体代码如下:


{dede:php}
$pattern = '/<img src="(.*?.jpg)" />/i';
$body = $GLOBALS['dede_arc']>GetImage($aid);
preg_match_all($pattern, $body, $matches);
if (isset($matches[1]) && count($matches[1])) {
foreach ($matches[1] as $match) {
echo '<img src="' . $match . '" alt="content image" />';
}
}
{/dede:php}
问题2:如何优化查询性能?
答:为了优化查询性能,可以采取以下措施:
1、缓存查询结果:对于频繁访问的数据,可以将查询结果缓存起来,减少数据库查询次数。
2、分页显示:如果列表页数据量较大,可以采用分页显示的方式,每次只加载部分数据。
3、优化SQL查询:确保SQL查询语句高效,避免不必要的复杂查询。
| 序号 | 问题 | 答案 |
| 1 | 如何定位到列表页的图片? | 通过获取列表页的URL,然后解析HTML内容,定位到包含图片的标签(如)。 |
| 2 | 如何获取图片的URL? | 在定位到的图片标签中,提取src属性值,该值即为图片的URL。 |
| 3 | 如何获取图片标题? | 在图片标签中,查找alt属性,该属性值即为图片的标题。 |
| 4 | 如何获取图片描述? | 在图片标签所在的父元素中,查找描述性的内容,如
|
| 5 | 如何获取图片的其他信息? | 可以通过CSS选择器或XPath进一步解析HTML,获取图片的更多属性,如尺寸、类名等。 |
| 6 | 如何处理JavaScript动态加载的图片? | 如果图片是通过JavaScript动态加载的,可以使用浏览器开发者工具的Network标签或Console控制台,查看图片加载的请求。 |
| 7 | 如何将获取到的图片信息存储或展示? | 可以将图片信息存储到数据库、文件或直接展示在页面上。 |
以下是一个使用Python的BeautifulSoup库从HTML中提取图片信息的示例代码:
from bs4 import BeautifulSoup
import requests
获取列表页的HTML内容
url = 'http://example.com/listpage'
response = requests.get(url)
html_content = response.text
解析HTML内容
soup = BeautifulSoup(html_content, 'html.parser')
获取图片信息
images = soup.find_all('img')
for img in images:
img_url = img.get('src')
img_alt = img.get('alt')
img_parent = img.parent
img_description = img_parent.text
print(f'图片URL: {img_url}')
print(f'图片标题: {img_alt}')
print(f'图片描述: {img_description}')
print('')





