
Phpcms 是一款基于 PHP 的内容管理系统,支持通过接口实现模块间或外部系统的数据交互。要调用 Phpcms 接口或让外部请求处理数据,需理解其接口机制和安全控制方式。
一、Phpcms 内部接口调用方法
Phpcms 本身采用模块化设计,接口调用通常指在系统内部通过 API 模块获取数据,比如获取文章、栏目信息等。
1. 使用自带的 api.php 入口文件
Phpcms 提供了统一的 API 入口:/api.php,可通过传参调用指定接口。
立即学习“PHP免费学习笔记(深入)”;
示例:
http://yourdomain.com/api.php?op=content&act=get_list&catid=11&num=10op:操作模块(如 content)act:具体动作(如 get_list)其他参数根据接口需求传入
你需要提前在 /api/content.php 中定义 get_list 方法,并返回 JSON 数据。
2. 自定义接口文件
可在 /api/ 目录下创建自定义接口文件,如 my_api.php:
<?phpdefined(‘IN_PHPCMS’) or exit(‘No permission resources.’);// 加载必要模块pc_base::load_app_func(‘global’);// 示例:返回最新文章$news_db = pc_base::load_model(‘content_model’);$news_db->set_model(1); // 假设模型ID为1$data = $news_db->listinfo(”, ‘id DESC’, 1, 10);echo json_encode($data);exit;
访问地址:https://www.php.cn/link/5e7409b3e5519eff37d11f5fa5f796cb
二、外部请求如何调用 Phpcms 接口
外部系统(如 APP、前端页面、第三方服务)可通过 HTTP 请求调用 Phpcms 提供的接口。
1. 开启接口并设置访问权限
确保 api.php 可被访问避免直接暴露敏感操作,建议对接口做身份验证
2. 添加认证机制(推荐)
为防止未授权访问,可加入 token 或 key 验证:
$auth_key = ‘your_secret_key’;$token = isset($_GET[‘token’]) ? $_GET[‘token’] : ”;if ($token !== md5($auth_key . date(‘Ymd’))) { echo json_encode([‘error’ => ‘Invalid token’]); exit;}
外部请求时带上 token 参数即可验证。
3. 支持跨域请求(CORS)
如果前端是独立部署,需允许跨域:
header("Access-Control-Allow-Origin: *");header("Access-Control-Allow-Methods: GET, POST");header("Access-Control-Allow-Headers: Content-Type");
放在接口文件开头。
三、外部数据提交到 Phpcms 如何处理
外部系统向 Phpcms 提交数据(如用户注册、表单提交),可通过以下方式:
1. 创建专用接收接口
在 /api/ 下建 submit_form.php:
<?phpdefined(‘IN_PHPCMS’) or exit(‘No permission resources.’);$title = isset($_POST[‘title’]) ? trim($_POST[‘title’]) : ”;if (!$title) { echo json_encode([‘status’ => 0, ‘msg’ => ‘标题不能为空’]); exit;}$model = pc_base::load_model(‘content_model’);$model->set_model(1);$result = $model->insert([ ‘title’ => $title, ‘username’ => ‘api_user’, ‘inputtime’ => SYS_TIME, ‘updatetime’ => SYS_TIME]);if ($result) { echo json_encode([‘status’ => 1, ‘id’ => $result]);} else { echo json_encode([‘status’ => 0, ‘msg’ => ‘保存失败’]);}
外部使用 POST 请求发送数据即可。
2. 注意事项
过滤输入参数,防止 SQL 注入或 XSS使用 Phpcms 自带的输入过滤函数:safe_html、new_addslashes 等记录日志便于排查问题
基本上就这些。关键是通过 api.php 入口暴露安全可控的接口,配合认证和数据校验,就能实现内外系统互通。

评论(0)