没有统一的PHP函数可直接读取栏目表单字段,需按CMS类型分别处理:DedeCMS查dede_arctype.addonfields或扩展表,EmpireCMS查enewsclassadd表,采集场景则需解析HTML或调用API。

PHP怎么读取栏目表单字段(如 DedeCMS、EmpireCMS 等常见 CMS)
直接说结论:没有统一的“PHP 获取栏目表单字段”函数,必须根据具体 CMS 的数据库结构和 API 来查。所谓“栏目表单字段”,通常指后台为某个栏目(channel)单独配置的自定义字段(比如 seo_title、banner_img),不是文章内容字段,也不在 arctype 或 enewsclass 主表里——多数情况它们存在扩展表或自定义字段配置表中。
dedecms 中读取栏目自定义字段的实操路径
DedeCMS 5.7+ 支持栏目自定义字段,但默认不启用,需手动开启并添加字段。字段值实际存于 dede_channeltype(字段定义) + dede_arctype(主表)或独立扩展表(如 dede_mychannels)中。
常见错误现象:GetOne("SELECT seo_title FROM `dede_arctype` WHERE id=123") 返回空——因为 seo_title 并不在 dede_arctype 表里,而是你后来加的字段,可能被写进扩展表或用 addonfields 方式序列化存进 dede_arctype.addonfields 字段(Dede 的老版本逻辑)。
- 确认字段是否已启用:进入后台 → 栏目管理 → 修改栏目 → 查看底部“自定义字段”区域是否可编辑
- 查字段真实存储位置:
SHOW CREATE TABLE dede_arctype,看有没有你加的字段名;若无,执行SELECT addonfields FROM dede_arctype WHERE id=123,解析 JSON/序列化字符串 - 推荐做法:用 Dede 内置函数
GetChannelFields()(需先引入include/helpers/extend.helper.php)或直接查扩展表(如dede_mychannels)
帝国CMS(EmpireCMS)获取栏目字段的正确方式
帝国对栏目字段支持更规范:自定义字段默认存于 enewsclassadd 表,主键 classid 关联 enewsclass.classid。这是最可靠、最常被忽略的路径。
立即学习“PHP免费学习笔记(深入)”;
典型错误:直接查 enewsclass 表,发现没有 mobile_banner 字段就断定“没存”,其实它在 enewsclassadd 里。
- 安全查询写法:
$sql = "SELECT a.* FROM {$dbtbpre}enewsclass c LEFT JOIN {$dbtbpre}enewsclassadd a ON c.classid=a.classid WHERE c.classid='$classid'"; - 注意:字段名要带表前缀,且
enewsclassadd表必须存在(安装时默认有,但部分精简版可能删了) - 如果字段是“文本区域”类型,内容可能含 HTML 实体或换行符,输出前建议用
htmlspecialchars_decode()或nl2br()处理
通用采集场景下怎么稳定取到栏目字段(非 CMS 内部调用)
如果你是在写采集脚本(比如用 PHP cURL 抓其他站点栏目页),那根本不存在“PHP 获取栏目表单字段”这回事——你只能解析 HTML 或调用对方开放的 API。这时候“栏目表单字段”其实是页面上某段 DOM 或 JSON 接口返回的数据。
- 先抓取栏目页 HTML:
file_get_contents('https://xxx.com/channel/123.html'),再用DOMDocument或simple_html_dom提取meta[name="keywords"]、div.seo-desc等 - 如果目标站有 API(如
/api/v1/channel/123),优先走接口,响应通常是 JSON,字段名明确,比如data.seo_title - 切忌硬编码字段名:不同站点结构千差万别,
banner_img可能叫cover、thumb或藏在data-attr里,必须动态识别
最容易被忽略的一点:很多 CMS 的栏目字段只在后台生效,前台模板没调用就不会输出到 HTML —— 采集脚本拿不到,不是你代码错了,是源头就没给。











