{"id":181,"date":"2026-01-23T02:58:32","date_gmt":"2026-01-23T02:58:32","guid":{"rendered":"https:\/\/blog.gpst.net.cn:4008\/?p=181"},"modified":"2026-01-28T06:24:15","modified_gmt":"2026-01-28T06:24:15","slug":"%e4%bc%81%e4%b8%9a%e5%be%ae%e4%bf%a1-%e5%8f%91%e9%80%81%e6%b6%88%e6%81%af%e7%9a%84bash-shell%e8%84%9a%e6%9c%ac","status":"publish","type":"post","link":"https:\/\/opshub.com.cn\/?p=181","title":{"rendered":"\u4f01\u4e1a\u5fae\u4fe1\u2014\u2014\u53d1\u9001\u6d88\u606f\u7684bash shell\u811a\u672c"},"content":{"rendered":"\n<pre class=\"wp-block-code\"><code>#!\/bin\/bash\n#\u5982\u679c\u643a\u5e264\u4e2a\u53c2\u6570\uff0c$1\u662f\u9644\u4ef6\u6587\u4ef6\uff0c\u6587\u4ef6\u4e0d\u5b58\u5728\u6216\u6b64\u5904\u4e3a\u7a7a\uff0c\u5219\u4f1a\u53ea\u4ee5\u6587\u672c\u6d88\u606f\u53d1\u9001\uff0c\u53cd\u4e4b\u4f1a\u53d1\u9001\u6587\u672c\u6d88\u606f\u548c\u6587\u672c\u6587\u4ef6\u6d88\u606f\n#$2\u662f\u5e94\u7528ID\n#$3\u662f\u7528\u6237ID\n#$4\u662f\u6587\u672c\u6d88\u606f\u5185\u5bb9\n#\u5982\u679c\u643a\u5e263\u4e2a\u53c2\u6570, $1\u662f\u5e94\u7528ID\n#$2\u662f\u7528\u6237ID\n#$3\u662f\u6587\u672c\u6d88\u606f\u5185\u5bb9\nif &#091;&#091; $# -eq 4 ]]; then\n\t_UpLoadFile_=\"$1\"\nfi\nCropID=''\nSecret=''\nGURL=\"https:\/\/qyapi.weixin.qq.com\/cgi-bin\/gettoken?corpid=$CropID&amp;corpsecret=$Secret\"\n\nGtoken=$(\/usr\/bin\/curl -s -G $GURL | awk -F'\"' '{print $10}')\n\nMUPURL=\"https:\/\/qyapi.weixin.qq.com\/cgi-bin\/media\/upload?access_token=$Gtoken&amp;type=file\"\nPURL=\"https:\/\/qyapi.weixin.qq.com\/cgi-bin\/message\/send?access_token=$Gtoken\"\nif &#091;&#091; -f \"$_UpLoadFile_\" ]]; then\n\tnewfilename=\"$(echo \"$(md5sum $_UpLoadFile_ | awk '{print $1}').$(date +%s%N).62e3f7499c2e8aa5af6fe58e0cecdaa3\" | md5sum | awk '{print $1}').txt\"\n\t\/bin\/cp -f $_UpLoadFile_ .\/$newfilename\n\tmedia_id=\"$(curl -s --form \"file=@$newfilename\" \"$MUPURL\" 2&gt;\/dev\/null | egrep -o \"\\\"media_id\\\":\\\"&#091;^\\\"]+\\\"\" | awk -F'\"' '{print $4}')\"\n\tif &#091;&#091; -z \"$media_id\" ]]; then\n\t\tmedia_id=\"$(curl -s --form \"file=@$newfilename\" \"$MUPURL\" 2&gt;\/dev\/null | egrep -o \"\\\"media_id\\\":\\\"&#091;^\\\"]+\\\"\" | awk -F'\"' '{print $4}')\"\n\tfi\nfi\nfunction body_file() {\n\tlocal int AppID=$1\n\tlocal UserID=\"$2\"\n\tlocal MediaID=\"$3\"\n\tlocal Msg=\"$(echo \"$@\" | awk '{$1=\"\";$2=\"\";$3=\"\";printf\"%s\\n\",$0}')\"\n\tprintf '{'\n\tprintf '\"touser\": '\"\\\"$UserID\\\"\"\",\"\n\tprintf '\"toparty\": '\"\\\"\\\"\"\",\"\n\tprintf '\"totag\": '\"\\\"\\\"\"\",\"\n\tprintf '\"toall\" : 0,'\n\tprintf '\"msgtype\": \"file\",'\n\tprintf '\"agentid\": '\"\\\"$AppID\\\"\"\",\"\n\tprintf '\"file\" : {'\n\tprintf '\"media_id\" : '\"\\\"$MediaID\\\"\"\n\tprintf '},'\n\tprintf '\"safe\":\"0\"'\n\tprintf '}'\n\n}\nfunction body_text() {\n\tlocal int AppID=$1\n\tlocal UserID=\"$2\"\n\tlocal Msg=\"$(echo \"$@\" | awk '{$1=\"\";$2=\"\";printf\"%s\\n\",$0}')\"\n\tprintf '{'\n\tprintf '\"touser\": '\"\\\"$UserID\\\"\"\",\"\n\tprintf '\"toparty\": '\"\\\"$PartyID\\\"\"\",\"\n\tprintf '\"msgtype\": \"text\",'\n\tprintf '\"agentid\": '\"\\\"$AppID\\\"\"\",\"\n\tprintf '\"text\": {'\n\tprintf '\"content\": '\n\techo -e \"\\\"$Msg\\\"\"\n\tprintf '},'\n\tprintf '\"safe\":\"0\"'\n\tprintf '}'\n\n}\nnginx_proxys=(-)\nfor ((i = 0; i &lt; ${#nginx_proxys&#091;@]}; i++)); do\n\tproxy=${nginx_proxys&#091;$i]}\n\tcase $proxy in\n\t-)\n\t\tif &#091;&#091; -n \"$media_id\" ]]; then\n\t\t\thttp_code=$(curl --connect-timeout 3 --no-keepalive --retry 3 -w '%{http_code}\\n' -s -o \/dev\/null --data-ascii \"$(body_text \"$2\" \"$3\" \"$4\\n\u6d88\u606f\u6587\u672c\u9644\u4ef6:\\n$newfilename\")\" $PURL 2&gt;\/dev\/null)\n\t\t\thttp_code=$(curl --connect-timeout 3 --no-keepalive --retry 3 -w '%{http_code}\\n' -s -o \/dev\/null --data-ascii \"$(body_file \"$2\" \"$3\" \"$media_id\")\" $PURL 2&gt;\/dev\/null)\n\t\telse\n\t\t\thttp_code=$(curl --connect-timeout 3 --no-keepalive --retry 3 -w '%{http_code}\\n' -s -o \/dev\/null --data-ascii \"$(body_text \"$1\" \"$2\" \"$3\")\" $PURL 2&gt;\/dev\/null)\n\t\tfi\n\t\t;;\n\t*)\n\t\tif &#091;&#091; -n \"$media_id\" ]]; then\n\t\t\thttp_code=$(curl -x $proxy --connect-timeout 3 --no-keepalive --retry 3 -w '%{http_code}\\n' -s -o \/dev\/null --data-ascii \"$(body_text \"$2\" \"$3\" \"$4\\n\u6d88\u606f\u6587\u672c\u9644\u4ef6:\\n$newfilename\")\" $PURL 2&gt;\/dev\/null)\n\t\t\thttp_code=$(curl -x $proxy --connect-timeout 3 --no-keepalive --retry 3 -w '%{http_code}\\n' -s -o \/dev\/null --data-ascii \"$(body_file \"$2\" \"$3\" \"$media_id\")\" $PURL 2&gt;\/dev\/null)\n\t\telse\n\t\t\thttp_code=$(curl -x $proxy --connect-timeout 3 --no-keepalive --retry 3 -w '%{http_code}\\n' -s -o \/dev\/null --data-ascii \"$(body_text \"$1\" \"$2\" \"$3\")\" $PURL 2&gt;\/dev\/null)\n\t\tfi\n\t\t;;\n\tesac\n\t&#091;&#091; $http_code == 200 ]] &amp;&amp; break\ndone\n<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>#!\/bin\/bash\n##############################################################################\n# \u811a\u672c\u540d\u79f0: wechat_work_msg.sh\n# \u811a\u672c\u529f\u80fd: \u4f01\u4e1a\u5fae\u4fe1\u6d88\u606f\u53d1\u9001\u811a\u672c\uff08\u652f\u6301\u6587\u672c\u6d88\u606f\/\u6587\u672c+\u6587\u4ef6\u9644\u4ef6\uff09\n# \u4f7f\u7528\u8bf4\u660e:\n#   1. \u5148\u914d\u7f6eCropID\uff08\u4f01\u4e1aID\uff09\u548cSecret\uff08\u5e94\u7528Secret\uff09\n#   2. \u4e24\u79cd\u8c03\u7528\u65b9\u5f0f\uff1a\n#      - \u4ec5\u6587\u672c\u6d88\u606f: .\/\u811a\u672c\u540d \u5e94\u7528ID \u7528\u6237ID \u6587\u672c\u5185\u5bb9\n#      - \u6587\u672c+\u6587\u4ef6:  .\/\u811a\u672c\u540d \u9644\u4ef6\u6587\u4ef6 \u5e94\u7528ID \u7528\u6237ID \u6587\u672c\u5185\u5bb9\n# \u4f9d\u8d56\u5de5\u5177: curl\u3001awk\u3001md5sum\n# \u6ce8\u610f\u4e8b\u9879:\n#   - \u9644\u4ef6\u6587\u4ef6\u5927\u5c0f\u9700\u7b26\u5408\u4f01\u4e1a\u5fae\u4fe1\u9650\u5236\uff08\u6587\u4ef6\u7c7b\u578b\u226420MB\uff09\n#   - \u786e\u4fdd\u670d\u52a1\u5668\u80fd\u8bbf\u95ee\u4f01\u4e1a\u5fae\u4fe1API\uff08https:\/\/qyapi.weixin.qq.com\uff09\n##############################################################################\n\n# ======================== \u914d\u7f6e\u9879\uff08\u5fc5\u586b\uff01\u8bf7\u66ff\u6362\u4e3a\u5b9e\u9645\u503c\uff09 ========================\nCropID=\"your_corp_id\"          # \u4f01\u4e1a\u5fae\u4fe1\u4f01\u4e1aID\uff08\u4ece\u4f01\u4e1a\u5fae\u4fe1\u540e\u53f0\u83b7\u53d6\uff09\nSecret=\"your_app_secret\"       # \u4f01\u4e1a\u5fae\u4fe1\u5e94\u7528Secret\uff08\u4ece\u5e94\u7528\u7ba1\u7406\u540e\u53f0\u83b7\u53d6\uff09\nTEMP_DIR=\"\/tmp\/wechat_msg\"     # \u4e34\u65f6\u6587\u4ef6\u5b58\u50a8\u76ee\u5f55\nLOG_FILE=\"\/var\/log\/wechat_msg.log\" # \u8fd0\u884c\u65e5\u5fd7\u6587\u4ef6\n\n# ======================== \u65e5\u5fd7\u51fd\u6570 ========================\nlog() {\n    local level=$1\n    local msg=$2\n    echo \"&#091;$(date +'%Y-%m-%d %H:%M:%S')] &#091;$level] $msg\" &gt;&gt; ${LOG_FILE}\n}\n\n# ======================== \u521d\u59cb\u5316 ========================\n# \u521b\u5efa\u4e34\u65f6\u76ee\u5f55\nmkdir -p ${TEMP_DIR}\nchmod 700 ${TEMP_DIR}\n\n# \u521d\u59cb\u5316\u53d8\u91cf\n_UpLoadFile_=\"\"\nmedia_id=\"\"\nnewfilename=\"\"\nhttp_code=\"\"\nerrcode=\"\"\n\n# ======================== \u53c2\u6570\u89e3\u6790 ========================\n# \u68c0\u67e5\u53c2\u6570\u6570\u91cf\nif &#091;&#091; $# -ne 3 &amp;&amp; $# -ne 4 ]]; then\n    log \"ERROR\" \"\u53c2\u6570\u6570\u91cf\u9519\u8bef\uff01\u7528\u6cd5\uff1a\"\n    log \"ERROR\" \"  \u4ec5\u6587\u672c: $0 &lt;\u5e94\u7528ID&gt; &lt;\u7528\u6237ID&gt; &lt;\u6587\u672c\u5185\u5bb9&gt;\"\n    log \"ERROR\" \"  \u6587\u672c+\u6587\u4ef6: $0 &lt;\u9644\u4ef6\u6587\u4ef6&gt; &lt;\u5e94\u7528ID&gt; &lt;\u7528\u6237ID&gt; &lt;\u6587\u672c\u5185\u5bb9&gt;\"\n    echo \"\u53c2\u6570\u6570\u91cf\u9519\u8bef\uff01\"\n    echo \"\u7528\u6cd5\uff1a\"\n    echo \"  \u4ec5\u6587\u672c: $0 &lt;\u5e94\u7528ID&gt; &lt;\u7528\u6237ID&gt; &lt;\u6587\u672c\u5185\u5bb9&gt;\"\n    echo \"  \u6587\u672c+\u6587\u4ef6: $0 &lt;\u9644\u4ef6\u6587\u4ef6&gt; &lt;\u5e94\u7528ID&gt; &lt;\u7528\u6237ID&gt; &lt;\u6587\u672c\u5185\u5bb9&gt;\"\n    exit 1\nfi\n\n# \u89e3\u6790\u53c2\u6570\nif &#091;&#091; $# -eq 4 ]]; then\n    _UpLoadFile_=\"$1\"\n    AppID=\"$2\"\n    UserID=\"$3\"\n    MsgContent=\"$4\"\n    log \"INFO\" \"\u6a21\u5f0f\uff1a\u6587\u672c+\u6587\u4ef6 | \u9644\u4ef6\u6587\u4ef6: $_UpLoadFile_ | \u5e94\u7528ID: $AppID | \u7528\u6237ID: $UserID\"\nelif &#091;&#091; $# -eq 3 ]]; then\n    AppID=\"$1\"\n    UserID=\"$2\"\n    MsgContent=\"$3\"\n    log \"INFO\" \"\u6a21\u5f0f\uff1a\u4ec5\u6587\u672c | \u5e94\u7528ID: $AppID | \u7528\u6237ID: $UserID\"\nfi\n\n# ======================== \u83b7\u53d6\u4f01\u4e1a\u5fae\u4fe1Access Token ========================\nGURL=\"https:\/\/qyapi.weixin.qq.com\/cgi-bin\/gettoken?corpid=${CropID}&amp;corpsecret=${Secret}\"\nlog \"INFO\" \"\u83b7\u53d6Token\u8bf7\u6c42URL: ${GURL}\"\n\n# \u8c03\u7528API\u83b7\u53d6token\ntoken_response=$(\/usr\/bin\/curl -s --connect-timeout 5 --retry 2 ${GURL})\nGtoken=$(echo ${token_response} | awk -F'\"' '{print $10}')\n\n# \u6821\u9a8ctoken\u662f\u5426\u83b7\u53d6\u6210\u529f\nif &#091;&#091; -z ${Gtoken} || ${Gtoken} == \"null\" ]]; then\n    log \"ERROR\" \"\u83b7\u53d6Token\u5931\u8d25\uff01\u54cd\u5e94\u5185\u5bb9: ${token_response}\"\n    echo \"\u83b7\u53d6\u4f01\u4e1a\u5fae\u4fe1Token\u5931\u8d25\uff01\"\n    exit 1\nfi\nlog \"INFO\" \"\u83b7\u53d6Token\u6210\u529f: ${Gtoken:0:10}...\" # \u4ec5\u6253\u5370\u524d10\u4f4d\uff0c\u907f\u514d\u6cc4\u9732\n\n# ======================== \u4e0a\u4f20\u9644\u4ef6\u6587\u4ef6\uff08\u5982\u6709\uff09 ========================\nMUPURL=\"https:\/\/qyapi.weixin.qq.com\/cgi-bin\/media\/upload?access_token=${Gtoken}&amp;type=file\"\nif &#091;&#091; -f \"${_UpLoadFile_}\" &amp;&amp; -r \"${_UpLoadFile_}\" ]]; then\n    log \"INFO\" \"\u5f00\u59cb\u4e0a\u4f20\u9644\u4ef6\u6587\u4ef6: ${_UpLoadFile_}\"\n    \n    # \u751f\u6210\u552f\u4e00\u4e34\u65f6\u6587\u4ef6\u540d\uff08\u907f\u514d\u51b2\u7a81\uff09\n    newfilename=\"${TEMP_DIR}\/$(echo \"$(md5sum ${_UpLoadFile_} | awk '{print $1}').$(date +%s%N)\" | md5sum | awk '{print $1}').txt\"\n    \n    # \u590d\u5236\u6587\u4ef6\u5230\u4e34\u65f6\u76ee\u5f55\n    \/bin\/cp -f ${_UpLoadFile_} ${newfilename}\n    if &#091;&#091; $? -ne 0 ]]; then\n        log \"ERROR\" \"\u590d\u5236\u9644\u4ef6\u6587\u4ef6\u5931\u8d25: ${_UpLoadFile_} -&gt; ${newfilename}\"\n        echo \"\u590d\u5236\u9644\u4ef6\u6587\u4ef6\u5931\u8d25\uff01\"\n        exit 1\n    fi\n    \n    # \u4e0a\u4f20\u6587\u4ef6\u5230\u4f01\u4e1a\u5fae\u4fe1\n    upload_response=$(curl -s --connect-timeout 10 --retry 2 --form \"file=@${newfilename}\" \"${MUPURL}\")\n    media_id=$(echo ${upload_response} | egrep -o \"\\\"media_id\\\":\\\"&#091;^\\\"]+\\\"\" | awk -F'\"' '{print $4}')\n    \n    # \u7b2c\u4e00\u6b21\u4e0a\u4f20\u5931\u8d25\uff0c\u91cd\u8bd5\u4e00\u6b21\n    if &#091;&#091; -z ${media_id} ]]; then\n        log \"WARN\" \"\u7b2c\u4e00\u6b21\u4e0a\u4f20\u6587\u4ef6\u5931\u8d25\uff0c\u91cd\u8bd5\uff01\u54cd\u5e94: ${upload_response}\"\n        sleep 1\n        upload_response=$(curl -s --connect-timeout 10 --retry 2 --form \"file=@${newfilename}\" \"${MUPURL}\")\n        media_id=$(echo ${upload_response} | egrep -o \"\\\"media_id\\\":\\\"&#091;^\\\"]+\\\"\" | awk -F'\"' '{print $4}')\n    fi\n    \n    # \u6821\u9a8c\u4e0a\u4f20\u7ed3\u679c\n    if &#091;&#091; -z ${media_id} ]]; then\n        log \"ERROR\" \"\u6587\u4ef6\u4e0a\u4f20\u5931\u8d25\uff01\u54cd\u5e94\u5185\u5bb9: ${upload_response}\"\n        echo \"\u9644\u4ef6\u6587\u4ef6\u4e0a\u4f20\u5931\u8d25\uff01\"\n        # \u6e05\u7406\u4e34\u65f6\u6587\u4ef6\n        rm -f ${newfilename}\n        exit 1\n    fi\n    log \"INFO\" \"\u6587\u4ef6\u4e0a\u4f20\u6210\u529f\uff0cmedia_id: ${media_id:0:10}...\"\nelse\n    if &#091;&#091; -n \"${_UpLoadFile_}\" ]]; then\n        log \"WARN\" \"\u9644\u4ef6\u6587\u4ef6\u4e0d\u5b58\u5728\u6216\u4e0d\u53ef\u8bfb: ${_UpLoadFile_}\uff0c\u5c06\u4ec5\u53d1\u9001\u6587\u672c\u6d88\u606f\"\n        echo \"\u9644\u4ef6\u6587\u4ef6\u4e0d\u5b58\u5728\u6216\u4e0d\u53ef\u8bfb\uff0c\u5c06\u4ec5\u53d1\u9001\u6587\u672c\u6d88\u606f\uff01\"\n    fi\nfi\n\n# ======================== \u6784\u9020\u6d88\u606fJSON\u51fd\u6570 ========================\n# \u6784\u9020\u6587\u4ef6\u6d88\u606fJSON\nbody_file() {\n    local AppID=$1\n    local UserID=$2\n    local MediaID=$3\n    \n    cat &lt;&lt; EOF\n{\n    \"touser\": \"${UserID}\",\n    \"toparty\": \"\",\n    \"totag\": \"\",\n    \"msgtype\": \"file\",\n    \"agentid\": \"${AppID}\",\n    \"file\": {\n        \"media_id\": \"${MediaID}\"\n    },\n    \"safe\": \"0\"\n}\nEOF\n}\n\n# \u6784\u9020\u6587\u672c\u6d88\u606fJSON\nbody_text() {\n    local AppID=$1\n    local UserID=$2\n    local Msg=$3\n    \n    # \u8f6c\u4e49JSON\u7279\u6b8a\u5b57\u7b26\uff08\\\u3001\"\u3001\u6362\u884c\uff09\n    Msg=$(echo \"${Msg}\" | sed -e 's\/\\\\\/\\\\\\\\\/g' -e 's\/\"\/\\\\\"\/g' -e 's\/\\n\/\\\\n\/g')\n    \n    cat &lt;&lt; EOF\n{\n    \"touser\": \"${UserID}\",\n    \"toparty\": \"\",\n    \"totag\": \"\",\n    \"msgtype\": \"text\",\n    \"agentid\": \"${AppID}\",\n    \"text\": {\n        \"content\": \"${Msg}\"\n    },\n    \"safe\": \"0\"\n}\nEOF\n}\n\n# ======================== \u53d1\u9001\u6d88\u606f ========================\nPURL=\"https:\/\/qyapi.weixin.qq.com\/cgi-bin\/message\/send?access_token=${Gtoken}\"\nlog \"INFO\" \"\u6d88\u606f\u53d1\u9001URL: ${PURL}\"\n\n# \u4ee3\u7406\u914d\u7f6e\uff08\u5982\u9700\u4f7f\u7528\u4ee3\u7406\uff0c\u4fee\u6539\u6b64\u5904\uff09\nnginx_proxys=(-)\n\n# \u904d\u5386\u4ee3\u7406\u53d1\u9001\u6d88\u606f\nfor proxy in \"${nginx_proxys&#091;@]}\"; do\n    # \u6784\u5efacurl\u53c2\u6570\uff08\u662f\u5426\u4f7f\u7528\u4ee3\u7406\uff09\n    curl_proxy=\"\"\n    if &#091;&#091; ${proxy} != \"-\" ]]; then\n        curl_proxy=\"-x ${proxy}\"\n        log \"INFO\" \"\u4f7f\u7528\u4ee3\u7406: ${proxy}\"\n    fi\n    \n    # \u53d1\u9001\u6d88\u606f\u903b\u8f91\n    if &#091;&#091; -n \"${media_id}\" ]]; then\n        # 1. \u53d1\u9001\u6587\u672c\u6d88\u606f\uff08\u5305\u542b\u9644\u4ef6\u8bf4\u660e\uff09\n        text_msg=\"${MsgContent}\\n\u6d88\u606f\u6587\u672c\u9644\u4ef6:\\n$(basename ${_UpLoadFile_})\"\n        text_json=$(body_text \"${AppID}\" \"${UserID}\" \"${text_msg}\")\n        log \"INFO\" \"\u53d1\u9001\u6587\u672c\u6d88\u606fJSON: ${text_json:0:100}...\"\n        \n        send_response=$(curl ${curl_proxy} --connect-timeout 5 --no-keepalive --retry 3 -w 'HTTP_CODE:%{http_code}\\n' -s -o - --data-ascii \"${text_json}\" ${PURL})\n        http_code=$(echo ${send_response} | grep -o \"HTTP_CODE:&#091;0-9]*\" | awk -F':' '{print $2}')\n        errcode=$(echo ${send_response} | egrep -o \"\\\"errcode\\\":&#091;0-9]+\" | awk -F':' '{print $2}')\n        \n        log \"INFO\" \"\u6587\u672c\u6d88\u606f\u53d1\u9001\u54cd\u5e94\uff1aHTTP_CODE=${http_code}, errcode=${errcode}\"\n        \n        # 2. \u53d1\u9001\u6587\u4ef6\u6d88\u606f\n        file_json=$(body_file \"${AppID}\" \"${UserID}\" \"${media_id}\")\n        log \"INFO\" \"\u53d1\u9001\u6587\u4ef6\u6d88\u606fJSON: ${file_json:0:100}...\"\n        \n        send_response=$(curl ${curl_proxy} --connect-timeout 5 --no-keepalive --retry 3 -w 'HTTP_CODE:%{http_code}\\n' -s -o - --data-ascii \"${file_json}\" ${PURL})\n        http_code=$(echo ${send_response} | grep -o \"HTTP_CODE:&#091;0-9]*\" | awk -F':' '{print $2}')\n        errcode=$(echo ${send_response} | egrep -o \"\\\"errcode\\\":&#091;0-9]+\" | awk -F':' '{print $2}')\n        \n        log \"INFO\" \"\u6587\u4ef6\u6d88\u606f\u53d1\u9001\u54cd\u5e94\uff1aHTTP_CODE=${http_code}, errcode=${errcode}\"\n    else\n        # \u4ec5\u53d1\u9001\u6587\u672c\u6d88\u606f\n        text_json=$(body_text \"${AppID}\" \"${UserID}\" \"${MsgContent}\")\n        log \"INFO\" \"\u53d1\u9001\u6587\u672c\u6d88\u606fJSON: ${text_json:0:100}...\"\n        \n        send_response=$(curl ${curl_proxy} --connect-timeout 5 --no-keepalive --retry 3 -w 'HTTP_CODE:%{http_code}\\n' -s -o - --data-ascii \"${text_json}\" ${PURL})\n        http_code=$(echo ${send_response} | grep -o \"HTTP_CODE:&#091;0-9]*\" | awk -F':' '{print $2}')\n        errcode=$(echo ${send_response} | egrep -o \"\\\"errcode\\\":&#091;0-9]+\" | awk -F':' '{print $2}')\n        \n        log \"INFO\" \"\u6587\u672c\u6d88\u606f\u53d1\u9001\u54cd\u5e94\uff1aHTTP_CODE=${http_code}, errcode=${errcode}\"\n    fi\n    \n    # \u6821\u9a8c\u53d1\u9001\u7ed3\u679c\uff08errcode=0\u8868\u793a\u6210\u529f\uff09\n    if &#091;&#091; ${http_code} == 200 &amp;&amp; ${errcode} == 0 ]]; then\n        log \"INFO\" \"\u6d88\u606f\u53d1\u9001\u6210\u529f\uff01\"\n        echo \"\u6d88\u606f\u53d1\u9001\u6210\u529f\uff01\"\n        break\n    else\n        log \"WARN\" \"\u6d88\u606f\u53d1\u9001\u5931\u8d25\uff0c\u5c1d\u8bd5\u4e0b\u4e00\u4e2a\u4ee3\u7406\uff08HTTP_CODE=${http_code}, errcode=${errcode}\uff09\"\n    fi\ndone\n\n# ======================== \u6e05\u7406\u4e34\u65f6\u6587\u4ef6 ========================\nif &#091;&#091; -f \"${newfilename}\" ]]; then\n    rm -f \"${newfilename}\"\n    log \"INFO\" \"\u6e05\u7406\u4e34\u65f6\u6587\u4ef6: ${newfilename}\"\nfi\n\n# ======================== \u6700\u7ec8\u7ed3\u679c\u6821\u9a8c ========================\nif &#091;&#091; ${http_code} != 200 || ${errcode} != 0 ]]; then\n    log \"ERROR\" \"\u6d88\u606f\u53d1\u9001\u6700\u7ec8\u5931\u8d25\uff01HTTP_CODE=${http_code}, errcode=${errcode}\"\n    echo \"\u6d88\u606f\u53d1\u9001\u5931\u8d25\uff01\"\n    exit 1\nfi\n\nexit 0<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[9],"tags":[],"class_list":["post-181","post","type-post","status-publish","format-standard","hentry","category-9"],"_links":{"self":[{"href":"https:\/\/opshub.com.cn\/index.php?rest_route=\/wp\/v2\/posts\/181","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/opshub.com.cn\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/opshub.com.cn\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/opshub.com.cn\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/opshub.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=181"}],"version-history":[{"count":2,"href":"https:\/\/opshub.com.cn\/index.php?rest_route=\/wp\/v2\/posts\/181\/revisions"}],"predecessor-version":[{"id":659,"href":"https:\/\/opshub.com.cn\/index.php?rest_route=\/wp\/v2\/posts\/181\/revisions\/659"}],"wp:attachment":[{"href":"https:\/\/opshub.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=181"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/opshub.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=181"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/opshub.com.cn\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=181"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}