Install
openclaw skills install dahua-cloud-open-device-image-analysis基于大华云开发者平台的 IoT 设备图像分析技能。支持对 Dahua IoT 设备进行抓拍,并调用大模型进行图片分析。可识别监控画面中的人、车辆、物体等,支持安全帽、口罩、烟雾、火焰等检测及摔倒、入侵等行为识别。适用于设备图像分析、安全生产、异常看护、连锁巡检、企业安全管理等场景。
openclaw skills install dahua-cloud-open-device-image-analysis调用大华云平台大模型进行图像分析。完整的抓图→AI 分析流程!
本技能提供端到端的大华云图像分析服务:
需要设置 Cloud 凭证(ProductId、AK、SK)!
最适合初学者和不想用命令行的用户!
Win + R 键,输入 sysdm.cpl 并回车在 "当前用户的变量(U)" 区域(窗口上半部分),点击 "新建(W)...":
| 变量名 | 变量值 | 说明 |
|---|---|---|
DAHUA_CLOUD_PRODUCT_ID | 你的 AppID | 应用 ID |
DAHUA_CLOUD_AK | 你的 AccessKey | 访问密钥 |
DAHUA_CLOUD_SK | 你的 SecretKey | 保密密钥 |
示例:
变量名:DAHUA_CLOUD_PRODUCT_ID
变量值:138XXXX731
变量名:DAHUA_CLOUD_AK
变量值:196XXXXXXXXXXXXX808
变量名:DAHUA_CLOUD_SK
变量值:naumXXXXXXXXXXXXXXXXyHxh
如果需要更详细的图文教程,请参考以下操作要点:
适合熟悉命令行的用户!
Windows PowerShell (推荐 - 用户级别):
[Environment]::SetEnvironmentVariable("DAHUA_CLOUD_PRODUCT_ID", "your_app_id", "User")
[Environment]::SetEnvironmentVariable("DAHUA_CLOUD_AK", "your_access_key", "User")
[Environment]::SetEnvironmentVariable("DAHUA_CLOUD_SK", "your_secret_key", "User")
Linux/Mac (当前会话临时):
export DAHUA_CLOUD_PRODUCT_ID='your_app_id'
export DAHUA_CLOUD_AK='your_access_key'
export DAHUA_CLOUD_SK='your_secret_key'
⚠️ 安全建议: 避免将凭证写入 ~/.bashrc、~/.zshrc 等启动文件进行长期存储,以防凭证泄露。建议优先使用 Windows 用户环境变量或临时的当前会话导出方式。
适合快速测试!
Windows PowerShell (临时):
$env:DAHUA_CLOUD_PRODUCT_ID='your_app_id'
$env:DAHUA_CLOUD_AK='your_access_key'
$env:DAHUA_CLOUD_SK='your_secret_key'
注意: 仅在当前窗口有效,关闭后失效
Linux/Mac:
echo $DAHUA_CLOUD_PRODUCT_ID
echo $DAHUA_CLOUD_AK
# 注意:不要打印 SK,避免泄露
Windows PowerShell:
$env:DAHUA_CLOUD_PRODUCT_ID
$env:DAHUA_CLOUD_AK
python device_image_analysis.py \
--device-sn BA5918431 \
--prompt "请判断这张图片中是否有人"
# 抓拍并调用 AI 分析(仅需要 Cloud 凭证)
python device_image_analysis.py \
-d BA5918431 \
-p "请判断图片中是否有白色轿车。回答格式:有{是} 或 无{否}" \
-c 0
from device_image_analysis import analyze_device_camera
result = analyze_device_camera(
device_sn="BA5918431",
prompt="请判断图中是否有人玩手机",
channel_no=0
)
print(f"Analysis Result: {result['analysis']['result']}")
┌─────────────┐
│ 1. 获取 Cloud Token │
│ (AppAccessToken) │
└──────┬──────┘
▼
┌─────────────┐
│ 2. 设备抓图 │
│ setDeviceSnapEnhanced │
└──────┬──────┘
▼
┌─────────────┐
│ 3. 等待 OSS │
│ URL 生效(1s) │
└──────┬──────┘
▼
┌─────────────┐
│ 4. 下载保存 │
│ 图片到本地 │
│ (支持5次重试) │
└──────┬──────┘
▼
┌─────────────┐
│ 5. 调用 AI 分析 │
│ imageAnalysis API │
└──────┬──────┘
▼
┌─────────────┐
│ 6. 返回结果 │
│ 含分析内容和本地路径 │
└─────────────┘
{
"success": True,
"device_sn": "BA5918431",
"channel_no": 0,
"image_url": "https://oss-cn-hangzhou.aliyuncs.com/...",
"local_image_path": "./captured_images/BA5918431/ch0_1234567890.jpg",
"analysis": {
"success": True,
"code": "200",
"message": "操作成功",
"data": {"content": "图中有 2 个人"},
"result": "图中有 2 个人"
}
}
python device_image_analysis.py \
-d YOUR_SN \
-p "图中是否有人?请回答'有'或'无'"
python device_image_analysis.py \
-d YOUR_SN \
-p "图中有多少辆车?分别是什么颜色?"
python device_image_analysis.py \
-d YOUR_SN \
-p "图中是否有打架、摔倒等异常情况?"
python device_image_analysis.py \
-d YOUR_SN \
-p "识别图中的主要物体,按重要性排序"
| 端点 | 路径 | 说明 |
|---|---|---|
| 认证 | /open-api/api-base/auth/getAppAccessToken | 获取 AppAccessToken |
| 抓图 | /open-api/api-iot/device/setDeviceSnapEnhanced | 设备实时抓图 |
| AI 分析 | /open-api/api-ai/largeModelDetect/imageAnalysis | 大模型图像分析 |
get_token_sign() - 获取 Token 签名 (access_key + timestamp + nonce)business_api_sign() - 业务 API 签名 (access_key + app_access_token + timestamp + nonce)┌─────────────────────────────────────────────────────────────┐
│ 常量配置层 (Constants) │
│ - API 端点、超时时间、环境变量名 │
└─────────────────────────────────────────────────────────────┘
│
┌─────────────────────────────────────────────────────────────┐
│ 工具函数层 (Utilities) │
│ - get_token_sign() 获取Token签名 │
│ - business_api_sign() 业务API签名 │
│ - verify_image_url_accessible() URL可访问性验证(备用) │
└─────────────────────────────────────────────────────────────┘
│
┌─────────────────────────────────────────────────────────────┐
│ DahuaSnapshotClient 类 │
│ - get_app_access_token() 获取/刷新 Token │
│ - capture_snapshot() 设备抓图 │
│ - download_and_save() 图片下载保存(含1s等待+5次重试) │
└─────────────────────────────────────────────────────────────┘
│
┌─────────────────────────────────────────────────────────────┐
│ AI 分析函数层 │
│ - analyze_with_dahua_ai() 调用大模型分析 │
│ - analyze_device_camera() 完整流程封装 │
└─────────────────────────────────────────────────────────────┘
analyze_device_camera(device_sn, prompt, channel_no=0)完整的图像分析流程封装函数。
参数:
| 参数 | 类型 | 必填 | 说明 |
|---|---|---|---|
device_sn | str | ✅ | 设备序列号 (SN) |
prompt | str | ✅ | AI 分析问题 |
channel_no | int | ❌ | 通道号 (默认:0) |
返回值: Dict[str, Any]
{
"success": True, # 整体成功状态
"device_sn": "BA5918431", # 设备序列号
"channel_no": 0, # 通道号
"image_url": "...", # 图片 URL
"local_image_path": "...", # 本地保存路径
"analysis": { # AI 分析结果
"success": True,
"code": "200",
"message": "操作成功",
"data": {"content": "..."},
"result": "..."
}
}
认证请求头 (获取 Token):
{
"Content-Type": "application/json",
"AccessKey": access_key,
"Timestamp": timestamp,
"Nonce": nonce,
"X-TraceId-Header": trace_id,
"Sign": signature, # get_token_sign() 生成
"ProductId": app_id, # DAHUA_CLOUD_PRODUCT_ID
"Version": "V1",
"Sign-Type": "simple"
}
业务请求头 (抓图/AI分析):
{
"Content-Type": "application/json",
"AccessKey": access_key,
"Timestamp": timestamp,
"Nonce": nonce,
"X-TraceId-Header": trace_id,
"Sign": signature, # business_api_sign() 生成
"Version": "V1",
"Sign-Type": "simple",
"AppAccessToken": app_token, # 获取Token后传入
"ProductId": app_id # DAHUA_CLOUD_PRODUCT_ID
}
| 常量名 | 默认值 | 说明 |
|---|---|---|
DEFAULT_API_BASE_URL | https://open.cloud-dahua.com/ | API 基础地址 |
DEFAULT_CHANNEL_NO | 0 | 默认通道号 |
TOKEN_EXPIRY_SECONDS | 3600 | Token 有效期(秒) |
TIMEOUT_AUTH | 60 | 认证超时(秒) |
TIMEOUT_SNAPSHOT | 60 | 抓图超时(秒) |
TIMEOUT_DOWNLOAD | 300 | 下载超时(秒) |
TIMEOUT_ANALYSIS | 120 | AI分析超时(秒) |
URL_VERIFY_RETRIES | 3 | URL 验证重试次数 |
URL_VERIFY_DELAY | 1 | URL 验证重试间隔(秒) |
SNAPSHOT_RETRY_DELAY | 2 | 抓拍重试间隔(秒) |
| 参数 | 简写 | 类型 | 必填 | 说明 |
|---|---|---|---|---|
--device-sn | -d | str | ✅ | 设备序列号 (SN) |
--prompt | -p | str | ✅ | AI 分析问题 |
--channel | -c | int | ❌ | 通道号 (默认:0) |
安装依赖:
pip install requests
不要将真实的 Cloud 凭证提交到 Git!
本项目包含 .gitignore 文件,会自动忽略敏感配置文件。建议:
dahua-cloud-open-device-image-analysis/
├── README.md # 说明文件
├── SKILL.md # 本文件
├── FAQ.md # 常见问题解答
├── device_image_analysis.py # 主程序
├── requirements.txt # Python 依赖
└── .gitignore # Git 忽略规则
✅ 极简配置 - 仅需要 3 个必要参数 (SN, Prompt, Channel)
✅ 代码优化 - 统一的签名/请求头生成,完整类型注解
✅ 可配置 - 超时、重试等参数通过常量统一管理
✅ 跨平台支持 - Windows/Linux/Mac 完美运行
✅ GUI 友好 - Windows 图形界面设置环境变量
✅ 轻量依赖 - 仅依赖 requests 库,单文件实现
✅ 安全可靠 - 标准 API 认证,无密码泄露风险
MIT License