日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

这些屌毛总是给订阅号发x图,连夜肝了一个微信订阅号鉴黄机器人抵御~

發布時間:2025/3/20 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 这些屌毛总是给订阅号发x图,连夜肝了一个微信订阅号鉴黄机器人抵御~ 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊上方?好好學java?,選擇?星標?公眾號

重磅資訊、干貨,第一時間送達

今日推薦:硬剛一周,3W字總結,一年的經驗告訴你如何準備校招!

個人原創100W+訪問量博客:點擊前往,查看更多

來源公眾號:碼匠筆記

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

公眾號接收用戶消息 -> 微信平臺發送消息給我們的服務器 -> 我們的服務器處理消息 -> 返回處理結果給微信平臺 -> 微信平臺發送內容給用戶。

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

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


# 配置微信公眾號

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

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


  • 開發者ID,開發者調用的唯一標示,調用接口的時候需要傳遞。

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

  • 服務地址,這個就是我們用來接收微信平臺轉發的用戶消息的服務的地址

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

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

  • 是否加密傳輸消息

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


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

    • Token 隨便生成一個 UUID 就可以

    • 隨機生成,后面如果調用 API 會用到。

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


    # 編寫服務端

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

    <repositories> <repository> <id>developer-weapons-repository</id> <url>https://raw.githubusercontent.com/developer-weapons/repository/master</url> </repository></repositories><dependency> <groupId>com.github.developer.weapons</groupId> <artifactId>wechat-spring-boot-starter</artifactId> <version>1.2.6</version></dependency>

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

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

    @Autowiredprivate 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();}編寫到這里就可以找一個服務器部署起來,點擊驗證嘍,這時候點擊提交直接成功 了,點擊啟用以后就生效了,生效以后你原來配置的自動回復就會生效,所以這個 操作請謹慎。


    # 處理業務邏輯

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

    @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<String, String> 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 方法解析出接收消息的內容,當前判斷比較簡單,直接判斷是否是圖片消息,然后返回圖片的 URL 給發送消息的用戶。效果圖如下

    那么接下來就到了最關鍵的一步,如何鑒黃,現在我們直接把相關代碼懟上。

    按照上面的文章修改代碼后結果如下,具體的 publicKey 和 privateKey 自己參考下哦

    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;}

    最終效果如下

    所以,你會搭建自己的鑒黃機器人了嗎?

    完整源碼獲取方法,老規矩啦!

    識別下方二維碼,關注后回復【A109

    即可獲取機器人完整源碼

    ????長按上方二維碼 2 秒

    推薦文章
    • 硬剛一周,3W字總結,一年的經驗告訴你如何準備校招!

    • 今年的校招,Java 好拿 offer 嗎?

    • 10月了,該聊聊今年秋招了!

    • 聊聊在騰訊實習快一個月的感受

    原創電子書歷時整整一年總結的?Java 面試 + Java 后端技術學習指南,這是本人這幾年及校招的總結,各種高頻面試題已經全部進行總結,按照章節復習即可,已經拿到了大廠offer。 原創思維導圖掃碼或者微信搜?程序員的技術圈子?回復?面試?領取原創電子書和思維導圖。

    總結

    以上是生活随笔為你收集整理的这些屌毛总是给订阅号发x图,连夜肝了一个微信订阅号鉴黄机器人抵御~的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。