wxapis
======
``wxapis`` 是一个封装了企业微信接口(API)的工具包。它提供了一个统一的入口和规范,以便于开发者在使用企业微信相关接口时能够更为方便快捷。
简介
----
- 本工具包专为企业微信内部开发而设计,旨在简化 `企业微信内部开发 <https://developer.work.weixin.qq.com/document/path/90556>`__ 过程中与 API 交互的复杂度。
- 当前版本不支持 `第三方应用开发 <https://developer.work.weixin.qq.com/document/path/90594>`__ 和 `服务商代开发 <https://developer.work.weixin.qq.com/document/path/97111>`__ ,未来可能会根据需求进行扩展。
- 目前已经集成了大多数常用的企业微信 API,并为每个接口提供易于理解的常量名称。请注意,并非所有官方接口都已经被包含在本工具包中。
使用
----
安装
~~~~
- 安装 ``wxapis`` 可以非常简单,通过以下命令即可完成:
.. code::
pip install wxapis
示例
~~~~
- 假设您想要获取特定成员的信息,有两种方法可以找到相关接口:一是直接查阅企业微信官方接口文档;二是使用我们包中提供的搜索功能进行查询。以下是如何使用搜索功能的示例:
.. code:: bash
from wxapis import search_apis
import json
print(
json.dumps(
search_apis(kw="user"),
ensure_ascii=False,
indent=4
)
)
- 通过关键词 "user" 搜索得到的结果会列出所有相关的接口信息,如下所示:
.. code:: bash
[
{
"WXWORK_GET_USER": [
"/cgi-bin/user/get?access_token=ACCESS_TOKEN",
"GET",
"读取成员。为保护企业数据与用户隐私,从 2022 年 6 月 20 号 20 点开始,新创建的自建应用与代开发应用,调用该接口时,不再返回以下字段:头像、性别、手机、邮箱、企业邮箱、员工个人二维码、地址,应用需要通过 oauth2 手工授权的方式获取管理员与员工本人授权的字段。"
]
},
{
"WXWORK_CREATE_USER": [
"/cgi-bin/user/create?access_token=ACCESS_TOKEN",
"POST",
"创建成员。仅通讯录同步助手或第三方通讯录应用可调用。每个部门下的部门、成员总数不能超过 3 万个。建议保证创建 `department` 对应的部门和创建成员是串行化处理。"
]
},
{
"WXWORK_UPDATE_USER": [
"/cgi-bin/user/update?access_token=ACCESS_TOKEN",
"POST",
"更新成员。特别地,如果 `userid` 由系统自动生成,则仅允许修改一次。新值可由 `new_userid` 字段指定。如果创建时企业邮箱为系统默认分配的,则仅允许修改一次,若创建时填入了合规的企业邮箱,则无法修改。仅通讯录同步助手或第三方通讯录应用可调用。注意,每个部门下的部门、成员总数不能超过 3 万个。"
]
},
{
"WXWORK_DELETE_USER": [
"/cgi-bin/user/delete?access_token=ACCESS_TOKEN",
"GET",
"删除成员。仅通讯录同步助手或第三方通讯录应用可调用。若是绑定了腾讯企业邮,则会同时删除邮箱账号。"
]
},
{
"WXWORK_BATCH_DELETE_USER": [
"/cgi-bin/user/batchdelete?access_token=ACCESS_TOKEN",
"POST",
"批量删除成员。仅通讯录同步助手或第三方通讯录应用可调用。"
]
},
{
"WXWORK_USER_SIMPLE_LIST": [
"/cgi-bin/user/simplelist?access_token=ACCESS_TOKEN",
"GET",
"获取部门成员。企业通讯录安全特别重要,企业微信将持续升级加固通讯录接口的安全机制,以下是关键的变更点:从 2022 年 8 月 15 日 10 点开始,\"企业管理后台 - 管理工具 - 通讯录同步\"的新增 IP 将不能再调用此接口,企业可通过 \"获取成员 ID 列表\" 和 \"获取部门 ID 列表\"接口获取 `userid` 和部门 ID 列表。"
]
},
{
"WXWORK_LIST_USER": [
"/cgi-bin/user/list?access_token=ACCESS_TOKEN",
"GET",
"获取部门成员详情。应用只能获取可见范围内的成员信息,且每种应用获取的字段有所不同,在返回结果说明中会逐个说明。企业通讯录安全特别重要,企业微信持续升级加固通讯录接口的安全机制,以下是关键的变更点:从 2022 年 6 月 20 号 20 点开始,除通讯录同步以外的基础应用(如客户联系、微信客服、会话存档、日程等),以及新创建的自建应用与代开发应用,调用该接口时,不再返回以下字段:头像、性别、手机、邮箱、企业邮箱、员工个人二维码、地址,应用需要通过 `oauth2` 手工授权的方式获取管理员与员工本人授权的字段。从 2022 年 8 月 15 日 10 点开始,\"企业管理后台 - 管理工具 - 通讯录同步\"的新增 IP 将不能再调用此接口,企业可通过 \"获取成员 ID 列表\" 和 \"获取部门 ID 列表\"接口获取 `userid` 和部门 ID 列表。"
]
},
{
"WXWORK_CONVERT_USERID_TO_OPENID": [
"/cgi-bin/user/convert_to_openid?access_token=ACCESS_TOKEN",
"POST",
"userid 与 openid 互换。该接口使用场景为企业支付,在使用企业红包和向员工付款时,需要自行将企业微信的 `userid` 转成 `openid`。注:需要成员使用微信登录企业微信或者关注微信插件(原企业号)才能转成 `openid`;如果是外部联系人,请使用外部联系人 `openid` 转换转换 `openid`。"
]
},
{
"WXWORK_CONVERT_OPENID_TO_USERID": [
"/cgi-bin/user/convert_to_userid?access_token=ACCESS_TOKEN",
"POST",
"openid 转 userid。该接口主要应用于使用企业支付之后的结果查询。开发者需要知道某个结果事件的 `openid` 对应企业微信内成员的信息时,可以通过调用该接口进行转换查询。"
]
},
{
"WXWORK_USER_AUTH_SUCCESS": [
"/cgi-bin/user/authsucc?access_token=ACCESS_TOKEN",
"GET",
"登录二次验证。此接口可以满足安全性要求高的企业进行成员验证。开启二次验证后,当且仅当成员登录时,需跳转至企业自定义的页面进行验证。验证频率可在设置页面选择。企业在开启二次验证时,必须在管理端填写企业二次验证页面的 url。当成员登录企业微信或关注微信插件(原企业号)进入企业时,会自动跳转到企业的验证页面。在跳转到企业的验证页面时,会带上如下参数:`code=CODE`。企业收到 code 后,使用 \"通讯录同步助手\" 调用接口 \"根据 code 获取成员信息\" 获取成员的 `userid`。"
]
}
]
- 如上所示,返回结果是一个字典列表,其中每个字典包含三个关键部分:一是 API 路径段(自动补全完整 URL),二是请求方法(GET 或 POST),三是该接口的描述性注释。
- 假设您要获取某位成员详细信息,您可按照如下方式调用对应 API:
.. code:: bash
from wxapis import WXWORK_GET_USER
from wxapis.corporate import CorpApis
from wxapis.abstract import ApiException
import json
try:
wx = CorpApis(
corpid="", # 填写您公司 ID
agentid="", # 填写您应用 ID
secret="" # 填写您应用密钥
)
users = wx.httpReq(
api=WXWORK_GET_USER,
params={
"userid": "" # 填写要查询的用户 ID
}
)
print(
json.dumps(
users,
ensure_ascii=False,
indent=4
)
)
except ApiException as err:
print(str(err))
- 最终返回的用户详情如下:
.. code:: bash
{
"errcode": 0,
"errmsg": "ok",
"userid": "",
"name": "",
"department": [],
"position": "",
"status": 1,
"isleader": 0,
"extattr": {
"attrs": []
},
"telephone": "",
"enable": 1,
"hide_mobile": 0,
"order": [],
"alias": "",
"is_leader_in_dept": [],
"direct_leader": []
}
- 在使用我们的企业微信 API 接口包时,您可能会发现并非所有的企业微信官方 API 接口都被直接封装在包中。如果您需要访问未被定义的接口,您可以轻松地自定义一个接口元组或列表来实现这一需求。在构建自定义接口元组或列表时,请确保至少包含两个必要的元素:接口的短路径和 HTTP 请求方法(如 GET 或 POST)。这两项是调用任何企业微信 API 时不可或缺的信息。至于其他参数,根据实际请求需求来决定是否添加。依然以获取某成员的信息为例:
.. code:: bash
from wxapis.corporate import CorpApis
from wxapis.abstract import ApiException
import json
try:
wx = CorpApis(
corpid="", # 填写您公司 ID
agentid="", # 填写您应用 ID
secret="" # 填写您应用密钥
)
users = wx.httpReq(
# 使用元组或者列表,且前两项元素的内容固定,即请求短路径和请求方法
api=(
"/cgi-bin/user/get?access_token=ACCESS_TOKEN",
"GET"
),
params={
"userid": "" # 填写要查询的用户 ID
}
)
print(
json.dumps(
users,
ensure_ascii=False,
indent=4
)
)
except ApiException as err:
print(str(err))
- 最终返回的用户详情如下:
.. code:: bash
{
"errcode": 0,
"errmsg": "ok",
"userid": "",
"name": "",
"department": [],
"position": "",
"status": 1,
"isleader": 0,
"extattr": {
"attrs": []
},
"telephone": "",
"enable": 1,
"hide_mobile": 0,
"order": [],
"alias": "",
"is_leader_in_dept": [],
"direct_leader": []
}
高级
~~~~
- 除标准 API 调用外,本工具包还提供了执行特定操作例如向某个应用发送消息等高级功能。安装本工具包后,在系统路径中将自动添加一个专门命令以便发送消息至企业微信应用。如下所示:
.. code::
$ which smsg
/d/Python/Python38/Scripts/smsg
$ smsg --help
usage: smsg.py [-h] -c CORPID -s SECRET -i AGENTID -m MESSAGE [-a FIELD] [-f {json,yaml}]
[-l {DEBUG,INFO,WARNING,ERROR,CRITICAL}]
发送企业微信内部应用消息。
optional arguments:
-h, --help 显示此帮助信息并退出。
-c CORPID, --corpid CORPID
企业微信的企业 id。可以在企业微信管理后台获取此 id。此选项为必须选项。
-s SECRET, --secret SECRET
与企业微信内应用关联的 secret。secret 用于验证身份并加密通讯过程,可在企业微信管理后台找到。此选项为必须选项。
-i AGENTID, --agentid AGENTID
企业微信内应用的 agent id,代表了应用实体,在企业微信中唯一标识一个应用。请确保传入正确的 agent id。此选项为必须选项。
-m MESSAGE, --message MESSAGE
要发送给企业微信应用的消息文本内容。此选项为必须选项。
-a FIELD, --field FIELD
消息体字段,格式为 "k=v",添加或覆盖参数 `message` 中字段的值,例如 "-a text.content=xxx"。此选 项为可选选项。
-f {json,yaml}, --format {json,yaml}
定义参数 `message` 文本内容的解析格式,默认为 "json"。此选项为可选选项。
-l {DEBUG,INFO,WARNING,ERROR,CRITICAL}, --level {DEBUG,INFO,WARNING,ERROR,CRITICAL}
设置输出日志级别,默认为 "INFO",在命令行传入时不区分大小写,比如传入 "DEBUG" 和传入 "debug" 一 样。此选项为可选选项。
- 根据命令行参数指南,您可以轻松地通过相应命令向企业微信中发送消息:
.. code::
PS E:\PycharmProjects\self\wxapis> smsg --corpid "" --agentid "" --secret "" --message '{\"touser\": \"\", \"agentid\": "", \"msgtype\": \"text\", \"text\": {\"content\": \"这是测试!\"}, \"safe\": 0, \"enable_id_trans\":0, \"enable_duplicate_check\": 0}' -a "text.content=test!!!"
INFO:root:发送消息[{'touser': '', 'agentid': '', 'msgtype': 'text', 'text': {'content': 'test!!!'}, 'safe': 0, 'enable_id_trans': 0, 'enable_duplicate_check': 0}]。
INFO:root:任务执行:"True"。
- 如果您需要审查消息发送详情,请确保设置合适的日志级别以便获得详细输出:
.. code::
PS E:\PycharmProjects\self\wxapis> smsg --corpid "" --agentid "" --secret "" --message '{\"touser\": \"\", \"agentid\": "", \"msgtype\": \"text\", \"text\": {\"content\": \"这是测试!\"}, \"safe\": 0, \"enable_id_trans\":0, \"enable_duplicate_check\": 0}' -a "text.content=test!!!" --level debug
DEBUG:root:Namespace(agentid='', corpid='', field=['text.content=test!!!'], format='json', level='DEBUG', message='{"touser": "", "agentid": '', "msgtype": "text", "text": {"content": "这是测试!"}, "safe": 0, "enable_id_trans":0, "enable_duplicate_check": 0}', secret='')
DEBUG:urllib3.connectionpool:Starting new HTTPS connection (1): qyapi.weixin.qq.com:443
DEBUG:urllib3.connectionpool:https://qyapi.weixin.qq.com:443 "POST /cgi-bin/message/send?access_token=xxx HTTP/11" 200 124
INFO:root:发送消息[{'touser': '', 'agentid': '', 'msgtype': 'text', 'text': {'content': 'test!!!'}, 'safe': 0, 'enable_id_trans': 0, 'enable_duplicate_check': 0}]。
INFO:root:任务执行:"True"。
Raw data
{
"_id": null,
"home_page": "https://github.com/gary714/wxapis",
"name": "wxapis",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "WeChat, WxWork",
"author": "gary",
"author_email": "mepmb@sina.com",
"download_url": "https://files.pythonhosted.org/packages/6c/1d/82f2fc7d164925468abdbc55843febe501f9f8a0860095094100b0a23128/wxapis-2.0.0.tar.gz",
"platform": "Linux",
"description": "wxapis\r\n======\r\n\r\n ``wxapis`` \u662f\u4e00\u4e2a\u5c01\u88c5\u4e86\u4f01\u4e1a\u5fae\u4fe1\u63a5\u53e3\uff08API\uff09\u7684\u5de5\u5177\u5305\u3002\u5b83\u63d0\u4f9b\u4e86\u4e00\u4e2a\u7edf\u4e00\u7684\u5165\u53e3\u548c\u89c4\u8303\uff0c\u4ee5\u4fbf\u4e8e\u5f00\u53d1\u8005\u5728\u4f7f\u7528\u4f01\u4e1a\u5fae\u4fe1\u76f8\u5173\u63a5\u53e3\u65f6\u80fd\u591f\u66f4\u4e3a\u65b9\u4fbf\u5feb\u6377\u3002\r\n\r\n\u7b80\u4ecb\r\n----\r\n\r\n- \u672c\u5de5\u5177\u5305\u4e13\u4e3a\u4f01\u4e1a\u5fae\u4fe1\u5185\u90e8\u5f00\u53d1\u800c\u8bbe\u8ba1\uff0c\u65e8\u5728\u7b80\u5316 `\u4f01\u4e1a\u5fae\u4fe1\u5185\u90e8\u5f00\u53d1 <https://developer.work.weixin.qq.com/document/path/90556>`__ \u8fc7\u7a0b\u4e2d\u4e0e API \u4ea4\u4e92\u7684\u590d\u6742\u5ea6\u3002\r\n\r\n- \u5f53\u524d\u7248\u672c\u4e0d\u652f\u6301 `\u7b2c\u4e09\u65b9\u5e94\u7528\u5f00\u53d1 <https://developer.work.weixin.qq.com/document/path/90594>`__ \u548c `\u670d\u52a1\u5546\u4ee3\u5f00\u53d1 <https://developer.work.weixin.qq.com/document/path/97111>`__ \uff0c\u672a\u6765\u53ef\u80fd\u4f1a\u6839\u636e\u9700\u6c42\u8fdb\u884c\u6269\u5c55\u3002\r\n\r\n- \u76ee\u524d\u5df2\u7ecf\u96c6\u6210\u4e86\u5927\u591a\u6570\u5e38\u7528\u7684\u4f01\u4e1a\u5fae\u4fe1 API\uff0c\u5e76\u4e3a\u6bcf\u4e2a\u63a5\u53e3\u63d0\u4f9b\u6613\u4e8e\u7406\u89e3\u7684\u5e38\u91cf\u540d\u79f0\u3002\u8bf7\u6ce8\u610f\uff0c\u5e76\u975e\u6240\u6709\u5b98\u65b9\u63a5\u53e3\u90fd\u5df2\u7ecf\u88ab\u5305\u542b\u5728\u672c\u5de5\u5177\u5305\u4e2d\u3002\r\n\r\n\u4f7f\u7528\r\n----\r\n\r\n\u5b89\u88c5\r\n~~~~\r\n\r\n- \u5b89\u88c5 ``wxapis`` \u53ef\u4ee5\u975e\u5e38\u7b80\u5355\uff0c\u901a\u8fc7\u4ee5\u4e0b\u547d\u4ee4\u5373\u53ef\u5b8c\u6210\uff1a\r\n\r\n .. code::\r\n\r\n pip install wxapis\r\n\r\n\u793a\u4f8b\r\n~~~~\r\n\r\n- \u5047\u8bbe\u60a8\u60f3\u8981\u83b7\u53d6\u7279\u5b9a\u6210\u5458\u7684\u4fe1\u606f\uff0c\u6709\u4e24\u79cd\u65b9\u6cd5\u53ef\u4ee5\u627e\u5230\u76f8\u5173\u63a5\u53e3\uff1a\u4e00\u662f\u76f4\u63a5\u67e5\u9605\u4f01\u4e1a\u5fae\u4fe1\u5b98\u65b9\u63a5\u53e3\u6587\u6863\uff1b\u4e8c\u662f\u4f7f\u7528\u6211\u4eec\u5305\u4e2d\u63d0\u4f9b\u7684\u641c\u7d22\u529f\u80fd\u8fdb\u884c\u67e5\u8be2\u3002\u4ee5\u4e0b\u662f\u5982\u4f55\u4f7f\u7528\u641c\u7d22\u529f\u80fd\u7684\u793a\u4f8b\uff1a\r\n\r\n .. code:: bash\r\n\r\n from wxapis import search_apis\r\n import json\r\n\r\n print(\r\n json.dumps(\r\n search_apis(kw=\"user\"),\r\n ensure_ascii=False,\r\n indent=4\r\n )\r\n )\r\n\r\n- \u901a\u8fc7\u5173\u952e\u8bcd \"user\" \u641c\u7d22\u5f97\u5230\u7684\u7ed3\u679c\u4f1a\u5217\u51fa\u6240\u6709\u76f8\u5173\u7684\u63a5\u53e3\u4fe1\u606f\uff0c\u5982\u4e0b\u6240\u793a\uff1a\r\n\r\n .. code:: bash\r\n\r\n [\r\n {\r\n \"WXWORK_GET_USER\": [\r\n \"/cgi-bin/user/get?access_token=ACCESS_TOKEN\",\r\n \"GET\",\r\n \"\u8bfb\u53d6\u6210\u5458\u3002\u4e3a\u4fdd\u62a4\u4f01\u4e1a\u6570\u636e\u4e0e\u7528\u6237\u9690\u79c1\uff0c\u4ece 2022 \u5e74 6 \u6708 20 \u53f7 20 \u70b9\u5f00\u59cb\uff0c\u65b0\u521b\u5efa\u7684\u81ea\u5efa\u5e94\u7528\u4e0e\u4ee3\u5f00\u53d1\u5e94\u7528\uff0c\u8c03\u7528\u8be5\u63a5\u53e3\u65f6\uff0c\u4e0d\u518d\u8fd4\u56de\u4ee5\u4e0b\u5b57\u6bb5\uff1a\u5934\u50cf\u3001\u6027\u522b\u3001\u624b\u673a\u3001\u90ae\u7bb1\u3001\u4f01\u4e1a\u90ae\u7bb1\u3001\u5458\u5de5\u4e2a\u4eba\u4e8c\u7ef4\u7801\u3001\u5730\u5740\uff0c\u5e94\u7528\u9700\u8981\u901a\u8fc7 oauth2 \u624b\u5de5\u6388\u6743\u7684\u65b9\u5f0f\u83b7\u53d6\u7ba1\u7406\u5458\u4e0e\u5458\u5de5\u672c\u4eba\u6388\u6743\u7684\u5b57\u6bb5\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_CREATE_USER\": [\r\n \"/cgi-bin/user/create?access_token=ACCESS_TOKEN\",\r\n \"POST\",\r\n \"\u521b\u5efa\u6210\u5458\u3002\u4ec5\u901a\u8baf\u5f55\u540c\u6b65\u52a9\u624b\u6216\u7b2c\u4e09\u65b9\u901a\u8baf\u5f55\u5e94\u7528\u53ef\u8c03\u7528\u3002\u6bcf\u4e2a\u90e8\u95e8\u4e0b\u7684\u90e8\u95e8\u3001\u6210\u5458\u603b\u6570\u4e0d\u80fd\u8d85\u8fc7 3 \u4e07\u4e2a\u3002\u5efa\u8bae\u4fdd\u8bc1\u521b\u5efa `department` \u5bf9\u5e94\u7684\u90e8\u95e8\u548c\u521b\u5efa\u6210\u5458\u662f\u4e32\u884c\u5316\u5904\u7406\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_UPDATE_USER\": [\r\n \"/cgi-bin/user/update?access_token=ACCESS_TOKEN\",\r\n \"POST\",\r\n \"\u66f4\u65b0\u6210\u5458\u3002\u7279\u522b\u5730\uff0c\u5982\u679c `userid` \u7531\u7cfb\u7edf\u81ea\u52a8\u751f\u6210\uff0c\u5219\u4ec5\u5141\u8bb8\u4fee\u6539\u4e00\u6b21\u3002\u65b0\u503c\u53ef\u7531 `new_userid` \u5b57\u6bb5\u6307\u5b9a\u3002\u5982\u679c\u521b\u5efa\u65f6\u4f01\u4e1a\u90ae\u7bb1\u4e3a\u7cfb\u7edf\u9ed8\u8ba4\u5206\u914d\u7684\uff0c\u5219\u4ec5\u5141\u8bb8\u4fee\u6539\u4e00\u6b21\uff0c\u82e5\u521b\u5efa\u65f6\u586b\u5165\u4e86\u5408\u89c4\u7684\u4f01\u4e1a\u90ae\u7bb1\uff0c\u5219\u65e0\u6cd5\u4fee\u6539\u3002\u4ec5\u901a\u8baf\u5f55\u540c\u6b65\u52a9\u624b\u6216\u7b2c\u4e09\u65b9\u901a\u8baf\u5f55\u5e94\u7528\u53ef\u8c03\u7528\u3002\u6ce8\u610f\uff0c\u6bcf\u4e2a\u90e8\u95e8\u4e0b\u7684\u90e8\u95e8\u3001\u6210\u5458\u603b\u6570\u4e0d\u80fd\u8d85\u8fc7 3 \u4e07\u4e2a\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_DELETE_USER\": [\r\n \"/cgi-bin/user/delete?access_token=ACCESS_TOKEN\",\r\n \"GET\",\r\n \"\u5220\u9664\u6210\u5458\u3002\u4ec5\u901a\u8baf\u5f55\u540c\u6b65\u52a9\u624b\u6216\u7b2c\u4e09\u65b9\u901a\u8baf\u5f55\u5e94\u7528\u53ef\u8c03\u7528\u3002\u82e5\u662f\u7ed1\u5b9a\u4e86\u817e\u8baf\u4f01\u4e1a\u90ae\uff0c\u5219\u4f1a\u540c\u65f6\u5220\u9664\u90ae\u7bb1\u8d26\u53f7\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_BATCH_DELETE_USER\": [\r\n \"/cgi-bin/user/batchdelete?access_token=ACCESS_TOKEN\",\r\n \"POST\",\r\n \"\u6279\u91cf\u5220\u9664\u6210\u5458\u3002\u4ec5\u901a\u8baf\u5f55\u540c\u6b65\u52a9\u624b\u6216\u7b2c\u4e09\u65b9\u901a\u8baf\u5f55\u5e94\u7528\u53ef\u8c03\u7528\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_USER_SIMPLE_LIST\": [\r\n \"/cgi-bin/user/simplelist?access_token=ACCESS_TOKEN\",\r\n \"GET\",\r\n \"\u83b7\u53d6\u90e8\u95e8\u6210\u5458\u3002\u4f01\u4e1a\u901a\u8baf\u5f55\u5b89\u5168\u7279\u522b\u91cd\u8981\uff0c\u4f01\u4e1a\u5fae\u4fe1\u5c06\u6301\u7eed\u5347\u7ea7\u52a0\u56fa\u901a\u8baf\u5f55\u63a5\u53e3\u7684\u5b89\u5168\u673a\u5236\uff0c\u4ee5\u4e0b\u662f\u5173\u952e\u7684\u53d8\u66f4\u70b9\uff1a\u4ece 2022 \u5e74 8 \u6708 15 \u65e5 10 \u70b9\u5f00\u59cb\uff0c\\\"\u4f01\u4e1a\u7ba1\u7406\u540e\u53f0 - \u7ba1\u7406\u5de5\u5177 - \u901a\u8baf\u5f55\u540c\u6b65\\\"\u7684\u65b0\u589e IP \u5c06\u4e0d\u80fd\u518d\u8c03\u7528\u6b64\u63a5\u53e3\uff0c\u4f01\u4e1a\u53ef\u901a\u8fc7 \\\"\u83b7\u53d6\u6210\u5458 ID \u5217\u8868\\\" \u548c \\\"\u83b7\u53d6\u90e8\u95e8 ID \u5217\u8868\\\"\u63a5\u53e3\u83b7\u53d6 `userid` \u548c\u90e8\u95e8 ID \u5217\u8868\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_LIST_USER\": [\r\n \"/cgi-bin/user/list?access_token=ACCESS_TOKEN\",\r\n \"GET\",\r\n \"\u83b7\u53d6\u90e8\u95e8\u6210\u5458\u8be6\u60c5\u3002\u5e94\u7528\u53ea\u80fd\u83b7\u53d6\u53ef\u89c1\u8303\u56f4\u5185\u7684\u6210\u5458\u4fe1\u606f\uff0c\u4e14\u6bcf\u79cd\u5e94\u7528\u83b7\u53d6\u7684\u5b57\u6bb5\u6709\u6240\u4e0d\u540c\uff0c\u5728\u8fd4\u56de\u7ed3\u679c\u8bf4\u660e\u4e2d\u4f1a\u9010\u4e2a\u8bf4\u660e\u3002\u4f01\u4e1a\u901a\u8baf\u5f55\u5b89\u5168\u7279\u522b\u91cd\u8981\uff0c\u4f01\u4e1a\u5fae\u4fe1\u6301\u7eed\u5347\u7ea7\u52a0\u56fa\u901a\u8baf\u5f55\u63a5\u53e3\u7684\u5b89\u5168\u673a\u5236\uff0c\u4ee5\u4e0b\u662f\u5173\u952e\u7684\u53d8\u66f4\u70b9\uff1a\u4ece 2022 \u5e74 6 \u6708 20 \u53f7 20 \u70b9\u5f00\u59cb\uff0c\u9664\u901a\u8baf\u5f55\u540c\u6b65\u4ee5\u5916\u7684\u57fa\u7840\u5e94\u7528\uff08\u5982\u5ba2\u6237\u8054\u7cfb\u3001\u5fae\u4fe1\u5ba2\u670d\u3001\u4f1a\u8bdd\u5b58\u6863\u3001\u65e5\u7a0b\u7b49\uff09\uff0c\u4ee5\u53ca\u65b0\u521b\u5efa\u7684\u81ea\u5efa\u5e94\u7528\u4e0e\u4ee3\u5f00\u53d1\u5e94\u7528\uff0c\u8c03\u7528\u8be5\u63a5\u53e3\u65f6\uff0c\u4e0d\u518d\u8fd4\u56de\u4ee5\u4e0b\u5b57\u6bb5\uff1a\u5934\u50cf\u3001\u6027\u522b\u3001\u624b\u673a\u3001\u90ae\u7bb1\u3001\u4f01\u4e1a\u90ae\u7bb1\u3001\u5458\u5de5\u4e2a\u4eba\u4e8c\u7ef4\u7801\u3001\u5730\u5740\uff0c\u5e94\u7528\u9700\u8981\u901a\u8fc7 `oauth2` \u624b\u5de5\u6388\u6743\u7684\u65b9\u5f0f\u83b7\u53d6\u7ba1\u7406\u5458\u4e0e\u5458\u5de5\u672c\u4eba\u6388\u6743\u7684\u5b57\u6bb5\u3002\u4ece 2022 \u5e74 8 \u6708 15 \u65e5 10 \u70b9\u5f00\u59cb\uff0c\\\"\u4f01\u4e1a\u7ba1\u7406\u540e\u53f0 - \u7ba1\u7406\u5de5\u5177 - \u901a\u8baf\u5f55\u540c\u6b65\\\"\u7684\u65b0\u589e IP \u5c06\u4e0d\u80fd\u518d\u8c03\u7528\u6b64\u63a5\u53e3\uff0c\u4f01\u4e1a\u53ef\u901a\u8fc7 \\\"\u83b7\u53d6\u6210\u5458 ID \u5217\u8868\\\" \u548c \\\"\u83b7\u53d6\u90e8\u95e8 ID \u5217\u8868\\\"\u63a5\u53e3\u83b7\u53d6 `userid` \u548c\u90e8\u95e8 ID \u5217\u8868\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_CONVERT_USERID_TO_OPENID\": [\r\n \"/cgi-bin/user/convert_to_openid?access_token=ACCESS_TOKEN\",\r\n \"POST\",\r\n \"userid \u4e0e openid \u4e92\u6362\u3002\u8be5\u63a5\u53e3\u4f7f\u7528\u573a\u666f\u4e3a\u4f01\u4e1a\u652f\u4ed8\uff0c\u5728\u4f7f\u7528\u4f01\u4e1a\u7ea2\u5305\u548c\u5411\u5458\u5de5\u4ed8\u6b3e\u65f6\uff0c\u9700\u8981\u81ea\u884c\u5c06\u4f01\u4e1a\u5fae\u4fe1\u7684 `userid` \u8f6c\u6210 `openid`\u3002\u6ce8\uff1a\u9700\u8981\u6210\u5458\u4f7f\u7528\u5fae\u4fe1\u767b\u5f55\u4f01\u4e1a\u5fae\u4fe1\u6216\u8005\u5173\u6ce8\u5fae\u4fe1\u63d2\u4ef6\uff08\u539f\u4f01\u4e1a\u53f7\uff09\u624d\u80fd\u8f6c\u6210 `openid`\uff1b\u5982\u679c\u662f\u5916\u90e8\u8054\u7cfb\u4eba\uff0c\u8bf7\u4f7f\u7528\u5916\u90e8\u8054\u7cfb\u4eba `openid` \u8f6c\u6362\u8f6c\u6362 `openid`\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_CONVERT_OPENID_TO_USERID\": [\r\n \"/cgi-bin/user/convert_to_userid?access_token=ACCESS_TOKEN\",\r\n \"POST\",\r\n \"openid \u8f6c userid\u3002\u8be5\u63a5\u53e3\u4e3b\u8981\u5e94\u7528\u4e8e\u4f7f\u7528\u4f01\u4e1a\u652f\u4ed8\u4e4b\u540e\u7684\u7ed3\u679c\u67e5\u8be2\u3002\u5f00\u53d1\u8005\u9700\u8981\u77e5\u9053\u67d0\u4e2a\u7ed3\u679c\u4e8b\u4ef6\u7684 `openid` \u5bf9\u5e94\u4f01\u4e1a\u5fae\u4fe1\u5185\u6210\u5458\u7684\u4fe1\u606f\u65f6\uff0c\u53ef\u4ee5\u901a\u8fc7\u8c03\u7528\u8be5\u63a5\u53e3\u8fdb\u884c\u8f6c\u6362\u67e5\u8be2\u3002\"\r\n ]\r\n },\r\n {\r\n \"WXWORK_USER_AUTH_SUCCESS\": [\r\n \"/cgi-bin/user/authsucc?access_token=ACCESS_TOKEN\",\r\n \"GET\",\r\n \"\u767b\u5f55\u4e8c\u6b21\u9a8c\u8bc1\u3002\u6b64\u63a5\u53e3\u53ef\u4ee5\u6ee1\u8db3\u5b89\u5168\u6027\u8981\u6c42\u9ad8\u7684\u4f01\u4e1a\u8fdb\u884c\u6210\u5458\u9a8c\u8bc1\u3002\u5f00\u542f\u4e8c\u6b21\u9a8c\u8bc1\u540e\uff0c\u5f53\u4e14\u4ec5\u5f53\u6210\u5458\u767b\u5f55\u65f6\uff0c\u9700\u8df3\u8f6c\u81f3\u4f01\u4e1a\u81ea\u5b9a\u4e49\u7684\u9875\u9762\u8fdb\u884c\u9a8c\u8bc1\u3002\u9a8c\u8bc1\u9891\u7387\u53ef\u5728\u8bbe\u7f6e\u9875\u9762\u9009\u62e9\u3002\u4f01\u4e1a\u5728\u5f00\u542f\u4e8c\u6b21\u9a8c\u8bc1\u65f6\uff0c\u5fc5\u987b\u5728\u7ba1\u7406\u7aef\u586b\u5199\u4f01\u4e1a\u4e8c\u6b21\u9a8c\u8bc1\u9875\u9762\u7684 url\u3002\u5f53\u6210\u5458\u767b\u5f55\u4f01\u4e1a\u5fae\u4fe1\u6216\u5173\u6ce8\u5fae\u4fe1\u63d2\u4ef6\uff08\u539f\u4f01\u4e1a\u53f7\uff09\u8fdb\u5165\u4f01\u4e1a\u65f6\uff0c\u4f1a\u81ea\u52a8\u8df3\u8f6c\u5230\u4f01\u4e1a\u7684\u9a8c\u8bc1\u9875\u9762\u3002\u5728\u8df3\u8f6c\u5230\u4f01\u4e1a\u7684\u9a8c\u8bc1\u9875\u9762\u65f6\uff0c\u4f1a\u5e26\u4e0a\u5982\u4e0b\u53c2\u6570\uff1a`code=CODE`\u3002\u4f01\u4e1a\u6536\u5230 code \u540e\uff0c\u4f7f\u7528 \\\"\u901a\u8baf\u5f55\u540c\u6b65\u52a9\u624b\\\" \u8c03\u7528\u63a5\u53e3 \\\"\u6839\u636e code \u83b7\u53d6\u6210\u5458\u4fe1\u606f\\\" \u83b7\u53d6\u6210\u5458\u7684 `userid`\u3002\"\r\n ]\r\n }\r\n ]\r\n\r\n- \u5982\u4e0a\u6240\u793a\uff0c\u8fd4\u56de\u7ed3\u679c\u662f\u4e00\u4e2a\u5b57\u5178\u5217\u8868\uff0c\u5176\u4e2d\u6bcf\u4e2a\u5b57\u5178\u5305\u542b\u4e09\u4e2a\u5173\u952e\u90e8\u5206\uff1a\u4e00\u662f API \u8def\u5f84\u6bb5\uff08\u81ea\u52a8\u8865\u5168\u5b8c\u6574 URL\uff09\uff0c\u4e8c\u662f\u8bf7\u6c42\u65b9\u6cd5\uff08GET \u6216 POST\uff09\uff0c\u4e09\u662f\u8be5\u63a5\u53e3\u7684\u63cf\u8ff0\u6027\u6ce8\u91ca\u3002\r\n\r\n- \u5047\u8bbe\u60a8\u8981\u83b7\u53d6\u67d0\u4f4d\u6210\u5458\u8be6\u7ec6\u4fe1\u606f\uff0c\u60a8\u53ef\u6309\u7167\u5982\u4e0b\u65b9\u5f0f\u8c03\u7528\u5bf9\u5e94 API\uff1a\r\n\r\n .. code:: bash\r\n\r\n from wxapis import WXWORK_GET_USER\r\n from wxapis.corporate import CorpApis\r\n from wxapis.abstract import ApiException\r\n import json\r\n\r\n try:\r\n wx = CorpApis(\r\n corpid=\"\", # \u586b\u5199\u60a8\u516c\u53f8 ID\r\n agentid=\"\", # \u586b\u5199\u60a8\u5e94\u7528 ID\r\n secret=\"\" # \u586b\u5199\u60a8\u5e94\u7528\u5bc6\u94a5\r\n )\r\n users = wx.httpReq(\r\n api=WXWORK_GET_USER,\r\n params={\r\n \"userid\": \"\" # \u586b\u5199\u8981\u67e5\u8be2\u7684\u7528\u6237 ID\r\n }\r\n )\r\n print(\r\n json.dumps(\r\n users,\r\n ensure_ascii=False,\r\n indent=4\r\n )\r\n )\r\n except ApiException as err:\r\n print(str(err))\r\n\r\n- \u6700\u7ec8\u8fd4\u56de\u7684\u7528\u6237\u8be6\u60c5\u5982\u4e0b\uff1a\r\n\r\n .. code:: bash\r\n\r\n {\r\n \"errcode\": 0,\r\n \"errmsg\": \"ok\",\r\n \"userid\": \"\",\r\n \"name\": \"\",\r\n \"department\": [],\r\n \"position\": \"\",\r\n \"status\": 1,\r\n \"isleader\": 0,\r\n \"extattr\": {\r\n \"attrs\": []\r\n },\r\n \"telephone\": \"\",\r\n \"enable\": 1,\r\n \"hide_mobile\": 0,\r\n \"order\": [],\r\n \"alias\": \"\",\r\n \"is_leader_in_dept\": [],\r\n \"direct_leader\": []\r\n }\r\n\r\n- \u5728\u4f7f\u7528\u6211\u4eec\u7684\u4f01\u4e1a\u5fae\u4fe1 API \u63a5\u53e3\u5305\u65f6\uff0c\u60a8\u53ef\u80fd\u4f1a\u53d1\u73b0\u5e76\u975e\u6240\u6709\u7684\u4f01\u4e1a\u5fae\u4fe1\u5b98\u65b9 API \u63a5\u53e3\u90fd\u88ab\u76f4\u63a5\u5c01\u88c5\u5728\u5305\u4e2d\u3002\u5982\u679c\u60a8\u9700\u8981\u8bbf\u95ee\u672a\u88ab\u5b9a\u4e49\u7684\u63a5\u53e3\uff0c\u60a8\u53ef\u4ee5\u8f7b\u677e\u5730\u81ea\u5b9a\u4e49\u4e00\u4e2a\u63a5\u53e3\u5143\u7ec4\u6216\u5217\u8868\u6765\u5b9e\u73b0\u8fd9\u4e00\u9700\u6c42\u3002\u5728\u6784\u5efa\u81ea\u5b9a\u4e49\u63a5\u53e3\u5143\u7ec4\u6216\u5217\u8868\u65f6\uff0c\u8bf7\u786e\u4fdd\u81f3\u5c11\u5305\u542b\u4e24\u4e2a\u5fc5\u8981\u7684\u5143\u7d20\uff1a\u63a5\u53e3\u7684\u77ed\u8def\u5f84\u548c HTTP \u8bf7\u6c42\u65b9\u6cd5\uff08\u5982 GET \u6216 POST\uff09\u3002\u8fd9\u4e24\u9879\u662f\u8c03\u7528\u4efb\u4f55\u4f01\u4e1a\u5fae\u4fe1 API \u65f6\u4e0d\u53ef\u6216\u7f3a\u7684\u4fe1\u606f\u3002\u81f3\u4e8e\u5176\u4ed6\u53c2\u6570\uff0c\u6839\u636e\u5b9e\u9645\u8bf7\u6c42\u9700\u6c42\u6765\u51b3\u5b9a\u662f\u5426\u6dfb\u52a0\u3002\u4f9d\u7136\u4ee5\u83b7\u53d6\u67d0\u6210\u5458\u7684\u4fe1\u606f\u4e3a\u4f8b\uff1a\r\n\r\n .. code:: bash\r\n\r\n from wxapis.corporate import CorpApis\r\n from wxapis.abstract import ApiException\r\n import json\r\n\r\n try:\r\n wx = CorpApis(\r\n corpid=\"\", # \u586b\u5199\u60a8\u516c\u53f8 ID\r\n agentid=\"\", # \u586b\u5199\u60a8\u5e94\u7528 ID\r\n secret=\"\" # \u586b\u5199\u60a8\u5e94\u7528\u5bc6\u94a5\r\n )\r\n users = wx.httpReq(\r\n # \u4f7f\u7528\u5143\u7ec4\u6216\u8005\u5217\u8868\uff0c\u4e14\u524d\u4e24\u9879\u5143\u7d20\u7684\u5185\u5bb9\u56fa\u5b9a\uff0c\u5373\u8bf7\u6c42\u77ed\u8def\u5f84\u548c\u8bf7\u6c42\u65b9\u6cd5\r\n api=(\r\n \"/cgi-bin/user/get?access_token=ACCESS_TOKEN\",\r\n \"GET\"\r\n ),\r\n params={\r\n \"userid\": \"\" # \u586b\u5199\u8981\u67e5\u8be2\u7684\u7528\u6237 ID\r\n }\r\n )\r\n print(\r\n json.dumps(\r\n users,\r\n ensure_ascii=False,\r\n indent=4\r\n )\r\n )\r\n except ApiException as err:\r\n print(str(err))\r\n\r\n- \u6700\u7ec8\u8fd4\u56de\u7684\u7528\u6237\u8be6\u60c5\u5982\u4e0b\uff1a\r\n\r\n .. code:: bash\r\n\r\n {\r\n \"errcode\": 0,\r\n \"errmsg\": \"ok\",\r\n \"userid\": \"\",\r\n \"name\": \"\",\r\n \"department\": [],\r\n \"position\": \"\",\r\n \"status\": 1,\r\n \"isleader\": 0,\r\n \"extattr\": {\r\n \"attrs\": []\r\n },\r\n \"telephone\": \"\",\r\n \"enable\": 1,\r\n \"hide_mobile\": 0,\r\n \"order\": [],\r\n \"alias\": \"\",\r\n \"is_leader_in_dept\": [],\r\n \"direct_leader\": []\r\n }\r\n\r\n\u9ad8\u7ea7\r\n~~~~\r\n\r\n- \u9664\u6807\u51c6 API \u8c03\u7528\u5916\uff0c\u672c\u5de5\u5177\u5305\u8fd8\u63d0\u4f9b\u4e86\u6267\u884c\u7279\u5b9a\u64cd\u4f5c\u4f8b\u5982\u5411\u67d0\u4e2a\u5e94\u7528\u53d1\u9001\u6d88\u606f\u7b49\u9ad8\u7ea7\u529f\u80fd\u3002\u5b89\u88c5\u672c\u5de5\u5177\u5305\u540e\uff0c\u5728\u7cfb\u7edf\u8def\u5f84\u4e2d\u5c06\u81ea\u52a8\u6dfb\u52a0\u4e00\u4e2a\u4e13\u95e8\u547d\u4ee4\u4ee5\u4fbf\u53d1\u9001\u6d88\u606f\u81f3\u4f01\u4e1a\u5fae\u4fe1\u5e94\u7528\u3002\u5982\u4e0b\u6240\u793a\uff1a\r\n\r\n .. code:: \r\n\r\n $ which smsg\r\n /d/Python/Python38/Scripts/smsg\r\n\r\n $ smsg --help\r\n usage: smsg.py [-h] -c CORPID -s SECRET -i AGENTID -m MESSAGE [-a FIELD] [-f {json,yaml}]\r\n [-l {DEBUG,INFO,WARNING,ERROR,CRITICAL}]\r\n\r\n \u53d1\u9001\u4f01\u4e1a\u5fae\u4fe1\u5185\u90e8\u5e94\u7528\u6d88\u606f\u3002\r\n\r\n optional arguments:\r\n -h, --help \u663e\u793a\u6b64\u5e2e\u52a9\u4fe1\u606f\u5e76\u9000\u51fa\u3002\r\n -c CORPID, --corpid CORPID\r\n \u4f01\u4e1a\u5fae\u4fe1\u7684\u4f01\u4e1a id\u3002\u53ef\u4ee5\u5728\u4f01\u4e1a\u5fae\u4fe1\u7ba1\u7406\u540e\u53f0\u83b7\u53d6\u6b64 id\u3002\u6b64\u9009\u9879\u4e3a\u5fc5\u987b\u9009\u9879\u3002\r\n -s SECRET, --secret SECRET\r\n \u4e0e\u4f01\u4e1a\u5fae\u4fe1\u5185\u5e94\u7528\u5173\u8054\u7684 secret\u3002secret \u7528\u4e8e\u9a8c\u8bc1\u8eab\u4efd\u5e76\u52a0\u5bc6\u901a\u8baf\u8fc7\u7a0b\uff0c\u53ef\u5728\u4f01\u4e1a\u5fae\u4fe1\u7ba1\u7406\u540e\u53f0\u627e\u5230\u3002\u6b64\u9009\u9879\u4e3a\u5fc5\u987b\u9009\u9879\u3002\r\n -i AGENTID, --agentid AGENTID\r\n \u4f01\u4e1a\u5fae\u4fe1\u5185\u5e94\u7528\u7684 agent id\uff0c\u4ee3\u8868\u4e86\u5e94\u7528\u5b9e\u4f53\uff0c\u5728\u4f01\u4e1a\u5fae\u4fe1\u4e2d\u552f\u4e00\u6807\u8bc6\u4e00\u4e2a\u5e94\u7528\u3002\u8bf7\u786e\u4fdd\u4f20\u5165\u6b63\u786e\u7684 agent id\u3002\u6b64\u9009\u9879\u4e3a\u5fc5\u987b\u9009\u9879\u3002\r\n -m MESSAGE, --message MESSAGE\r\n \u8981\u53d1\u9001\u7ed9\u4f01\u4e1a\u5fae\u4fe1\u5e94\u7528\u7684\u6d88\u606f\u6587\u672c\u5185\u5bb9\u3002\u6b64\u9009\u9879\u4e3a\u5fc5\u987b\u9009\u9879\u3002\r\n -a FIELD, --field FIELD\r\n \u6d88\u606f\u4f53\u5b57\u6bb5\uff0c\u683c\u5f0f\u4e3a \"k=v\"\uff0c\u6dfb\u52a0\u6216\u8986\u76d6\u53c2\u6570 `message` \u4e2d\u5b57\u6bb5\u7684\u503c\uff0c\u4f8b\u5982 \"-a text.content=xxx\"\u3002\u6b64\u9009 \u9879\u4e3a\u53ef\u9009\u9009\u9879\u3002\r\n -f {json,yaml}, --format {json,yaml}\r\n \u5b9a\u4e49\u53c2\u6570 `message` \u6587\u672c\u5185\u5bb9\u7684\u89e3\u6790\u683c\u5f0f\uff0c\u9ed8\u8ba4\u4e3a \"json\"\u3002\u6b64\u9009\u9879\u4e3a\u53ef\u9009\u9009\u9879\u3002\r\n -l {DEBUG,INFO,WARNING,ERROR,CRITICAL}, --level {DEBUG,INFO,WARNING,ERROR,CRITICAL}\r\n \u8bbe\u7f6e\u8f93\u51fa\u65e5\u5fd7\u7ea7\u522b\uff0c\u9ed8\u8ba4\u4e3a \"INFO\"\uff0c\u5728\u547d\u4ee4\u884c\u4f20\u5165\u65f6\u4e0d\u533a\u5206\u5927\u5c0f\u5199\uff0c\u6bd4\u5982\u4f20\u5165 \"DEBUG\" \u548c\u4f20\u5165 \"debug\" \u4e00 \u6837\u3002\u6b64\u9009\u9879\u4e3a\u53ef\u9009\u9009\u9879\u3002\r\n\r\n- \u6839\u636e\u547d\u4ee4\u884c\u53c2\u6570\u6307\u5357\uff0c\u60a8\u53ef\u4ee5\u8f7b\u677e\u5730\u901a\u8fc7\u76f8\u5e94\u547d\u4ee4\u5411\u4f01\u4e1a\u5fae\u4fe1\u4e2d\u53d1\u9001\u6d88\u606f\uff1a\r\n\r\n .. code:: \r\n\r\n PS E:\\PycharmProjects\\self\\wxapis> smsg --corpid \"\" --agentid \"\" --secret \"\" --message '{\\\"touser\\\": \\\"\\\", \\\"agentid\\\": \"\", \\\"msgtype\\\": \\\"text\\\", \\\"text\\\": {\\\"content\\\": \\\"\u8fd9\u662f\u6d4b\u8bd5\uff01\\\"}, \\\"safe\\\": 0, \\\"enable_id_trans\\\":0, \\\"enable_duplicate_check\\\": 0}' -a \"text.content=test!!!\"\r\n INFO:root:\u53d1\u9001\u6d88\u606f[{'touser': '', 'agentid': '', 'msgtype': 'text', 'text': {'content': 'test!!!'}, 'safe': 0, 'enable_id_trans': 0, 'enable_duplicate_check': 0}]\u3002\r\n INFO:root:\u4efb\u52a1\u6267\u884c\uff1a\"True\"\u3002\r\n\r\n- \u5982\u679c\u60a8\u9700\u8981\u5ba1\u67e5\u6d88\u606f\u53d1\u9001\u8be6\u60c5\uff0c\u8bf7\u786e\u4fdd\u8bbe\u7f6e\u5408\u9002\u7684\u65e5\u5fd7\u7ea7\u522b\u4ee5\u4fbf\u83b7\u5f97\u8be6\u7ec6\u8f93\u51fa\uff1a\r\n\r\n .. code:: \r\n\r\n PS E:\\PycharmProjects\\self\\wxapis> smsg --corpid \"\" --agentid \"\" --secret \"\" --message '{\\\"touser\\\": \\\"\\\", \\\"agentid\\\": \"\", \\\"msgtype\\\": \\\"text\\\", \\\"text\\\": {\\\"content\\\": \\\"\u8fd9\u662f\u6d4b\u8bd5\uff01\\\"}, \\\"safe\\\": 0, \\\"enable_id_trans\\\":0, \\\"enable_duplicate_check\\\": 0}' -a \"text.content=test!!!\" --level debug\r\n DEBUG:root:Namespace(agentid='', corpid='', field=['text.content=test!!!'], format='json', level='DEBUG', message='{\"touser\": \"\", \"agentid\": '', \"msgtype\": \"text\", \"text\": {\"content\": \"\u8fd9\u662f\u6d4b\u8bd5\uff01\"}, \"safe\": 0, \"enable_id_trans\":0, \"enable_duplicate_check\": 0}', secret='')\r\n DEBUG:urllib3.connectionpool:Starting new HTTPS connection (1): qyapi.weixin.qq.com:443\r\n DEBUG:urllib3.connectionpool:https://qyapi.weixin.qq.com:443 \"POST /cgi-bin/message/send?access_token=xxx HTTP/11\" 200 124\r\n INFO:root:\u53d1\u9001\u6d88\u606f[{'touser': '', 'agentid': '', 'msgtype': 'text', 'text': {'content': 'test!!!'}, 'safe': 0, 'enable_id_trans': 0, 'enable_duplicate_check': 0}]\u3002\r\n INFO:root:\u4efb\u52a1\u6267\u884c\uff1a\"True\"\u3002\r\n\r\n\r\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "\u4f01\u4e1a\u5fae\u4fe1\u670d\u52a1\u7aef API \u64cd\u4f5c\u5e93\u3002",
"version": "2.0.0",
"project_urls": {
"Documentation": "https://github.com/gary714/wxapis",
"Homepage": "https://github.com/gary714/wxapis",
"Source": "https://github.com/gary714/wxapis"
},
"split_keywords": [
"wechat",
" wxwork"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "a991ea4fb45d8de70cbdee8144e77eb798ae45a4708593afff24da227fe60928",
"md5": "87ad93a277454994394223fa52c125e7",
"sha256": "da6f8d6fbb7e4c6460b435500c8c06426e8f0200703e3883a5533fb665e3fe88"
},
"downloads": -1,
"filename": "wxapis-2.0.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "87ad93a277454994394223fa52c125e7",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 36325,
"upload_time": "2024-11-18T07:38:01",
"upload_time_iso_8601": "2024-11-18T07:38:01.796934Z",
"url": "https://files.pythonhosted.org/packages/a9/91/ea4fb45d8de70cbdee8144e77eb798ae45a4708593afff24da227fe60928/wxapis-2.0.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "6c1d82f2fc7d164925468abdbc55843febe501f9f8a0860095094100b0a23128",
"md5": "2267a7d826c8f4e70caf197a273b37b0",
"sha256": "8f0aba15c113e0c8055f9a3d2ad68457aa561c605badb7a1a432429d86dc7a0d"
},
"downloads": -1,
"filename": "wxapis-2.0.0.tar.gz",
"has_sig": false,
"md5_digest": "2267a7d826c8f4e70caf197a273b37b0",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 38070,
"upload_time": "2024-11-18T07:38:04",
"upload_time_iso_8601": "2024-11-18T07:38:04.644008Z",
"url": "https://files.pythonhosted.org/packages/6c/1d/82f2fc7d164925468abdbc55843febe501f9f8a0860095094100b0a23128/wxapis-2.0.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-11-18 07:38:04",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "gary714",
"github_project": "wxapis",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [],
"lcname": "wxapis"
}