您可以使用人體檢測功能檢測圖片中所有的人體以及人體位置框和信賴度。這項技術可以應用於安全監控、人流統計等多個領域,本文介紹如何使用人體檢測功能。
使用情境
安全監控:人體檢測可以用來識別未授權的個體進入受限制或私人地區。一旦檢測到人體活動,系統可以自動發出警報並通知安保人員。
人流統計:在商場、公用場所或大型活動中,人體檢測可以用來統計人流數量,分析擁擠程度,協助管理員進行人群管理和疏散規劃。
人體檢測功能可能無法在所有情況下都保持高準確率,特別是在光線不足、遮擋或擁擠環境中。
在複雜背景或動態情境中,區分人體和其他物體可能會更加困難,容易出現誤檢。
前提條件
已建立並擷取AccessKey。具體操作,請參見建立AccessKey。
已開通OSS服務、建立儲存空間並上傳檔案到儲存空間。具體操作,請參見控制台上傳檔案。
已開通Intelligent Media Management服務。具體操作,請參見開通產品。
已通過Intelligent Media Management控制台建立專案。具體操作,請參見建立專案。
說明您也可以調用API介面建立專案。具體操作,請參見CreateProject - 建立專案。
您可以調用ListProjects - 列出所有專案資訊的列表介面列出指定地區下已建立的所有專案資訊。
使用方法
調用DetectImageBodies - 檢測圖片中的人體介面擷取靶心圖表片人體資訊。
圖片資訊
IMM專案名稱:test-project
待檢測圖片的儲存地址:oss://test-bucket/test-object.jpg
圖片樣本:

請求樣本
{
"ProjectName": "test-project",
"SourceURI": "oss://test-bucket/test-object.jpg",
"Sensitivity": 1
}返回樣本
{
"RequestId": "E9BDE106-1436-5077-9F6E-65D81DC6FEC8",
"Bodies": [
{
"Confidence": 0.733,
"Boundary": {
"Left": 115,
"Top": 97,
"Height": 103,
"Width": 63
}
},
{
"Confidence": 0.732,
"Boundary": {
"Left": 214,
"Top": 121,
"Height": 86,
"Width": 63
}
},
{
"Confidence": 0.596,
"Boundary": {
"Left": 63,
"Top": 102,
"Height": 100,
"Width": 82
}
},
{
"Confidence": 0.566,
"Boundary": {
"Left": 194,
"Top": 123,
"Height": 82,
"Width": 40
}
}
]
}檢測結果說明
返回樣本顯示在當前圖片中檢測出四個人體資訊,人體的位置如下圖所示。

範例程式碼
以Python SDK為例,人體檢測的完整範例程式碼如下。
# -*- coding: utf-8 -*-
# This file is auto-generated, don't edit it. Thanks.
import sys
import os
from typing import List
from alibabacloud_imm20200930.client import Client as imm20200930Client
from alibabacloud_tea_openapi import models as open_api_models
from alibabacloud_imm20200930 import models as imm_20200930_models
from alibabacloud_tea_util import models as util_models
from alibabacloud_tea_util.client import Client as UtilClient
class Sample:
def __init__(self):
pass
@staticmethod
def create_client(
access_key_id: str,
access_key_secret: str,
) -> imm20200930Client:
"""
使用AccessKey ID&AccessKey Secret初始化帳號Client。
@param access_key_id:
@param access_key_secret:
@return: Client
@throws Exception
"""
config = open_api_models.Config(
access_key_id=access_key_id,
access_key_secret=access_key_secret
)
# 填寫訪問的網域名稱。
config.endpoint = f'imm.cn-beijing.aliyuncs.com'
return imm20200930Client(config)
@staticmethod
def main(
args: List[str],
) -> None:
# 阿里雲帳號AccessKey擁有所有API的存取權限,建議您使用RAM使用者進行API訪問或日常營運。
# 強烈建議不要把AccessKey ID和AccessKey Secret儲存到工程代碼裡,否則可能導致AccessKey泄露,威脅您帳號下所有資源的安全。
# 本樣本通過從環境變數中讀取AccessKey,來實現API訪問的身分識別驗證。如何配置環境變數,請參見https://www.alibabacloud.com/help/document_detail/2361894.html。
imm_access_key_id = os.getenv("AccessKeyId")
imm_access_key_secret = os.getenv("AccessKeySecret")
client = Sample.create_client(imm_access_key_id, imm_access_key_secret)
detect_image_bodies_request = imm_20200930_models.DetectImageBodiesRequest(
project_name='test-project',
source_uri='oss://test-bucket/test-object.jpg',
sensitivity=1
)
runtime = util_models.RuntimeOptions()
try:
# 複製代碼運行請自行列印API的傳回值。
client.detect_image_bodies_with_options(detect_image_bodies_request, runtime)
except Exception as error:
# 如有需要,請列印錯誤資訊。
UtilClient.assert_as_string(error.message)
@staticmethod
async def main_async(
args: List[str],
) -> None:
# 阿里雲帳號AccessKey擁有所有API的存取權限,建議您使用RAM使用者進行API訪問或日常營運。
# 強烈建議不要把AccessKey ID和AccessKey Secret儲存到工程代碼裡,否則可能導致AccessKey泄露,威脅您帳號下所有資源的安全。
# 本樣本通過從環境變數中讀取AccessKey,來實現API訪問的身分識別驗證。如何配置環境變數,請參見https://www.alibabacloud.com/help/document_detail/2361894.html。
imm_access_key_id = os.getenv("AccessKeyId")
imm_access_key_secret = os.getenv("AccessKeySecret")
client = Sample.create_client(imm_access_key_id, imm_access_key_secret)
detect_image_bodies_request = imm_20200930_models.DetectImageBodiesRequest(
project_name='test-project',
source_uri='oss://test-bucket/test-object.jpg',
sensitivity=1
)
runtime = util_models.RuntimeOptions()
try:
# 複製代碼運行請自行列印API的傳回值。
await client.detect_image_bodies_with_options_async(detect_image_bodies_request, runtime)
except Exception as error:
# 如有需要,請列印錯誤資訊。
UtilClient.assert_as_string(error.message)
if __name__ == '__main__':
Sample.main(sys.argv[1:])計費說明
在人體檢測過程中, OSS 和 IMM 兩側會產生以下計費項目:
OSS 側: 詳細定價請參見OSS產品定價。
API
計費項目
說明
GetObject
GET 類型請求
根據成功的請求次數計算請求費用。
低頻訪問資料取回容量
如果取回的資料是低頻訪問資料,會產生低頻訪問資料取回容量的費用,按資料取回量計費。
歸檔直讀資料取回容量
如果讀取的是歸檔的Object且Bucket開啟了歸檔直讀,會產生歸檔直讀資料取回容量費用,根據取回的資料容量大小計費。
傳輸加速
如果開啟了傳輸加速功能且使用傳輸加速網域名稱訪問您的Bucket會產生傳輸加速費用,根據資料容量大小計費。
HeadObject
GET 類型請求
根據成功的請求次數計算請求費用。
IMM 側: 詳細定價請參見IMM計費項目。
重要自北京時間 2025 年 7 月 28 日 11:00 起,IMM 人體檢測服務將併入到圖片檢測服務中,免費模式升級為計費模式,更多資訊請參見IMM計費調整公告。
API
計費項目
說明
DetectImageBodies
ImageDetect
根據成功的請求次數計算人體檢測費用。