【H5转化API】腾讯社交广告H5转化跟踪API说明文档 V2.0
chatdoc的api的用法
Chatdoc是一家专业的聊天文档管理评台,旨在帮助团队高效地协作和沟通。
其提供了丰富的API接口,使得开发者可以轻松地将Chatdoc集成到自己的应用或者服务中。
本文将介绍Chatdoc的API 用法,以便开发者能够更好地利用Chatdoc来提升团队的工作效率。
一、API注册与认证1. 开发者需要先注册一个Chatdoc的开发者账号,并且创建一个应用来获取API密钥。
2. 每次调用Chatdoc的API都需要在请求头中添加API密钥,以进行认证。
二、文档管理API1. 获取文档列表开发者可以通过调用API来获取特定团队下的所有文档列表,以便将其展示在自己的应用中。
2. 创建新文档开发者可以通过调用API来向特定团队添加新的文档,以实现自动化的文档管理。
3. 编辑文档内容通过调用API,开发者可以对特定文档的内容进行修改,从而实现自动化的文档更新。
4. 删除文档开发者可以通过调用API来删除特定文档,以便实现自己应用中的文档管理功能。
三、团队管理API1. 获取团队成员列表通过调用API,开发者可以获取特定团队下的所有成员列表,从而实现成员管理的功能。
2. 添加新成员开发者可以通过调用API来向特定团队添加新的成员,实现自动化的成员管理。
3. 删除成员通过调用API,开发者可以删除特定团队下的某个成员,实现成员管理的功能。
四、权限管理API1. 获取文档权限通过调用API,开发者可以获取特定文档的权限列表,以实现自定义的权限管理功能。
2. 修改文档权限通过调用API,开发者可以对特定文档的权限进行修改,以实现自定义的权限管理功能。
3. 角色管理开发者可以通过调用API来创建、修改、删除特定团队的角色,以实现自定义的角色管理功能。
五、事件通知API1. 订阅事件开发者可以通过调用API来订阅特定团队下的事件通知,以实现自定义的事件处理功能。
2. 处理事件通过调用API,开发者可以对收到的事件通知进行处理,从而实现自定义的事件处理功能。
MMS服务器端开发包接口API使用说明书
MMS服务器端开发包接口API使用说明书版本:V2.0深圳天勺电力软件有限公司深圳中国1.开发包简介该开发包根据已经正式发行的IEC61850最新版本开发而成,采用C语音编写,可跨平台使用。
为了最大限度地简化使用,完全封装了IEC61850中的诸多底层细节和各种复杂模型的实现逻辑。
用户利用它作开发的时候无需了解底层细节,只需要调用功能接口函数完成相应的功能研发,具有方便、快捷的优点。
本接口说明文档为接口全集,客户可以根据具体业务选择相应的接口进行调用。
本开发包既可以用在开发基于IEC61850标准的所有设备中(包括各个应用领域),也可以集成在网关机和通信管理机中。
现场运行稳定可靠,调用简单高效。
2.接口描述2.1获取节点数据路径函数函数声明char*get_path_by_node(TREE_NODE*treeNode)功能可通过该接口获取当前指定节点的路径参数TREE_NODE*treeNode:节点对象指针返回值数据路径字符串(不带fc)示例char*path=get_path_by_node(treeNode);2.2日志完整性周期服务函数函数声明void intgPdLog(SCL_INFO*ied)功能使用线程将该接口执行,可启动日志服务的完整性周期服务参数SCL_INFO*ied:模型信息对象指针返回值无示例intgPdLog(ied);2.3设置模型文件路径函数函数声明int SZTS_set_doc_path(char*theDocPath)功能设置模型文件路径,用于解析指定的模型文件参数char*theDocPath:模型文件路径返回值成功:1,失败:0示例int result=SZTS_set_doc_path(theDocPath);2.4获取设备节点函数函数声明SCL_INFO*SZTS_get_all_ied_node()功能解析模型文件中的IED节点,做成链表,并返回链表的头节点参数无返回值模型文件中IED节点链表头节点示例SCL_INFO*sclInfo=SZTS_get_all_ied_node();2.5拷贝树函数函数声明TREE_NODE*cp_tree_node_link(TREE_NODE*srcHead)功能拷贝一个树对象的全部信息参数TREE_NODE*srcHead:需要拷贝树对象的头节点返回值拷贝出来的树对象的头节点示例TREE_NODE*treeNode=cp_tree_node_link(srcHead);2.6通过路径获取节点函数函数声明TREE_NODE*get_tree_node_by_path(char*path)功能可获取指定路径的节点对象参数char*path:需要获取的节点的路径(不带FC)返回值路径对应的节点对象示例TREE_NODE*treeNode=get_tree_node_by_path(path);2.7通过路径获取节点函数函数声明TREE_NODE*get_tree_node_by_path_new(char*path)功能可获取指定路径的节点对象参数char*path:需要获取的节点的路径(带FC)返回值路径对应的节点对象示例TREE_NODE*treeNode=get_tree_node_by_path_new(path);2.8获取当前时间函数函数声明char*get_time()功能获取字符串时间格式的当前系统时间参数无返回值字符串时间格式的当前系统时间示例char*nowTime=get_time();2.9获取报告控制块信息函数函数声明RPT_CTRL*get_rpt_ctrl_by_ied_name(char*iedName)功能解析模型文件中指定的IED节点下的全部报告控制块,并生成链表,返回链表的头节点参数char*iedName:设备IED节点名称返回值指定IED节点下的报告控制块链表头节点示例RPT_CTRL*rptCtrl=get_rpt_ctrl_by_ied_name(iedName);2.10根据报告控制块最大使能数拷贝报告控制块信息节点函数函数声明RPT_CTRL*copy_rpt_ctrl_link(RPT_CTRL*head)功能按照模型文件中的最大使能报告控制块的参数配置,处理并实例化出对应最大使能个数的报告控制块参数RPT_CTRL*head:报告控制块链表的头节点返回值经过拷贝处理后的报告控制块链表的头节点示例RPT_CTRL*cp=copy_rpt_ctrl_link(head);2.11获取模型节点信息函数函数声明TREE_NODE*get_tree_node_link_by_ied_name(char*iedName)功能解析模型文件中指定的IED节点的全部数据对象节点,并生成树对象,返回树对象的头节点参数char*iedName:设备IED节点名称返回值指定IED节点下的模型节点树结构的头节点示例TREE_NODE*treeNode=get_tree_node_link_by_ied_name(iedName);2.12获取定值控制块信息函数函数声明SETTING_CTRL*get_setting_ctrl_by_ied_name(char*iedName)功能解析模型文件中指定的IED节点下的全部定值控制块,并生成链表,返回链表的头节点参数char*iedName:设备IED节点名称返回值指定IED节点下的定值控制块链表头节点示例SETTING_CTRL*settingCtrl=get_setting_ctrl_by_ied_name(iedName);2.13获取日志控制块信息函数函数声明LOG_CTRL*get_log_ctrl_by_ied_name(char*iedName)功能解析模型文件中指定的IED节点下的全部日志控制块,并生成链表,返回链表的头节点参数char*iedName:设备IED节点名称返回值指定IED节点下的日志控制块链表头节点示例LOG_CTRL*logCtrl=get_log_ctrl_by_ied_name(iedName);2.14获取数据集信息函数函数声明DATASET*get_dataSet_by_ied_name(char*iedName)功能解析模型文件中指定的IED节点下的全部数据集,并生成链表,返回链表的头节点参数char*iedName:设备IED节点名称返回值指定IED节点下的数据集链表头节点示例DATASET*dataset=get_dataSet_by_ied_name(iedName);2.15设置创建数据集保存路径函数函数声明int SZTS_set_create_dataSet_save_path(char*path)功能自主创建的数据集保存的dataSet.xml文件的所在路径,用于解析自主创建的数据集信息参数char*path:自主创建的数据集保存的dataSet.xml文件的所在路径返回值成功:1,失败:0示例int result=SZTS_set_create_dataSet_save_path(path);2.16解析创建的持久数据集函数函数声明void get_dataSet_self(DATASET*dataSetHead,SCL_INFO*ied)功能解析创建并保存在dataSet.xml中的自主创建的持久型数据集参数DATASET*dataSetHead:数据集链表头节点SCL_INFO*ied:指定得IED设备对象节点返回值无示例get_dataSet_self(dataSetHead,ied);2.17获取GOOSE函数函数声明GOOSE_INFO*get_goose_info_link_by_ied_name(char*iedName)功能解析模型文件中指定的IED节点下的全部GOOSE控制块,并生成链表,返回链表的头节点参数char*iedName:设备IED节点名称返回值指定IED节点下的GOOSE控制块链表头节点示例GOOSE_INFO*goossInfo=get_goose_info_link_by_ied_name(iedName);2.18获取SV函数函数声明SMV_INFO*get_smv_info_link_by_ied_name(char*iedName)功能解析模型文件中指定的IED节点下的全部MSV控制块,并生成链表,返回链表的头节点参数char*iedName:设备IED节点名称返回值指定IED节点下的MSV控制块链表头节点示例SMV_INFO*smvInfo=get_smv_info_link_by_ied_name(iedName);2.19设置模型节点的实例化初始值函数函数声明void set_instance_val_to_node(char*iedName)功能对指定的IED节点下的树对象中的数据节点,赋予模型文件中实例化部分对应的实例化值参数char*iedName:设备IED节点名称返回值无示例set_instance_val_to_node(iedName);函数声明S_ADDR_MAP*get_s_addr_map(char*iedName)功能解析模型文件中短地址,并与对应的点的索引路径形成映射关系,生成链表,并返回链表的头节点参数char*iedName:设备IED节点名称返回值短地址与节点路劲映射的链表的头节点(节点路径不带FC)示例S_ADDR_MAP*sAddr=get_s_addr_map(iedName);2.21缓存报告服务函数函数声明void buffDataReport(SCL_INFO*ied)功能开启缓存报告的缓存事件以及缓存报告的发送服务,该方法内部通过while 循环进行间歇遍历,无退出动作,建议使用独立线程启动该服务参数SCL_INFO*ied:设备IED节点对象返回值无示例buffDataReport(ied);2.22非缓存报告服务函数函数声明void unBuffDataReport_bufTm(SCL_INFO*ied)功能开启非缓存报告的缓存事件以及其缓存事件报告的发送服务,该方法内部通过while循环进行间歇遍历,无退出动作,建议使用独立线程启动该服务参数SCL_INFO*ied:设备IED节点对象返回值无示例unBuffDataReport_bufTm(ied);2.23完整性周期报告服务函数函数声明void unBuffDataReport_bufTm(SCL_INFO*ied)功能开启非缓存报告的缓存事件以及其缓存事件报告的发送服务,该方法内部通过while循环进行间歇遍历,无退出动作,建议使用独立线程启动该服务参数SCL_INFO*ied:设备IED节点对象返回值无示例unBuffDataReport_bufTm(ied);函数声明CFG_FILE*SZTS_readCfgFile(char*fileName)功能解析配置文件的信息,并生成存放配置文件信息的内存对象参数char*fileName:.cfg后缀的配置文件的路径返回值配置文件的信息对象示例CFG_FILE*cfgInfo=SZTS_readCfgFile(fileName);2.25解析获取模型文件函数函数声明SCL_INFO*SZTS_sclParse(CFG_FILE*cfgFile)功能解析配置文件中配置的模型文件路径、设备名,访问点对应的模型文件的全部数据节点信息,生成链表对象,并返回链表头节点参数CFG_FILE*cfgFile:.cfg配置文件信息对象返回值设备信息对象链表头节点示例SCL_INFO*sclInfo=SZTS_sclParse(cfgFile);2.26启动服务器函数函数声明int SZTS_startServer()功能开启服务器监听和接收消息服务,服务器对象默认为模型文件中的第一个IED,该方法内部通过while循环进行间歇遍历,无退出动作,建议使用独立线程启动该服务参数无返回值有返回值即为服务运行结束,无返回值即为服务运行中示例int result=SZTS_startServer();2.27启动指定的服务器函数函数声明int SZTS_start_server_by_ied(SCL_INFO*ied)功能开启服务器监听和接收消息服务,服务器对象为指定的一个IED,该方法内部通过while循环进行间歇遍历,无退出动作,建议使用独立线程启动该服务参数SCL_INFO*ied:设备IED节点对象返回值有返回值即为服务运行结束,无返回值即为服务运行中示例int result=SZTS_start_server_by_ied(ied);2.28停止服务器函数声明int SZTS_stopServer()功能停止服务器监听和接收消息服务,停止的服务器对象默认为模型文件中的第一个IED参数无返回值有返回值即为服务运行结束,无返回值即为服务运行中示例int result=SZTS_stopServer();2.29停止指定的服务器函数函数声明int SZTS_stop_server_by_ied(SCL_INFO*ied)功能停止服务器监听和接收消息服务,停止的服务器对象为指定的一个IED 参数SCL_INFO*ied:设备IED节点对象返回值有返回值即为服务运行结束,无返回值即为服务运行中示例int result=SZTS_stop_server_by_ied(ied);2.30设置对应路径模型节点值函数函数声明int setNodeValueByPath(char*path,char*value)功能通过节点路径更新节点值,方法内部校验并处理相关的非缓存报告、缓存报告、日志业务参数char*path:需要修改的节点路径(带FC)char*value:目标值返回值1:改值成功,0:改值失败示例int result=setNodeValueByPath(path,value);2.31设置对应路径模型节点值-只设置值函数函数声明int setNodeValueByPathOnly(char*path,char*value)功能通过节点路径更新节点值,只更新值,不产生报告事件、日志事件参数char*path:需要修改的节点路径(带FC)char*value:目标值返回值1:改值成功,0:改值失败示例int result=setNodeValueByPathOnly(path,value);2.32获取设备mac地址函数函数声明void get_mac_address(char*mac_address)功能获取当前设备的mac地址,存放到指定的内存空间参数char*mac_address:已分配可容纳mac地址空间的字符串指针返回值设备mac地址示例get_mac_address(char*mac_address);2.33缓存报告控制块的预留时间超时校验函数函数声明void handle_buffer_rptCtrl_client_resv_check()功能开启缓存报告控制块预留时间的超时检测机制服务,对每个TCP连接在关联过缓存报告控制块的情况中,在失去关联时,进行设定的缓存报告控制块预留时间进行超时校验,在超时时间到达前,除最近一次关联过该缓存报告控制块的TCP连接可设置并使用该缓存报告控制块,其他的TCP连接不可设置和使用;倘若在超时间内最近一次关联该缓存报告控制块的TCP连接未继续关联该缓存报告控制块,则取消预留限制,任何TCP连接均可对此缓存报告控制块进行设置和使用;该方法内部通过while循环进行间歇遍历,无退出动作,建议使用独立线程启动该服务参数无返回值无示例handle_buffer_rptCtrl_client_resv_check();2.34客户端连接信息回调函数函数原型定义typedef int(*connectInfoFun)(char*ip,int port,int status);函数全局变量connectInfoFun connectInfo_fun;注册回调函数方法extern int regist_connectInfoFun(connectInfoFun f);输入char*ip:连接过来的客户端ipint port:连接过来的客户端端口int status:连接过来的客户端状态返回预留返回值,未使用用途可通过该回调获得客户端的连接信息2.35接收客户端报文信息回调函数函数原型定义typedef int(*recvDataFun)(char*data,int length);函数全局变量recvDataFun recvData_fun;注册回调函数方法extern int regist_recvDataFun(recvDataFun f);输入char*data:接收的报文数据int length:接收的报文长度返回预留返回值,未使用用途可通过该回调获得客户端的请求报文信息2.36判断否允许写入文件回调函数函数原型定义typedef int(*fileDataIsOkFun)(char*path);函数全局变量fileDataIsOkFun fileDataIsOk_fun;注册回调函数方法extern int regist_fileDataIsOkFun(fileDataIsOkFun f);输入char*path:文件路径返回1:允许写文件操作,0:不允许写文件操作用途可通过该回调可实现对写文件动作的允许与否2.37遥控选择回调函数函数原型定义typedef int(*selectFun)(char*reference);函数全局变量selectFun select_fun;注册回调函数方法extern int regist_selectFun(selectFun f);输入char*reference:遥控点路径返回1:允许选择,0:不允许选择用途可通过该回调实现对遥控选择的判断介入2.38遥控带值选择回调函数函数原型定义typedef int(*selectWithValueFun)(char*reference,Data*ctlVal,int*addCase);函数全局变量selectWithValueFun selectWithValue_fun;注册回调函数方法extern int regist_selectWithValueFun(selectWithValueFun f);输入char*reference:遥控点路径Data*ctlVal:控制值输出int*addCase:不允许选择原因返回1:允许带值选择,0:不允许带值选择用途可通过该回调实现对遥控带值选择的判断介入2.39遥控取消回调函数函数原型定义typedef int(*cancelFun)(char*reference,Data*ctlVal,int*addCase);函数全局变量cancelFun cancel_fun;注册回调函数方法extern int regist_cancelFun(cancelFun f);输入char*reference:遥控点路径Data*ctlVal:控制值输出int*addCase:不允许取消原因返回1:允许取消,0:不允许取消用途可通过该回调实现对遥控取消的判断介入2.40遥控执行回调函数函数原型定义typedef int(*operateFun)(char*reference,Data*ctlVal,int*addCase);函数全局变量operateFun operate_fun;注册回调函数方法extern int regist_operateFun(operateFun f);输入char*reference:遥控点路径Data*ctlVal:控制值输出int*addCase:不允许遥控执行的原因返回1:允许遥控执行,0:不允许遥控执行用途可通过该回调实现对遥控执行的判断介入2.41定值切区回调函数函数原型定义typedef int(*selectActiveSgFun)(char*reference,int sgNumber);函数全局变量selectActiveSgFun selectActiveSg_fun;注册回调函数方法extern int regist_selectActiveSgFun(selectActiveSgFun f);输入char*reference:定值控制块路径int sgNumber:切区的区号返回预留返回值,未使用用途可通过该回调获取定值切区的相关信息2.42改值操作回调函数函数原型定义typedef int(*setDataValuesFun)(char*reference,char*fc);函数全局变量setDataValuesFun setDataValues_fun;注册回调函数方法extern int regist_setDataValuesFun(setDataValuesFun f);输入char*reference:改值对象的路径char*fc:改值对象的FC返回1:允许改值,0:不允许改值用途可通过该回调实现改值操作的判断介入2.43改值操作回调-sv取代函数函数原型定义typedef int(*setSVDataValuesFun)(char*reference,char*value);函数全局变量setSVDataValuesFun setSVDataValues_fun;注册回调函数方法extern int regist_setSVDataValuesFun(setSVDataValuesFun f);输入char*reference:改值对象的路径char*value:目的值返回1:允许改值,0不允许改值用途:可通过该回调实现取代的业务逻辑,在改值操作时,优先执行此回调中实现的取代业务。
微信h5网页自定义分享(标题、描述、图标)
微信h5⽹页⾃定义分享(标题、描述、图标)⼀、绑定域名先登录微信公众平台进⼊“公众号设置”的“功能设置”⾥填写“JS接⼝安全域名”。
注:登录后可在“开发者中⼼”查看对应的接⼝权限。
⼆、引⼊JS⽂件三、引⼊封装好的⽅法require_once "jssdk.php";$jssdk = new JSSDK("appid", "app密钥");$signPackage = $jssdk->GetSignPackage();四、jssdk.php<?phpclass JSSDK {private $appId;private $appSecret;public function __construct($appId, $appSecret) {$this->appId = $appId;$this->appSecret = $appSecret;}public function getSignPackage() {$jsapiTicket = $this->getJsApiTicket();// 注意 URL ⼀定要动态获取,不能 hardcode.$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";$url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";$timestamp = time();$nonceStr = $this->createNonceStr();// 这⾥参数的顺序要按照 key 值 ASCII 码升序排序$string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr×tamp=$timestamp&url=$url";$signature = sha1($string);$signPackage = array("appId" => $this->appId,"nonceStr" => $nonceStr,"timestamp" => $timestamp,"url" => $url,"signature" => $signature,"rawString" => $string);return $signPackage;}private function createNonceStr($length = 16) {$chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";$str = "";for ($i = 0; $i < $length; $i++) {$str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);}return $str;}private function getJsApiTicket() {// jsapi_ticket 应该全局存储与更新,以下代码以写⼊到⽂件中做⽰例$data = json_decode($this->get_php_file("jsapi_ticket.php"));if ($data->expire_time < time()) {$accessToken = $this->getAccessToken();// 如果是企业号⽤以下 URL 获取 ticket// $url = "https:///cgi-bin/get_jsapi_ticket?access_token=$accessToken";$url = "https:///cgi-bin/ticket/getticket?type=jsapi&access_token=$accessToken";$res = json_decode($this->httpGet($url));$ticket = $res->ticket;if ($ticket) {$data->expire_time = time() + 7000;$data->jsapi_ticket = $ticket;$this->set_php_file("jsapi_ticket.php", json_encode($data));}} else {$ticket = $data->jsapi_ticket;}return $ticket;}private function getAccessToken() {// access_token 应该全局存储与更新,以下代码以写⼊到⽂件中做⽰例$data = json_decode($this->get_php_file("access_token.php"));if ($data->expire_time < time()) {// 如果是企业号⽤以下URL获取access_token// $url = "https:///cgi-bin/gettoken?corpid=$this->appId&corpsecret=$this->appSecret";$url = "https:///cgi-bin/token?grant_type=client_credential&appid=$this->appId&secret=$this->appSecret";$res = json_decode($this->httpGet($url));$access_token = $res->access_token;if ($access_token) {$data->expire_time = time() + 7000;$data->access_token = $access_token;$this->set_php_file("access_token.php", json_encode($data));}} else {$access_token = $data->access_token;}return $access_token;}private function httpGet($url) {$curl = curl_init();curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);curl_setopt($curl, CURLOPT_TIMEOUT, 500);// 为保证第三⽅服务器与微信服务器之间数据传输的安全性,所有微信接⼝采⽤https⽅式调⽤,必须使⽤下⾯2⾏代码打开ssl安全校验。
腾讯对外接口API文档
打开以下网址,输入您的腾讯绑定帐号以及密码:/index.php/API%E6%96%87%E6%A1%A3类似这样的:API文档返回出自腾讯微博开放平台跳转到:导航, 搜索OAuth授权时间线微博相关帐户相关关系链相关私信相关搜索相关热度,趋势数据更新相关数据收藏话题相关标签相关名单微群相关邀请相关LBS相关其他文档更新历史API问题QA错误码说明表情列表下载OAuth授权request_token 获取request_tokenauthorize 用户授权request_tokenaccess_token 交换access_tokenaccess_token 交换access_token点击查看示例API请求示例说明auth/get_oauth2_token 通过oAuth1.0的token获取oAuth2.0的token时间线statuses/home_timeline 主页时间线statuses/public_timeline 广播大厅时间线statuses/user_timeline 其他用户发表时间线statuses/mentions_timeline 用户提及时间线statuses/ht_timeline 话题时间线(建议使用新话题时间线接口ht_timeline_ext) statuses/broadcast_timeline 我发表时间线statuses/special_timeline 特别收听的人发表时间线statuses/area_timeline 地区发表时间线statuses/home_timeline_ids 主页时间线索引statuses/user_timeline_ids 其他用户发表时间线索引statuses/broadcast_timeline_ids 我发表时间线索引statuses/mentions_timeline_ids 用户提及时间线索引statuses/users_timeline 多用户发表时间线statuses/users_timeline_ids 多用户发表时间线索引statuses/ht_timeline_ext 话题时间线statuses/home_timeline_vip 拉取vip用户发表微博消息接口statuses/sub_re_list 获取二传手列表(获取转播或评论的再次转播或评论列表)微博相关t/show 获取一条微博数据t/add 发表一条微博t/del 删除一条微博t/re_add 转播一条微博t/reply 回复一条微博(即对话)t/add_pic 发表一条带图片的微博t/re_count 转播数或点评数t/re_list 获取单条微博的转发或点评列表t/comment 点评一条微博t/add_music 发表音乐微博t/add_video 发表视频微博t/getvideoinfo 获取视频信息t/list 根据微博id批量获取微博内容(与索引合起来用)t/sub_re_count 获取转播的再次转播数(二次转发次数)t/add_emotion 发表心情帖子t/add_pic_url 用图片URL发表带图片的微博t/add_multi 多类型发表(可同时发表带音频、视频、图片的微博)帐户相关user/info 获取自己的详细资料user/update 更新用户信息user/update_head 更新用户头像信息user/update_edu 更新用户教育信息user/other_info 获取其他人资料user/infos 获取一批人的简单资料user/verify 验证账户是否合法(是否注册微博)user/emotion 获取心情微博关系链相关friends/fanslist 我的听众列表friends/fanslist_name 我的听众列表,只输出namefriends/idollist 我收听的人列表friends/idollist_name 我收听的人列表,只输出namefriends/blacklist 黑名单列表friends/speciallist 特别收听列表friends/add 收听某个用户friends/del 取消收听某个用户friends/addspecial 特别收听某个用户friends/delspecial 取消特别收听某个用户friends/addblacklist 添加某个用户到黑名单friends/delblacklist 从黑名单中删除某个用户friends/check 检测是否我的听众或收听的人friends/user_fanslist 其他帐户听众列表friends/user_idollist 其他帐户收听的人列表friends/user_speciallist 其他帐户特别收听的人列表friends/fanslist_s 我的听众列表,简单信息(200个)friends/idollist_s 我的收听列表,简单信息(200个)friends/mutual_list 互听关系链列表friends/match_nick_tips 好友账号及昵称输入提示私信相关private/add 发私信private/del 删除一条私信private/recv 收件箱private/send 发件箱搜索相关search/user 搜索用户search/t 搜索微博search/userbytag 通过标签搜索用户热度,趋势trends/ht 话题热榜trends/t 转播热榜trends/famouslist 推荐名人列表数据更新相关info/update 查看数据更新条数数据收藏fav/addt 收藏一条微博fav/delt 取消收藏一条微博fav/list_t 收藏的微博列表fav/addht 订阅话题fav/delht 取消订阅话题fav/list_ht 获取已订阅话题列表话题相关ht/ids 根据话题名称查询话题idht/info 根据话题id获取话题相关信息标签相关tag/add 添加标签tag/del 删除标签名单list/list_followers 名单订阅成员列表信息list/myfollowlist 我订阅的名单信息list/create 创建名单list/delete 删除名单list/edit 修改名单list/get_list 查询我创建的名单list/check_user_in_list 筛选指定的用户是否在名单中list/list_attr 名单属性信息list/follow 订阅多个名单list/undo_follow 取消订阅多个名单list/add_to_list 收录指定用户到名单list/del_from_list 从名单中删除指定用户list/get_other_in_list 查询指定用户所在的所有listlist/listusers 查询名单成员列表list/list_info 查询指定微博用户的名单相关信息微群相关weiqun/add 在微群中发表微博消息weiqun/apply4group 申请加入微群weiqun/bindqqgroup 微群与Q群互绑定weiqun/del 删除微群中的微博weiqun/home_timeline 微群主页时间线weiqun/multihome_timeline 多微群主页时间线weiqun/quitgroup 退出微群weiqun/setbulletin 设置微群公告weiqun/setmemattr 设置微群成员属性邀请相关invite/get_invite_list 获取好友列表invite/event_invite 发送好友邀请LBS相关LBS相关接口使用说明文档lbs/update_pos 更新地理位置lbs/del_pos 删除最后更新位置lbs/get_poi 获取POI(Point of Interest)lbs/get_around_new 获取身边最新的微博lbs/get_around_people 获取身边的人其他other/kownperson 我可能认识的人other/shorturl 短url变长urlother/videokey 获取视频上传的keyother/get_emotions 获取表情接口other/gettopreadd 一键转播热门排行other/follower_trans_conv 拉取我收听的用户的转播消息接口other/quality_trans_conv 拉取精华转播消息接口other/vip_trans_conv 拉取vip用户的转播消息接口other/url_converge 短url聚合other/gettopiczbrank 同话题热门转播排行文档更新历史API问题QA错误码说明表情列表下载取自“/index.php/API%E6%96%87%E6%A1%A3”帐户相关/取消收听某个用户返回出自腾讯微博开放平台跳转到:导航, 搜索目录[隐藏]∙ 1 请求说明∙ 2 参数说明∙ 3 使用说明∙ 4 返回结果∙ 5 字段说明请求说明url /api/friends/del格式xml,jsonhttp请求方式post是否需要鉴权true请求数限制true关于请求数限制,参见接口访问权限说明参数说明请求参数:oauth或openid&openkey标准参数,并带上以下参数format 返回数据的格式(json或xml)name 他人的帐户名(可选)他人的openid(可选)fopenidname和fopenid至少选一个,若同时存在则以name值为主使用说明/api/friends/delpost包体格式为:format=json&name=xxxx&fopenid=xxxx返回结果{ret:0,msg:"ok",errcode:0}字段说明ret: 返回值,0-成功,非0-失败msg:错误信息errcode:返回错误码errcode:发表失败错误码参看文档最后说明,点击此处查看取自“/index.php/%E5%B8%90%E6%88%B7%E7%9B%B8%E5%85%B3/%E5 %8F%96%E6%B6%88%E6%94%B6%E5%90%AC%E6%9F%90%E4%B8%AA%E7%94%A8%E6%88%B 7”。
google api 用法
google api 用法Google API(Application Programming Interface)是谷歌提供的一组开发者工具和功能,用于与谷歌服务进行交互和访问。
谷歌提供了多个API,包括地图API、语音识别API、人工智能API等等。
这些API可以被开发者用来构建各种应用,从地图应用到语音助手,都可以使用谷歌API来实现。
使用Google API之前,首先需要创建一个开发者账号,并获取API密钥,该密钥用于验证开发者的身份和授权访问谷歌服务。
接下来,我们将介绍一些常用的Google API以及其用法。
1. Google Maps API:Google Maps API是用于在自己的网站或应用中嵌入地图功能的API。
可以使用Google Maps API来实现地理定位、地点搜索、路线规划等功能。
开发者可以使用HTML、JavaScript和CSS来定制地图的外观和交互方式。
2. Google Translate API:Google Translate API可以将文本翻译成多种语言。
可以使用这个API来开发翻译应用,让用户能够快速翻译文本到其他语言。
通过调用Translate API提供的接口,可以实现自动翻译功能。
3. Google Calendar API:Google Calendar API可以让开发者读取、写入和修改Google日历中的事件。
可以使用Calendar API来创建和管理用户的日程安排,可以实现日历应用、待办事项管理等功能。
4. Google Drive API:Google Drive API可以让开发者访问和操作用户的Google Drive云存储空间。
可以使用Drive API来上传、下载、删除和修改用户的文件,可以实现文件管理应用、在线协作编辑等功能。
5. Google Cloud Speech-to-Text API:Google Cloud Speech-to-Text API可以将语音转换为文本。
面对潜在用户量破亿的微信和QQ,H5开发者该如何做产品立项与适配?课堂笔记
面对潜在用户量破亿的微信和QQ,H5开发者该如何做产品立项与适配?课堂笔记以下为内容整理:正如之前说的,QQ玩一玩的前身是厘米游戏,目前已经有很多成品游戏了。
它的主要入口包括2个:1.在QQ游戏中心的下方,会有QQ玩一玩的入口。
2.在2人对话时,玩家可以通过对话框之中的加号功能进入QQ 玩一玩。
QQ玩一玩平台采用的是QQ自研的runtime引擎来进行运行,它本身并不是H5。
通过调用引擎的API,在上层加入JS接口,通过JS便可以直接进行使用。
Layabox在17年8月份就完成了对它的适配支持工作,在目前我们最新的IDE中,用户可以通过项目发布功能一键发布QQ玩一玩。
这张图是QQ玩一玩、微信小游戏和H5游戏之间的重点差异对比。
首先从运行环境来看,微信小游戏和QQ玩一玩都是Runtime的,它们的产品不支持在浏览器中运行;相比之下,H5游戏则是在浏览器或者是webView中去运行。
在本地包方面也有差异。
微信小游戏最多支持4M的本地包体,QQ玩一玩本地包体则最多可以达到10M,目前推荐4到5M。
H5游戏不支持本地包,运行过程都是动态资源加载。
本地缓存也有所区别。
微信小游戏最多支持50M的本地缓存,也就是说,在首次加载后,开发者可以自己去管理这部分的动态缓存。
相比之下,QQ玩一玩也支持本地缓存,但目前还没有设定相关限制,在春节后推出正式版本后可能会颁布相关规则。
在缓存管理上,微信小游戏和QQ玩一玩中,开发者都可以自己去管理缓存,但开发者是不能对H5缓存进行管理的。
在3D支持方面,H5游戏支持得最好。
就我们来说,在3D方面,通过WebGL,Layabox已经上线了不少商业级的案例了。
相比之下,微信小游戏目前在3D方面支持得比较少,尤其对于复杂3D内容,目前微信小游戏还不太能给出太多的支持方案,因此3D微信小游戏一般来说都比较轻度。
QQ玩一玩正在做通过WebGL支持3D的相关工作,至于能支持到什么程度,目前还不是很清楚。
“互联网+”背景下传统广告模式的创新之道——以华龙网H5广告“老重庆问答穿越之旅”为例
新媒介技术推进社会变革,也冲击着传统广告经营。
传统广告模式无法适应用户阅读习惯,导致广告量大幅缩水。
H5广告的诞生为广告经营模式开创了更多可能,迎来新的发展机遇。
H5广告,是指基于H5编码技术的一种新媒体广告形式,泛指在网络社交媒体中带有声效、特效和互动体验的web 网页,支持手机端和PC 端两大新媒体平台接口。
一、华龙网H5广告“老重庆问答穿越之旅”的策划制作2021年2月,华龙网迎春巨制,出品H5广告“老重庆问答穿越之旅”(以下简称“老重庆”),以游戏互动的方式展现“金夫人”品牌形象,其广告的强隐匿性和3D 动画的趣味性,引发朋友圈转发和分享热潮。
“老重庆”于2月1日正式上线,2月7日结束,活动期间日均浏览量18万。
截至2月7日,参与互动次数52681次,参与抽奖人次为71390人次,“金夫人”品牌形象曝光达历史新高。
“老重庆”成为低成本、高效果的H5广告范例。
1989年,“金夫人”品牌诞生在重庆解放碑邹容路,它伴随着改革开放,见证了重庆人三十多年消费观念的改变,是重庆变革发展的标签,品牌本身即是老重庆的一部分。
H5广告“老重庆”将“金夫人”品牌形象嫁接到问答之中,赋予其历史厚重感,浸润无声地向用户注入品牌情感。
“老重庆”主打“回忆杀”感情牌,迎合大众社会心理。
产品发布于春节前夕,年味气息日渐浓厚,网民对“春节”、“家乡”等话题关注度达年度最高。
在内容上,“老重庆”设置十个涵盖重庆吃、穿、住、用、行的问答,通过重庆方言和老重庆场景的绘画还原,串联两代人的老重庆记忆,激发用户主动参与的积极性。
二、华龙网H5广告“老重庆”的精妙之处传统广告陷入危机,其自身弊端为主要因素。
传统广告属于大众传播,没有精准的用户画像,而且由于版面和播出时长限制、单向传播等因素,导致传统广告很难给受众留下深刻的印象。
华龙网H5广告“老重庆”的成功,得益于其【摘要】互联网技术的深入发展改变了传媒格局,广告的形式也更加多元。
腾讯广告产品手册说明书
Tencent Marketing Solution腾讯广告产品手册美好连接智慧增长Content目录01-10 01腾讯广告11-16 02QQ广告17-24 03微信广告25-30 04腾讯视频广告31-36 05腾讯新闻广告37-42 06腾讯看点广告43-48 07腾讯优量广告49-54 08腾讯音乐广告01腾讯广告介绍Tencent Marketing Solution腾讯广告承载覆盖11亿+受众的微信、QQ等领先社交平台,及腾讯新闻、腾讯视频、腾讯看点、腾讯音乐以及合作伙伴应用等丰富广告场景。
通过触达目标受众和提供创新的原生广告体验,帮助广告主实现他们的商业目标。
全景连接腾讯广告为广告主提供丰富的场景触点,实现社交、资讯、娱乐、支付、工具等全景互动,线上线下一体触达。
全民K歌天天P图腾讯看点腾讯电脑管家优量汇QQ浏览器腾讯视频腾讯新闻酷我音乐腾讯体育企鹅电竞QQ音乐腾讯微视腾讯WiFi 管家王者荣耀企鹅FM 微信QQAdvantages核心优势Tencent Marketing Solution腾讯广告将IP内容、小程序、支付、AI、AR等创新应用于营销场景中,助力广告主打造以消费者为中心依托覆盖全国11亿+网民的腾讯账号体系和多维标签体系,腾讯广告将数据技术充分应用到策略、创意、了解消费者腾讯广告产品手册针对数据管理、智能投放、创意制作、落地页制作、线索管理、账号管理等各环节提供丰富的产品能力,帮助广告主高效达成营销目标。
数据管理帮助客户精准创建和高效管理广告定向人群的平台,同时提供洞察人群画像、投放后人群及广告效果分析等功能。
接口服务Tencent Marketing AP I是腾讯广告向营销客户提供的一套接口服务,提供了完整的数据上报、数据报表投放及投放管理功能。
账号管理面向广告主构建的包括统一管理账号、数据、用户、多类型资产等需求的腾讯广告账号管理系统。
商务管家(BM)腾讯广告数据管理平台(DMP)Tencent Marketing APIKey Products重点产品统一管理账号10W+统一数据统一多类型资产统一用户数据报表投放管理投放数据上报Tencent Marketing Solution线索管理Tencent Marketing Solution腾讯广告为广告主提供线索收集、线索管理、线索应用等线索转化全链路解决方案,丰富线索收集通路,并针对线索进行智能化管理和分析,并探索多个线索应用新场景,形成线索转化营销闭环。
2345团购导航合作API操作手册
2345团购导航合作api手册v4.0一、API正文字体蓝色为注释性语句,红色为注意事项。
<申明: API4.0格式不是xml形式或 html形式的, 所以抓取方式是逐行读取数据内容而不是根据xml的节点或其他方式。
因此请开发时千万别走入误区。
API格式如下:>二、API举例范例说明:ver=4.0<url>X团上海餐饮美食仅售36.9元!英国女王、戴安娜王妃最爱:原价85元皇家御用CYCLAX绿茶面颈滋润霜!神奇抹去颈部细纹,网上超爆人气,狂卖/static/team/2010/0830/12831375661943.jpg12995513331299551333150.0050.003.02221299551333 1299551333200商品描述商品提示六一淮海路北京西路235弄38号广汇广场北京西路235弄38号广汇广场021-435966 021-435833</url>三、各字段名说明四、API分类说明五、API制作注意事项1、每个产品由<url>开始</url>结束,其中间包含36个字段信息,每个字段信息一行,所以每个产品中间务必只有36行,每行内容最后请用回车换行符("\r\n")结束,每行数据的内容中如果有回车换行符("\r\n"、"\r"、"\n")请替换成字符串"<br>"。
2、所有非数字选填项没有则为空,数字的选填项没有则填03、请在文件开头加上ver=版本号(目前为4.0),不加版本号的API将视为无效API。
4、严格按照标准制作可以帮助您更好更快的抓取商品,所以请严格对照标准来制作api,认真填写每一行数据.由于导航站每日编辑处理的数据众多,因为格式错误或api错误造成图片无法显示的情况,我们会予以删除.所以会影响您的广告及收录质量,请您认真对待API的内容.5、图片无法抓取的情况,主要有以下几个方面的原因:<1>图片地址必须为绝对路径,请不要使用相对地址<2>扩展名必须为jpg,gif或png,请不要使用其他后缀名,<3>图片不要太大,2345的图片标准格式大小为440X282,请在保证清晰的情况下保持大于等于此比例,图片质量越小抓取速度越快。
百度信息流oCPC投放手册
接收回传数据 用于投放策略优化与数据披露
监测平台服务器
接收点击数据及参数信息 (接口一)
将广告点击数据与推广AP P转化相关数据进行数据
拼接将拼接成功的数据回传给 callback url (接口二)
APC CPC oCPC
优化依赖 无 无
对接转化数据
场景2 :线索收集类
- 按钮点击
表单提交 电话
咨询
成功提交
✔ 表单提交成功
对
接 方
有技术能力
式 无技术能力
数据对接 JS 移动营销页
适 配
金融、教育、汽 车平台、家居、
行 招商咨询、二类
业 电商……
API-数据传输原理
6 附录2:问题自查手册 API自查 | JS自查 | 其他常见问题
3 投放指南
7 附录3:oCPC转化目标说明
oCPC投放法则 | 常见优化问题 | oCPC与CPC投放说明
激活 | 表单提交成功 | 按钮点击 | 闪投DPA oCPC
4 排查通路 凤聆通路及问题架构
产品介绍
广告投放痛点与趋势 | 基本概念 | 价值优势
第一阶段
数据积累
获取足够的转化量(20个 )以确保智能投放阶段系
统准确的预测转化率
第二阶段
智能出价
根据转化率预估进行智能投放,以转化成本为优化方向,帮助广告主 提高广告转化效果
高价值流量判定产品能力PMC用户行为点击广告
广告效果
CPC出价
用户A 预估CTR 2%
已点击广告
产生转化
广告效果
ᔱࢶ
ىᔮහഝ ᴅي᪁
腾讯认证空间API接口说明文档1.0
7. 诚意邀请:
现在加入
与我们一同拥抱4.28亿用户,拥抱未来!
联系我们:page.opensns@
腾讯认证空间介绍
——SNS新媒体革命
1.认证空间:新的媒介趋势
1.认证空间:新的媒介趋势
QQ空间战略级产品“认证空间” 与您一同拥抱这令人激动的媒介革命。
1.认证空间:新的媒介趋势
认证空间是指经过腾讯官方认证的,针对知名品牌、机构、媒体、名人推出, 拥有更多丏属功能的QQ空间。它类似于Facebook Page、人人网公共主页,形 象地说,它社交网络中的大型通讯社。
5. 认证空间:更多丰富应用
5. 认证空间:更多丰富应用
分享
说说: 投票 活动 APP ……
Tips:点击此处可 同步信息到微博。
5. 认证空间:更多丰富应用
分享
说说 投票: 活动 APP ……
5. 认证空间:更多丰富应用
分享
说说 投票 活动: APP ……
5. 认证空间:更多丰富应用
分享
1.认证空间:新的媒介趋势
认证空间有三大特点:
(1) 认证空间是经过腾讯官方认证,能有效帮助网站/品牌/机构提升形 象,幵有效防止仿冒空间的恶意传播。 (2) 用户可以自主添加成为认证空间的粉丝,幵即时收到认证空间动态。 (3) 认证空间可发起各种活动,与目标用户保持持续、顺畅的互动交流。
2. 认证空间:更易引爆流行
5. 认证空间:更多丰富应用
分享:支持站内外分享,跨平台级应用产品。
说说:类同微博功能,更多同步应用。 投票:与用户互动的简易办法,有助增加用户粘度。 活动:认证空间丏属功能,可发起多种线上活动。 APP:未来将引迚大量第三方应用。 ……
科大讯飞HTML5 API说明文档
评测开发接口说明 ...................................................................................................................... 14
5.1 IFLYISESESSION 接口 .............................................................................................................................. 14 5.2 5.3 第6章 第7章
13开发包组件听写业务开发组件组件组成说明基础库文件webapiopenspeechcniatminjswebapiopenspeechcnrecorderworkerjswebapiopenspeechcnsocketiosocketiojswebapiopenspeechcnspeexjswebapiopenspeechcnvadjswebapiopenspeechcnfingerprintjs浏览器录音网络连接语音听写会话封装运行环境firefoxchromeuc360ie9表12听写业务包合成业务开发组件组件组成说明基础库文件webapiopenspeechcnttsminjswebapiopenspeechcnfingerprintjswebapiopenspeechcnsocketiosocketiojs网络连接语音合成会话封装运行环境全浏览器支持表13合成业务包评测业务开发组件组件组成说明基础库文件webapiopenspeechcniseminjswebapiopenspeechcnrecorderworkerjswebapiopenspeechcnsocketiosocketiojswebapiopenspeechcnspeexjswebapiopenspeechcnvadjswebapiopenspeechcnfingerprintjs浏览器录音网络连接语音听写会话封装运行环境firefoxchromeuc360表13评测业务包html5api开发手册接入授权21授权字段html5语音服务建立在接入协议基础上接入授权需要传入的信息字段如表21示其中appidsecretkey可以在http
百度知道开放平台频道API接口规范文档(1.0.1)
百度知道开放平台OPEN API接口规范文档V 1.0.1系统名称百度知道开放平台OPEN API服务接口项目负责人作者陈霖文档提交日期2010-11-04百度在线网络技术(北京)有限公司(版权所有,翻版必究)修改记录No 修改后版本号修改内容简介修改日期修改人1 1.0 百度知道OPEN API服务接口2010-11-04 陈霖2 1.0.1 baidu.zhidao.getQuestionInfo修改baidu.zhidao.setBestAnswer修改2011-02-17 王兴目录1背景 (6)2规范适用对象说明 (6)3名词解释 (6)4请求数据包格式规范 (6)4.1URL (6)4.2参数 (7)4.2.1系统级参数 (7)4.2.2业务级参数的通用约定 (7)4.2.3参数签名算法 (7)5响应数据包格式规范 (8)5.1XML输出格式 (8)5.2json输出格式 (9)5.3错误响应输出格式 (9)6错误码定义 (10)7API接口细则 (10)7.1baidu.zhidao.getCatalogInfo (10)7.1.1功能 (10)7.1.2参数 (11)7.1.3返回值 (11)7.2baidu.zhidao.getQuestionList (11)7.2.1功能 (11)7.2.2参数 (11)7.2.3返回值 (12)7.3baidu.zhidao.getQuestionSearch (12)7.3.1功能 (12)7.3.2参数 (12)7.3.3返回值 (13)7.4baidu.zhidao.getQuestionInfo (13)7.4.1功能 (13)7.4.2参数 (13)7.4.3返回值 (14)7.5baidu.zhidao.getQuestionAnswer (15)7.5.1功能 (15)7.5.2参数 (15)7.5.3返回值 (15)7.6baidu.zhidao.getUserInfo (15)7.6.1功能 (15)7.6.2参数 (16)7.6.3返回值 (16)7.7baidu.zhidao.getUserQuestionList (16)7.7.1功能 (16)7.7.2参数 (17)7.7.3返回值 (17)7.8baidu.zhidao.getUserAnswerList (17)7.8.1功能 (17)7.8.2参数 (18)7.8.3返回值 (18)7.9baidu.zhidao.getRecommend (18)7.9.1功能 (18)7.9.2参数 (19)7.9.3返回值 (19)7.10baidu.zhidao.getUserScoreRank (19)7.10.1功能 (19)7.10.2参数 (20)7.10.3返回值 (20)7.11baidu.zhidao.changeUserWealth (20)7.11.1功能 (20)7.11.2参数 (21)7.11.3返回值 (21)7.12baidu.zhidao.setBestAnswer (21)7.12.1功能 (21)7.12.2参数 (21)7.12.3返回值........................................................................................... 错误!未定义书签。
api 整改技巧
api 整改技巧(原创版2篇)目录(篇1)1.API 整改的背景和原因2.API 整改的主要技巧3.API 整改的实际应用案例4.API 整改的未来发展趋势正文(篇1)一、API 整改的背景和原因API,即应用程序编程接口,是软件开发中不可或缺的一个部分。
近年来,随着我国互联网行业的迅速发展,API 的使用越来越广泛。
然而,由于各种原因,如技术更新、业务需求变化等,API 的整改也时常发生。
因此,掌握 API 整改的技巧显得尤为重要。
二、API 整改的主要技巧1.接口功能重构:根据新的业务需求,对原有接口功能进行调整和优化,以满足新的业务场景。
2.接口命名规范调整:为了保持代码的一致性和可读性,需要对接口命名规范进行调整。
3.接口版本控制:为了保证新旧系统间的平滑过渡,可以通过接口版本控制来实现不同版本的接口共存。
4.接口文档更新:随着接口的整改,需要及时更新接口文档,以方便其他开发者使用。
5.接口测试:在整改完成后,需要对接口进行详细的测试,以确保其功能正确、性能稳定。
三、API 整改的实际应用案例以某电商平台为例,由于业务发展需要,需要对接入该平台的第三方商家进行管理。
因此,需要对原有的 API 进行整改,以满足新业务场景的需求。
在这个过程中,可以通过上述技巧,如接口功能重构、接口命名规范调整等,来完成 API 的整改。
四、API 整改的未来发展趋势随着技术的不断发展,API 整改也将面临更多的挑战。
如何在保证API 功能正确的同时,提高其性能、可扩展性、安全性等方面的要求,将是 API 整改未来发展的重要方向。
同时,借助人工智能、自动化测试等技术手段,有望提高 API 整改的效率和质量。
总之,掌握 API 整改的技巧对于软件开发者来说具有重要意义。
目录(篇2)1.API 整改的背景和原因2.API 整改的主要技巧3.API 整改的实际应用案例4.API 整改的未来发展趋势和建议正文(篇2)一、API 整改的背景和原因API,即应用程序编程接口,是软件开发中不可或缺的重要组成部分。
微信端html5页面调用分享接口示例
微信端html5页⾯调⽤分享接⼝⽰例最近公司做了⼀个给学⽣投票的H5页⾯,主要是在微信端使⽤,需要添加微信分享功能;本⽂章主要是记录调⽤微信分享接⼝需要注意的事项;1、前端⽤的angular1框架,⾸先需要在index页⾯引⼊微信接⼝⽂件;<script src="/open/js/jweixin-1.2.0.js"></script>2、在myApp.run⽂件中写微信分享函数,注意该函数需要将当前页⾯的url获取并解析,然后发给后端来⽣成对应签名,直接上代码;// 微信分享函数function wxShare() {var url = $location.absUrl().split('#')[0];wxServices.postWxShare(url).then(function (res) {if (res.data.code == 0) {var respanse = res.data.data;wx.config({debug: false, // 开启调试模式,调⽤的所有api的返回值会在客户端alert出来,若要查看传⼊的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: respanse.appId,timestamp: respanse.timestamp, // 必填,⽣成签名的时间戳nonceStr: respanse.nonceStr, // 必填,⽣成签名的随机串signature: respanse.signature,// 必填,签名jsApiList: ['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone']// 必填,需要使⽤的JS接⼝列表});}})}将当前url解析后,发给后端接⼝,后端需要将appId,时间戳,随机字符串和签名返回,然后接⼝列表(jsApiList)根据需要⾃⼰⼿动添加,注意是⼀个数组的形式,我这⾥只需要调⽤分享接⼝;调试的时候,可以将debug更改为true,这样在就每次调⽤微信接⼝的时候就会有接⼝信息alert出来,⽅便查看接⼝调⽤是否正常了;3、在该函数后,⾃定义分享内容,代码如下;wx.ready(function () {var obj = {title: 'SPBCN团体赛开始投票啦!', // 分享标题desc: 'SPBCN团体赛开始投票了,快来为我们加油吧!', // 分享描述link: '/wechat-vote-phone/redirect.html', // 分享链接,该链接域名或路径必须与当前页⾯对应的公众号JS安全域名⼀致// 该链接是重定向链接,因为需要获取⽤户code,但是该链接⼜⽆法直接写微信获取code的链接,// 所以需要点击后重新加载新的页⾯,来实现重定向,重新打开获取code的微信链接,实现获取⽤户信息的功能;imgUrl: '/img/logo-image.png', // 分享图标fail: function (res) {alert(JSON.stringify(res));}};// 2.1 监听“分享给朋友”,按钮点击、⾃定义分享内容及分享结果接⼝wx.onMenuShareAppMessage(obj);// 2.2 监听“分享到朋友圈”按钮点击、⾃定义分享内容及分享结果接⼝wx.onMenuShareTimeline(obj);// 2.3 监听“分享到QQ”按钮点击、⾃定义分享内容及分享结果接⼝wx.onMenuShareQQ(obj);// 2.4 监听“分享到微博”按钮点击、⾃定义分享内容及分享结果接⼝wx.onMenuShareWeibo(obj);// 2.5 监听“分享到QZone”按钮点击、⾃定义分享内容及分享接⼝wx.onMenuShareQZone(obj);})wx.ready是在wx.config之后⾃动运⾏的,我是定义了⼀个分享内容的通⽤对象,然后直接调⽤即可,也可以根据需要来分别定义分享朋友、朋友圈、微博等的不同内容,具体查看微信接⼝⽂档即可;主要强调⼀下分享链接,该链接必须是你的公众号设置的JS安全域名下的,不然⽆法分享成功;分享失败的表现是,分享链接图⽚⽆法加载你⾃定义的图⽚,分享标题也不对;5、我这个项⽬是投票类的,所以需要每次点击进来之后获取⽤户code,如果你只是分享⽂章,不需要⽤户信息,直接将link更改为你的⽂章链接即可;6、对于投票类,我这⾥特殊处理了,就是重定向了该链接,⼤家都知道H5获取微信⽤户信息有两种,⼀种是关注微信公众号;另⼀种提⽰⽤户需要获取⽤户公开信息,⽤户点击确定即可。
腾讯广告API全概述
02 2 . 3 . 1 获 取 资 金 账
户信息
04 2 . 4 . 1 获 取 定 向 标
签信息
05 2 . 5 . 1 获 取 微 信 原
生落地页信息
获取 access_token
开发者ID(AppID) 开发者密码(AppSecret) 获取access_token接口
所有接口的请求路 径:
auth_type,要授权的帐号类型 1-则商户扫码后,手机端仅展示公众号
2-表示仅展示小程序 3-表示公众号和小程序都展示 null = 3 biz_appid,指定授权唯一的小程序或公众号
步骤 2:引入用户 进入授权页
方式二:点击移动端链接快速授 权
#1 使用授 权码获取授 权信息
component_access_token
原理介绍
1.对于落地页为 H5 或小程序的广告而 言,在微信广告平台推广时,每次点击
都会生成一个 click_id
3.回传转化数据时,需要回传 click_id 与转化行为
5.关联后计算的广告效果会呈现在 MP 投放端报表中,并会成为后续智能优化
的数据基础。
2.在跳转到落地页时,会将 click_id 作为参数传入对应的 URL 中
04
4.广告平台会通 过click_id关联 到该次转化对应 的广告,从而得 到点击与转化的 关联
05
5.关联后计算的 广告效果会呈现 在 MP 投放端报 表中,并会成为 后续智能优化的 数据基础。
准备阶段
(一) 注册成为开发者 目标:获取开发者ID、密码和access_token 步骤
(二) 创建数据源 一个公众号有一个数据源,使用access_token创建
Html5调用企业微信的实现
Html5调⽤企业微信的实现前⾔基于H5的页⾯调通企业微信的API (已调通demo)⼀、环境企业微信管理员添加应⽤,地址指向H5程序的地址。
(企业微信通过内部游览器访问你⾃⼰发布出来的web端的⼿机项⽬,不做本⽂重点)⼆、使⽤步骤1.js引⽤<script src="/open/js/jweixin-1.2.0.js"></script>2.config接⼝注⼊权限验证配置代码如下:wx.config({beta: true,// 必须这么写,否则wx.invoke调⽤形式的jsapi会有问题debug: true, // 开启调试模式,调⽤的所有api的返回值会在客户端alert出来,若要查看传⼊的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: '', // 必填,企业微信的corpIDtimestamp: , // 必填,⽣成签名的时间戳nonceStr: '', // 必填,⽣成签名的随机串signature: '',// 必填,签名,见附录-JS-SDK使⽤权限签名算法jsApiList: [] // 必填,需要使⽤的JS接⼝列表,凡是要调⽤的接⼝都需要传进来});其中 appId 在企业微信上获取,timestamp 时间戳,nonceStr ⼀个16位的随机字符串,signature 这个签名是最复杂的(下⾯有讲到配置⽅法)。
signature 这个签名需要的如下(官⽹⽂档)参与签名的参数有四个: noncestr(随机字符串), jsapi_ticket(如何获取参考“获取企业jsapi_ticket”以及“获取应⽤的jsapi_ticket接⼝”), timestamp(时间戳), url(当前⽹页的URL,不包含#及其后⾯部分)将这些参数使⽤URL键值对的格式(即 key1=value1&key2=value2…)拼接成字符串string1。
Taro v1.3 API 文档
自 v1.3.0 起可用 1. static getDerivedStateFromProps(props, state)
getDerivedStateFromProps 会在调用 render 方法之前调用,并且在初始挂载及后续更新时都会被调用。它应返回 一个对象来更新 state,如果返回 null 则不更新任何内容。
此方法无权访问组件实例(this)。如果你需要,可以通过提取组件 props 的纯函数及 class 之外的状态,在 getDerivedStateFromProps() 和其他 class 方法之间重用代码。
和 componentWillReceiveProps 不同, getDerivedStateFromProps componentWillReceiveProps 会在父组件重新渲染时调用。
在 Taro 中,即便你不写 constructor(),编译到微信小程序时也会自动给你加上,因为 Taro 运行时框架需要在 constructor() 中多做一些事 情。
可以基于属性来初始化状态。这样有效地“分离(forks)”属性并根据初始属性设置状态。
ponent
static getDerivedStateFromProps()
应返回 snapshot 的值(或 null)。
请注意:getSnapshotBeforeUpdate() 如果存在, componentWillReceiveProps 、 componentWillMount 和 componentWillUpdate 将不会调用。当你需要在以上老生命周期 setState 时,我们更推荐你使用 getSnapshotBeforeUpdate
关于API
API 说明 ponent 环境判断 消息机制
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
模式1:开发者用一套完成鉴权的 account id 和对应的 pixel id 来上报所有账户的数据。
模式2:开发者与每一个广告主账户进行鉴权,用各个账户的广告主ID作为 account id 和各自对应的 pixel id 完成各自账户的数据上报。
1.2 接口改动(必读)
内测期间使用的接口地址为:
https:///
目前已经全面更新为:
https:///
新接入的开发者请使用 https:/// ,已经完成对接的广告主建议做更新,但也可以不做修改。
如果开发者已经是广点通的广告主账户(代理商或广告主),建议直接用代理商帐号或广告主帐号的开户QQ进行注册。
2.1.2 完善开发者资料
完成QQ登录后,将进入开发者资料填写页面:
资料填写完整并手机验证通过后即完成开发者注册。
2.1.3 创建转化数据上报应用
注册为开发者后,在开发者官网登录即可进入『应用程序管理』面板:
点击『创建新应用程序』进入创建转化数据上报服务界面:
当引导广告主在上述登录界面完成登录身份验证后,系统会自动跳转到刚才定义的回调地址中,并带上 authorization_code(有效期5分钟)和state两个参数。
形如:
/response?authorization_code=<CODE>&state=<STATE>
开发者的应用程序在收到上述返回后,应当在 authorization_code 有效期内,利用authorization_code 获得 access_token (见下一步),并对广告主给出相应的提示和跳转指引等。
步骤 2:使用authorization_code获得access_token和refresh_token
用 authorization_code 获得 access_token 和 refresh_token 的接口地址为
https:///oauth/token
接口输入参数如下表所示:
名称类型描述限制是否必填
client_id integer应用id,开发者创建应用后获得,旧名称 appid
已不可用
yes
client_secret string应用secret,应用被审核通过后获得,旧名称
app_key 已不可用应用secret
小于
256个
英文
字符
yes
grant_type string请求的类型,可选值:authorization_code(授
权码方式获取 token)、refresh_token(刷新
token)
yes
authorization_code string OAuth 认证 code,当
grant_type='authorization_code' 时必填
no
转化行为ActionType(action_type)下单COMPLETE_ORDER
2.4.2 转化数据类型示例
此处以【下单】为例
2.4.3 数据上报参数说明
名称类型描述限制是否必填
account_id integer广告主ID必须是已经
和开发者完
成鉴权的广
告主ID
yes
pixel_id integer后续用于标识数据归属权此参数请联
系广点通运
营获取
yes url string转化行为发生页面的URL yes
action_time integer行为发生时,客户端的时间点。
广点通使用的是
GMT+8的时间,容错范围是前后10秒,UNIX时
间,单位为秒,如果不填将使用服务端时间填写
yes
action_type enum预定义的行为类型,目前只支持
COMPLETE_ORDER(表单提交)
yes
click_id string落地页URL中的click_id,对于广点通流量为URL
中的qz_gdt,对于微信流量为URL中的gdt_vid 目前仅支持
click_id
yes
value integer转化行为价值(例如金额)100表示1元no nonce integer nonce是一个长度小于32的随机字符串,并要保
证唯一性
yes
timestamp integer timestamp是精确到秒的时间戳,广点通使用的
是GMT+8的时间,容错范围是前后10秒yes
名称类型描述限制是否必填
2.4.4 转化数据上报请求示例
需要统计『下单』的转化行为,开发者只需要在下单转化行为发生时,上报
action_type=”COMPLETE_ORDER”,且附上由落地页获取的 click_id,nonce是一个长度小于32的随机字符串,并要保证唯一性。
请求示例如下:
curl -k "https:///v1.0/user_actions/add?access_token=<TOKEN>×t amp=<TIMESTAMP>&nonce=<NONCE>" \
-d '{
"account_id": "<ACCOUNT_ID>"
"actions": [
{
"pixel_id": "<PIXEL_ID>",
"url": "<URL>",
"action_time": 1487923255,
"action_type": "COMPLETE_ORDER",
"trace": {
"click_id": "<CLICK_ID>"
},
"value": 10000
}
]
}'。