# 获取答题卡单道题目的答题汇总

### 接口URL

```
http://api.polyv.net/live/v3/channel/question/detail
```

### 接口说明

```
1、接口用于获取答题卡单道题目的答题汇总
2、接口支持https
```

### 请求方式

```
GET
```

### 请求参数

| 参数名        | 必选 | 类型     | 说明                                                                                                                                                                                                        |
| ---------- | -- | ------ | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| appId      | 是  | string | 从API设置中获取，在直播系统登记的appId                                                                                                                                                                                   |
| timestamp  | 是  | long   | 当前13位毫秒级时间戳，3分钟内有效                                                                                                                                                                                        |
| sign       | 是  | String | 签名，为32位大写的MD5值,`生成签名的appSecret密钥作为通信数据安全的关键信息，严禁保存在客户端直接使用，所有API都必须通过客户自己服务器中转调用POLYV服务器获取响应数据`【详见[签名生成规则](https://git.polyv.net/help-center/document-center/-/blob/master/live/api/buildSign/README.md)】 |
| channelId  | 是  | string | 频道号                                                                                                                                                                                                       |
| questionId | 是  | string | 题目ID，从题目列表中获取                                                                                                                                                                                             |
| times      | 是  | int    | 第几次的答题详情，用于同一道题发送了多次的情况，从题目列表中获取                                                                                                                                                                          |

### 响应成功JSON示例：

```json
// 成功
{
    "code": 200,
    "status": "success",
    "message": "",
    "data": {
        "question": [
            {
                "count": 155,
                "tips": "",
                "option": "7"
            },
            {
                "count": 88,
                "tips": "",
                "option": "8"
            },
            {
                "count": 24,
                "tips": "",
                "option": "9"
            },
            {
                "count": 135,
                "tips": "",
                "option": "10"
            }
        ],
        "total": 402,
        "answer": "",
        "correctRecord": 0,
        "title": "请您为选手打分",
        "type": "S",
        "itemType": 0
    }
}
```

### 响应失败JSON示例：

未输入appId

```json
{
    "code": 400,
    "status": "error",
    "message": "appId is required.",
    "data": ""
}
```

appId不正确

```json
{
    "code": 400,
    "status": "error",
    "message": "application not found.",
    "data": ""
}
```

时间戳错误

```json
{
    "code": 400,
    "status": "error",
    "message": "invalid timestamp.",
    "data": ""
}
```

签名错误

```json
{
    "code": 403,
    "status": "error",
    "message": "invalid signature.",
    "data": ""
}
```

### 字段说明

| 参数名                      | 说明                                            |
| ------------------------ | --------------------------------------------- |
| code                     | 响应的状态码，例如：200                                 |
| status                   | 响应状态                                          |
| message                  | 异常错误信息                                        |
| data                     | 响应结果集                                         |
| data.question            | 问题的各选项统计列表                                    |
| data.question\[0].option | 问题的选项                                         |
| data.question\[0].count  | 问题选项的选择数量                                     |
| data.question\[0].count  | 问题选项的提示                                       |
| data.total               | 回答问题的总数量                                      |
| data.correctRecord       | 正确回答问题的总数量                                    |
| data.answer              | 问题的答案                                         |
| data.title               | 问题内容                                          |
| data..type               | 题目类型("R":单选,"C"：多选，"S": 评分, "Q": 问答, "V": 投票) |
| data.itemType            | 答题卡为0，问答为1                                    |

### php请求示例

```php
<?php
//引用config.php
include 'config.php';
$params = array(
	'appId' => $appId,
	'timestamp' => $timestamp,
	'channelId' => 108888,
	'questionId' => "zxcvbnm",
	'times' => 1
);

//生成sign
$sign = getSign($params); //详细查看config.php文件的getSign方法
$params['sign'] = $sign;

$url = "http://api.polyv.net/live/v3/channel/question/detail?".http_build_query($params);

$curl = curl_init();
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_TIMEOUT, 500);
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_URL, $url);
$res = curl_exec($curl);
curl_close($curl);

echo $res;
?>
```
