成绩云接口开发文档

来自成绩云帮助中心
Admin讨论 | 贡献2019年1月18日 (五) 08:47的版本 更新用户

跳转至: 导航搜索

前言

本文档针对需要对接成绩云系统的平台而编写。

接入成绩云的平台需要先联系知未科技研发,获取2个基本参数:平台ID[platform],平台密钥[key]。这两个参数也可以反过来向知未科技提供。

然后提供一个接口URL前缀[apiBaseUrl],后面所有的接口都基于这个前缀。

为每一所接入学校向知未提供一个[orgId]

单点登录

Login.png


单点登录流程说明


1. 第三方平台内添加成绩云访问单点登录链接,点击链接访问成绩云。
2. 成绩云接收来自第三方的的访问参数,查询站点信息。(成绩云是分学段建立站点的;如果一个学校包含了小学、初中、高中,那么成绩云中将分别建立小学、初中、高中三个站点。成绩云分学段建立的站点将使用第三方平台给定的学校唯一标识建立站点关联关系)。
3. 第三方平台给定的学校没有包含多个学段,则开始验证用户信息。
4. 第三方平台给定的学校包含多个学段,成绩云将会显示选择站点页面。选择站点页面将列举出访问用户可选择的站点。用户选择对应的站点后,则开始验证用户信息。

接口说明


请求方法:GET
接口方向:第三方成绩云
PC版登录URL:https://chengjiyun.com/portal/[platform]?orgId=[orgId]&account=[account]&timestamp=[timestamp]&sign=[sign]
移动版登录URL:https://chengjiyun.com/mobile-portal/[platform]?orgId=[orgId]&account=[account]&timestamp=[timestamp]&sign=[sign]
访问参数:

参数 类型 是否必填 描述
orgId string 学校ID
account string 账号
type string 学段,可选值为“小学”、“初中”、“高中”。如果存在多学段且不填此字段,系统会让用户选择。
timestamp int 时间戳(Unixtime),有效时长7200秒
sign string 签名, 详见附录签名参数sign生成说明

查询用户

查询所有用户列表

成绩云仅需要4种用户角色:学生,教师,管理员,家长。
此接口是下面其它接口的超集,后面的接口通过role参数查询子集。当指定了role参数后,返回结果中,可忽略用户的角色属性。

接口说明

请求方式:GET
请求url:[apiBaseUrl]/queryUsers?orgId=[orgId]&timestamp=[timestamp]&sign=[sign]
请求参数:

参数 类型 是否必填 描述
orgId string 学校 ID
role string 角色。可选值为“学生”、“教师”、“管理员、“家长”
timestamp int 时间戳(Unixtime)
sign string 签名。详见附录签名参数sign生成说明

返回参数:

参数 类型 描述
id string 用户的唯一 ID
name string 姓名
roleList array 角色数组
schoolId string 学号。要求同一个学校内唯一
gender string 性别,可选“男”、“女”或“”(空字符串)
grade int 年级,7表示初一,10表示高一,以此类推。
class int 班级。必须为纯整数,不能含有其他字符

返回样例

{
    "code": 0,
    "msg": "success",
    "data": [
        {
            "id": "zhiwei_01",
            "schoolId": "20190101",
            "name": "刘备",
            "gender": "男",
            "grade": 10,
            "class": 1,
            "roleList": [
                "学生"
            ]
        },
        {
            "id": "zhiwei_06",
            "name": "单福",
            "roleList": [
                "管理员",
                "教师"
            ]
        },
        {
            "id": "parent_01",
            "name": "费曼",
            "roleList": [
                "家长"
            ]
        },
    ]
}


查询学生列表

接口说明

请求方式:GET
请求url: [apiBaseUrl]/queryUsers?orgId=[orgId]&timestamp=[timestamp]&role=学生&sign=[sign]
请求参数:

参数 类型 是否必填 描述
orgId string 学校 ID
role string 填“学生”
timestamp int 时间戳(Unixtime)
sign string 签名。详见附录签名参数sign生成说明

返回参数:

参数 类型 描述
id string 学生的账户 ID
schoolId string 学号。要求同一个学校内唯一
name string 姓名
gender string 性别,可选“男”、“女”或“”(空字符串)
grade int 年级
class int 班级。必须为纯整数,不能含有其他字符

返回样例

{
    "code": 0,
    "msg": "success",
    "data": [
        {
            "id": "zhiwei_01",
            "schoolId": "20190101",
            "name": "刘备",
            "gender": "男",
            "grade": 10,
            "class": 1
        },
        {
            "id": "zhiwei_02",
            "schoolId": "20190102",
            "name": "关羽",
            "gender": "男",
            "grade": 11,
            "class": 2
        },
        {
            "id": "zhiwei_03",
            "schoolId": "20190103",
            "name": "张飞",
            "gender": "男",
            "grade": 12,
            "class": 3
        }
    ]
}

查询管理员列表

接口说明

请求方式:GET
请求url: [apiBaseUrl]/queryUsers?orgId=[orgId]&timestamp=[timestamp]&role=管理员&sign=[sign]
请求参数:

参数 类型 是否必填 描述
orgId string 学校 ID
role string 填“管理员”
timestamp int 时间戳(Unixtime)
sign string 签名。详见附录签名参数sign生成说明

返回参数:

参数 类型 描述
id string 管理员的账户 ID
name string 姓名

返回样例

{
    "code": 0,
    "msg": "success",
    "data": [
        {
            "id": "zhiwei_07",
            "name": "陈大文"
        },
        {
            "id": "zhiwei_08",
            "name": "张伟"
        },
        {
            "id": "zhiwei_09",
            "name": "杨红"
        }
    ]
}


查询教师列表

接口说明

请求方式:GET
请求url: [apiBaseUrl]/queryUsers?orgId=[orgId]&timestamp=[timestamp]&role=教师&sign=[sign]
请求参数:

参数 类型 是否必填 描述
orgId string 学校 ID
role string 填“教师”
timestamp int 时间戳(Unixtime)
sign string 签名。详见附录签名参数sign生成说明

返回参数:

参数 类型 描述
id string 教师的账户 ID
name string 姓名


返回样例

{
    "code": 0,
    "msg": "成功",
    "data": [
        {
            "id": "zhiwei_04",
            "name": "孔明"
        },
        {
            "id": "zhiwei_05",
            "name": "郭嘉"
        },
        {
            "id": "zhiwei_06",
            "name": "单福"
        }
    ]
}

查询家长列表

接口说明

请求方式:GET
请求url: [apiBaseUrl]/queryUsers?orgId=[orgId]&timestamp=[timestamp]&role=家长&sign=[sign]
请求参数:

参数 类型 是否必填 描述
orgId string 学校 ID
role string 填“家长”
timestamp int 时间戳(Unixtime)
sign string 签名。详见附录签名参数sign生成说明

返回参数:

参数 类型 描述
id string 家长的账户 ID
name string 姓名
studentList array 家长关联的学生 ID数组


返回样例

{
    "code": 0,
    "msg": "success",
    "data": [
        {
            "id": "parent_01",
            "name": "费曼",
            "studentList": [
                "stu_01"
            ]
        },
        {
            "id": "parent_02",
            "name": "图灵",
            "studentList": [
                "stu_02",
                "stu_03"
            ]
        },
        {
            "id": "parent_03",
            "name": "香侬",
            "studentList": [
                "stu_04",
                "stu_05",
                "stu_06"
            ]
        }
    ]
}

更新用户

第三方平台修改用户信息后,主动推送被修改用户到成绩云进行修改。

接口说明

请求方式:POST(Content-Type:application/json)
接口方向:第三方成绩云
请求url: https://chengjiyun.com/vendor-api/update/user?orgId=[orgId]&timestamp=[timestamp]&sign=[sign]
URL参数说明:

参数 类型 是否必填 描述
orgId string 学校ID
timestamp int 时间戳(Unixtime),有效时长600秒
sign string 签名。详见附录签名参数sign生成说明

POST数据结构参数(并非所有角色都支持全部参数的修改,例如班别信息对家长角色是无效的):

参数 类型 是否必填 描述
id string 用户的唯一 id
name string 姓名
schoolId string 学号。要求同一个学校内唯一
gender string 性别,可选“男”、“女”或“”(空字符串)
grade int 年级,7表示初一,10表示高一,以此类推。
class int 班级。必须为纯整数,不能含有其他字符

请求样例

POST数据如下:

    [
        {
            "id": "zhiwei_01",
            "name": "刘备",
            "class": 2
        },
        {
            "id": "zhiwei_06",
            "name": "单福",
            "gender": "男"
        },
        {
            "id": "parent_01",
            "name": "费曼"
        },
    ]



返回样例

{
    "code": 0,
    "msg": "success",
}


查询班级任教信息列表

接口说明

请求方式:GET
请求url: [apiBaseUrl]/queryClassStatus?orgId=[orgId]&timestamp=[timestamp]&sign=[sign]
请求参数

参数 类型 是否必填 描述
orgId string 学校 ID
timestamp int 时间戳(Unixtime)
sign string 签名。详见附录签名参数sign生成说明

返回参数:

参数 类型 描述
year int 入学年份
grade int 年级
class int 班级。必须为纯整数,不能含有其他字符
headTeacher string 班主任的账户 ID
subject enum(0,1,2) 0=>未指定,1=>文科, 2=>理科
courseTeacherList object 科目任教信息. 以科目的英文名为属性, 教师的账户 ID 为 属性值的结构对象

例如:

{
 "chinese":"zhiwei_04", 
 "maths":"zhiwei_05",
 "english":"zhiwei_06"
}

支持下列科目:
"chinese"(语文)
"maths" (数学)
"english" (英语)
"physics" (物理)
"chemistry" (化学)
"biology" (生物)
"politics" (政治)
"history" (历史)
"geography" (地理)
"pe" (体育)

返回样例

{
    "code": 0,
    "msg": "success",
    "data": [
        {
            "year": 2018,
            "grade": 10,
            "class": 1,
            "headTeacher": "zhiwei_04",
            "subject": 1,
            "courseTeacherList": {
                "chinese": "zhiwei_04",
                "maths": "zhiwei_05",
                "english": "zhiwei_06"
            }
        },
        {
            "year": 2018,
            "grade": 10,
            "class": 2,
            "headTeacher": "zhiwei_05",
            "subject": 1,
            "courseTeacherList": {
                "chinese": "zhiwei_04",
                "maths": "zhiwei_05",
                "english": "zhiwei_06"
            }
        }
    ]
}

更新班级任教信息列表

常见问题

附录

签名参数sign生成说明

第一步:对传入的参数按照键名排序
第二步:使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA
第三步:在stringA最后拼接上“&key=[平台密钥]”得到stringSignTemp字符串,并对stringSignTemp进行MD5运算
第四步:得到最终请求字符串sign

PHP签名算法示例:

//$key 平台密钥
function sign($data, $key) {
  ksort($data);                                    // 正向排序
  $key_str = urldecode(http_build_query($data));  // 连接字符串
  $key_str .= '&key=' . $key;                     // 拼接key
  return md5($key_str);
}

$data = array(
   'orgId'=>'testapi',
   'account'=> 'zhiwei_01',
   'type'=> '高中',
   'timestamp'  => time(),
);
$sign = sign($data, $key);

注意:一般接口会有一个timestamp参数,如无特别说明,timestamp的有效时间为600秒(登录接口有效时常为7200秒),以降低受到重放攻击的风险。


返回结果

参数名称 类型 描述
code int 公共返回码,详见附录公共返回码
msg string 返回信息
data object 返回的查询或操作数据,数据可能是对象或数组。具体根据每个API而定。

返回示例:

{
    "code": 0,
    "msg": "success",
    "data": [
        {
            "userName": "成绩云",
            "schoolId": 101,
        }
    ]
}

公共返回码

开发者每次调用接口时,可能获得正确或错误的返回码,开发者可以根据返回码信息调试接口,排查错误。 返回码如下:

返回码(code) 消息(msg)
0 成功
10001 未知错误
10002 服务器忙
10003 服务器无响应
10004 操作超时
10005 网络异常
10006 IP地址无效或不匹配
10007 操作异常
10008 操作无效
10009 数据库操作异常
20001 没有匹配的数据
20002 数据无效
30001 接口不存在
30002 参数解析错误
30003 参数格式错误
30004 参数长度超出范围
30005 参数值内容错误
30006 验证失败
40001 用户账号不存在
40002 用户账号已经禁用