微信平臺發(fā)送消息給我們的服務器 -> 我們的服務器處理消息 -> 返回..." />
<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          一晚上,搞出來一個微信訂閱號鑒黃機器人

          共 4545字,需瀏覽 10分鐘

           ·

          2020-12-03 11:34

          點擊上方“逆鋒起筆”,公眾號回復?pdf
          領取大佬們推薦的學習資料

          顧名思義,我們就是來做一個訂閱號機器人,大致是這樣一個過程

          公眾號接收用戶消息 -> 微信平臺發(fā)送消息給我們的服務器 -> 我們的服務器處理消息 -> 返回處理結(jié)果給微信平臺 -> 微信平臺發(fā)送內(nèi)容給用戶。

          基于這樣一個大前提就有了下面的步驟。

          1、填寫服務器配置,可以接收微信平臺發(fā)送的內(nèi)容
          2、開發(fā)服務端,并驗證服務器地址的有效性
          3、處理具體的業(yè)務邏輯

          1. 配置微信公眾號

          首先肯定需要有一個訂閱號,然后在訂閱號后臺點擊 開發(fā)者->基本配置進入如下頁面,點擊確定

          然后進入配置頁面,我們一一對配置進行講解

          1. 開發(fā)者ID,開發(fā)者調(diào)用的唯一標示,調(diào)用接口的時候需要傳遞。

          2. 開發(fā)者密碼,這個很重要一定要保存在自己的服務器上面,用于驗證安全性。

          3. 服務地址,這個就是我們用來接收微信平臺轉(zhuǎn)發(fā)的用戶消息的服務的地址

          4. 令牌,用戶接收信息時候做驗證是否請求來自微信平臺

          5. 用于加密消息,防止被截獲,如果 6 設置為明文模式不需要這個配置。

          6. 是否加密傳輸消息

          我們本期只做接收圖片消息,驗證完成以后回復消息,所以只需要配置 3、4。

          1. 是我們具體的服務器地址,path是 weixin/receive 這個下文中具體代碼部分會詳細講解

          2. Token 隨便生成一個 UUID 就可以

          3. 隨機生成,后面如果調(diào)用 API 會用到。

          這時候你點擊提交會提示驗證失敗,是因為你還沒有部署 API,配置到這里我們就開始編寫代碼。

          2. 編寫服務端

          服務器端使用現(xiàn)有的輪子非常簡單,因為是 spring-boot 項目,直接引入一個現(xiàn)成的微信 starter,一定要添加 repository ,這個是依托 Github 自帶的倉庫。

          <repositories>
          ????<repository>
          ????????<id>developer-weapons-repositoryid>
          ????????<url>https://raw.githubusercontent.com/developer-weapons/repository/masterurl>
          ????repository>
          repositories>
          <dependency>
          ????<groupId>com.github.developer.weaponsgroupId>
          ????<artifactId>wechat-spring-boot-starterartifactId>
          ????<version>1.2.6version>
          dependency>

          然寫兩個接口,一個 GET 用于第一次綁定微信后臺驗證用,一個 POST 用于以后接收消息 /weixin/receive

          把之前準備好的 token 配置到 application.properties 然后注入到 Controller 里面,大致的驗證代碼如下,如果驗證簽名成功就返回 echostr,算是通信的標示,如果驗證失敗返回 error。

          @Autowired
          private?WechatOfficialService?wechatOfficialService;

          @Value("${weixin.token}")
          private?String?token;

          @RequestMapping(value?=?"/weixin/receive",?method?=?RequestMethod.GET)
          public?void?receive(
          ????????@RequestParam(value?=?"signature")
          ?String?signature,
          ????????@RequestParam(value?=?"timestamp")?String?timestamp,
          ????????@RequestParam(value?=?"nonce")?String?nonce,
          ????????@RequestParam(value?=?"echostr")?String?echostr,
          ????????HttpServletResponse?response)?throws?IOException?
          {
          ????boolean?valid?=?wechatOfficialService.isValid(signature,?timestamp,?nonce,?token);
          ????PrintWriter?writer?=?response.getWriter();
          ????if?(valid)?{
          ????????writer.print(echostr);
          ????}?else?{
          ????????writer.print("error");
          ????}
          ????writer.flush();
          ????writer.close();
          }

          編寫到這里就可以找一個服務器部署起來,點擊驗證嘍,這時候點擊提交直接成功了,點擊啟用以后就生效了,生效以后你原來配置的自動回復就會生效,所以這個操作請謹慎。

          3. 處理業(yè)務邏輯

          處理業(yè)務邏輯首先是接收消息,下面是接收消息的代碼

          @RequestMapping(value?=?"/weixin/receive",?method?=?RequestMethod.POST)
          public?void?receive(
          ????????@RequestParam(value?=?"signature")
          ?String?signature,
          ????????@RequestParam(value?=?"timestamp")?String?timestamp,
          ????????@RequestParam(value?=?"nonce")?String?nonce,
          ????????HttpServletRequest?request,
          ????????HttpServletResponse?response)?throws?IOException?
          {
          ????request.setCharacterEncoding("UTF-8");
          ????response.setCharacterEncoding("UTF-8");
          ????boolean?valid?=?wechatOfficialService.isValid(signature,?timestamp,?nonce,?token);
          ????PrintWriter?writer?=?response.getWriter();
          ????if?(!valid)?{
          ????????writer.print("error");
          ????????writer.flush();
          ????????writer.close();
          ????????return;
          ????}
          ????try?{
          ????????Map?map?=?wechatOfficialService.toMap(request.getInputStream());
          ????????if?(map.get("MsgType").equals("image"))?{
          ????????????String?msg?=?OfficialAutoReplyMessage.build()
          ????????????????????.withContent("接收到圖片鏈接為:"?+?map.get("PicUrl"))
          ????????????????????.withMsgtype(MessageTypeEnum.TEXT)
          ????????????????????.withFromUserName(map.get("ToUserName"))
          ????????????????????.withToUserName(map.get("FromUserName"))
          ????????????????????.toXml();
          ????????????writer.print(msg);
          ????????????writer.flush();
          ????????????writer.close();
          ????????????return;
          ????????}
          ????}?catch?(Exception?e)?{
          ????????log.error("WeixinController?receive?error",?e);
          ????}
          ????writer.print("success");
          ????writer.flush();
          ????writer.close();
          }

          第一步還是驗證消息是否來自微信平臺,然后使用 wechatOfficialService.toMap 方法解析出接收消息的內(nèi)容,當前判斷比較簡單,直接判斷是否是圖片消息,然后返回圖片的 URL 給發(fā)送消息的用戶。效果圖如下

          那么接下來就到了最關鍵的一步,如何鑒黃,這個具體的邏輯可以參考這一篇文章《怒爬某 Hub 資源就為擼了一個鑒黃平臺》,現(xiàn)在我們直接把相關代碼懟上。

          按照上面的文章修改代碼后結(jié)果如下,具體的 publicKey 和 privateKey 自己參考下哦。關注公眾號 逆鋒起筆,回復 pdf,下載你需要的各種學習資料。

          if?(map.get("MsgType").equals("image"))?{
          ??String?res?=?checkService.check(publicKey,?privateKey,?map.get("PicUrl"));
          ??OfficialAutoReplyMessage?officialAutoReplyMessage?=
          ??????????OfficialAutoReplyMessage.build()
          ??????????????????.withMsgtype(MessageTypeEnum.TEXT)
          ??????????????????.withFromUserName(map.get("ToUserName"))
          ??????????????????.withToUserName(map.get("FromUserName"));
          ??if?(StringUtils.equals("forbid",?res))?{
          ??????officialAutoReplyMessage.withContent("小哥,你的圖片有點問題哦");
          ??}?else?{
          ??????officialAutoReplyMessage.withContent("騷年,你這圖片剛剛的沒問題");
          ??}
          ??writer.print(officialAutoReplyMessage.toXml());
          ??writer.flush();
          ??writer.close();
          ??return;
          }

          最終效果如下


          所以你會搭建自己的鑒黃機器人了嗎?點擊原文獲取項目源碼。


          全網(wǎng)最新 程序員編程視頻教程分享

          精心挑選的 Python 視頻教程(無套路)

          你們猜猜,哪個省的女生最愛豐胸??

          學著爬取了某 Hub 資源,只為擼這個鑒黃平臺!

          抓了!程序員因受不了 996,怒建 6 個涉黃平臺,涉案 5000 余萬元


          點個『在看』支持下?
          瀏覽 63
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  美女操逼动漫 | 操在线小视频 | 国产精品三区视频 | 欧美成人网站在线观看视频 | www.激情网站 |