当前位置: 首页 > article >正文

WxJava 微信开发包 - 新手入门指南

WxJava 微信开发包 - 新手入门指南项目概览项目名称Binary Wang/WxJavaStarsGVP ⭐⭐⭐⭐⭐组织Binary Wang语言Java标签GVP, Java, 微信开发, 微信公众号, 微信支付项目简介WxJava 是一个基于 Java 的微信开发工具包支持微信公众号、微信支付、小程序、企业微信等多种微信服务的开发。它是 Gitee 的 GVP 项目是国内最流行的 Java 微信开发库之一。核心特性1. 多平台支持•微信公众号: 完整支持公众号开发•微信支付: 支持 Native、JSAPI、H5 等多种支付方式•微信小程序: 小程序开发支持•企业微信: 企业微信接口支持•微信开放平台: 第三方平台支持2. 功能丰富•消息处理 (文本、图片、语音、视频等)•菜单管理•用户管理•模板消息•素材管理•客服消息•数据分析3. 支付能力•统一下单•订单查询•退款•分账•红包•企业付款4. 技术特点•基于 Spring Boot 自动配置•支持 Redis 缓存 AccessToken•提供 Starter 简化集成•支持多租户多公众号使用场景1.微信公众号开发- 快速构建公众号应用2.微信小程序后端- 小程序服务端开发3.微信支付集成- 接入微信支付功能4.企业微信应用- 企业微信二次开发5.第三方平台开发- 微信开放平台开发项目结构wxjava/├── wx-java-common/ # 公共模块├── wx-java-mp/ # 公众号模块├── wx-java-pay/ # 支付模块├── wx-java-miniapp/ # 小程序模块├── wx-java-cp/ # 企业微信模块├── wx-java-open/ # 开放平台模块└── wx-spring-boot-starter/ # Spring Boot Starter快速入门环境要求•JDK 8•Maven 3.6•Spring Boot 2.x / 3.x (可选)1. 添加依赖Maven 依赖:!-- 公众号 --dependency groupIdcom.github.binarywang/groupId artifactIdweixin-java-mp/artifactId version4.5.0/version/dependency !-- 支付 --dependency groupIdcom.github.binarywang/groupId artifactIdweixin-java-pay/artifactId version4.5.0/version/dependency !-- Spring Boot Starter --dependency groupIdcom.github.binarywang/groupId artifactIdwx-java-spring-boot-starter/artifactId version4.5.0/version/dependency2. 配置application.yml:wx: mp: app-id: your_app_id secret: your_app_secret token: your_token aes-key: your_aes_key pay: app-id: your_app_id mch-id: your_mch_id mch-key: your_mch_key cert-path: classpath:apiclient_cert.p123. 配置类Configurationpublic class WxMpConfig { Value(${wx.mp.app-id}) private String appId; Value(${wx.mp.secret}) private String secret; Bean public WxMpService wxMpService() { WxMpServiceImpl service new WxMpServiceImpl(); WxMpDefaultConfigImpl config new WxMpDefaultConfigImpl(); config.setAppId(appId); config.setSecret(secret); service.setWxMpConfigStorage(config); return service; }}代码示例1. 公众号消息处理RestControllerRequestMapping(/wx/portal)public class WxPortalController { Autowired private WxMpService wxMpService; GetMapping(produces text/plain;charsetutf-8) public String validate( RequestParam String signature, RequestParam String timestamp, RequestParam String nonce, RequestParam String echostr) { if (wxMpService.checkSignature(timestamp, nonce, signature)) { return echostr; } return 非法请求; } PostMapping(produces application/xml;charsetUTF-8) public String handleMessage(RequestBody String requestBody) { WxMpXmlMessage message WxMpXmlMessage.fromXml(requestBody); WxMpXmlOutMessage response null; switch (message.getMsgType()) { case TEXT: response WxMpXmlOutMessage.TEXT() .content(收到文本消息: message.getContent()) .fromUser(message.getToUser()) .toUser(message.getFromUser()) .build(); break; case EVENT: // 处理事件消息 break; } return response.toXml(); }}2. 微信支付Servicepublic class WxPayService { Autowired private WxPayService wxPayService; public WxPayUnifiedOrderResult createOrder(String orderId, BigDecimal amount) { WxPayUnifiedOrderRequest request new WxPayUnifiedOrderRequest(); request.setBody(商品描述); request.setOutTradeNo(orderId); request.setTotalFee(amount.multiply(new BigDecimal(100)).intValue()); request.setSpbillCreateIp(127.0.0.1); request.setNotifyUrl(https://your-domain.com/wx/pay/notify); request.setTradeType(JSAPI); request.setOpenid(用户openid); return wxPayService.unifiedOrder(request); }}3. 获取用户信息public WxMpUser getUserInfo(String openid) { try { return wxMpService.getUserService().userInfo(openid); } catch (WxErrorException e) { // 处理异常 return null; }}4. 发送模板消息public boolean sendTemplateMessage(String openid, String templateId) { WxMpTemplateMessage templateMessage WxMpTemplateMessage.builder() .toUser(openid) .templateId(templateId) .url(https://example.com) .build(); templateMessage.addData(new WxMpTemplateData(first, 您好, #173177)); templateMessage.addData(new WxMpTemplateData(keyword1, 订单号, #173177)); templateMessage.addData(new WxMpTemplateData(remark, 感谢您的使用, #173177)); try { wxMpService.getTemplateMsgService().sendTemplateMsg(templateMessage); return true; } catch (WxErrorException e) { return false; }}学习资源官方资源•文档: https://github.com/binarywang/weixin-java-tools/wiki[1]•示例: 项目包含多个示例项目•交流群: 官方 QQ 群•Demo: 提供完整的演示项目常见问题Q: AccessToken 如何管理A: WxJava 提供了内存缓存和 Redis 缓存两种方式建议生产环境使用 Redis 缓存。Q: 如何处理支付回调A: 在配置文件中设置 notifyUrl然后在对应接口处理回调通知。Q: 支持哪些支付方式A: 支持 Native、JSAPI、H5、App、小程序等多种支付方式。Q: 如何获取用户 OpenIDA: 通过 OAuth2 授权获取用户的 OpenID。推荐指数⭐⭐⭐⭐⭐ (5/5)WxJava 是 Java 微信开发的首选工具包功能完善、文档齐全、社区活跃。无论是个人开发者还是企业级应用都是一个非常值得推荐的选择。总结WxJava 极大简化了 Java 开发者接入微信生态的复杂度提供了丰富的 API 和便捷的封装。它的设计遵循 Spring Boot 风格易于集成和使用是微信开发的必备工具。References[1]:https://github.com/binarywang/weixin-java-tools/wiki

相关文章:

WxJava 微信开发包 - 新手入门指南

WxJava 微信开发包 - 新手入门指南项目概览项目名称Binary Wang/WxJavaStarsGVP ⭐⭐⭐⭐⭐组织Binary Wang语言Java标签GVP, Java, 微信开发, 微信公众号, 微信支付项目简介WxJava 是一个基于 Java 的微信开发工具包,支持微信公众号、微信支付、小程序、企业微信等…...

鸿蒙今日穿搭页面构建:单品清单、一周搭配日历与穿搭提示模块详解

鸿蒙今日穿搭页面构建:单品清单、一周搭配日历与穿搭提示模块详解 前言 在 HarmonyOS 6.0 应用开发中,穿搭类页面的单品管理、周计划安排和温馨提醒是完善用户体验的重要补充模块。本文将以“今日穿搭”应用中的“单品清单”网格模块、“一周搭配日历”周…...

鸿蒙今日穿搭页面构建:衣橱库存、今日配色与场景建议模块详解

鸿蒙今日穿搭页面构建:衣橱库存、今日配色与场景建议模块详解 前言 在 HarmonyOS 6.0 应用开发中,穿搭类页面的衣橱管理、配色方案和场景化建议是提升用户实用性的关键功能模块。本文将以“今日穿搭”应用中的“衣橱库存”进度条模块、“今日配色”色彩盘…...

关于自指系统与算术障碍的跨领域猜想:一项探索性研究(世毫九实验室学术完善报告)

关于自指系统与算术障碍的跨领域猜想:一项探索性研究(世毫九实验室学术完善报告) 作者:方见华 单位:世毫九实验室 核心摘要 本报告针对世毫九实验室原创的探索性跨领域论文《关于自指系统与算术障碍的跨领域猜想&#…...

鸿蒙今日穿搭页面构建:搭配推荐与风格筛选模块详解

鸿蒙今日穿搭页面构建:搭配推荐与风格筛选模块详解 前言 在 HarmonyOS 6.0 应用开发中,穿搭类页面的核心挑战在于如何展示搭配灵感、风格筛选和衣橱管理。本文将以“今日穿搭”应用的主页面为例,深入解析如何在鸿蒙平台上构建时尚穿搭类应用的…...

【咨询业AI Agent应用成熟度评估模型】:基于217家机构实测数据的4级能力图谱与升级路线图

更多请点击: https://codechina.net 第一章:【咨询业AI Agent应用成熟度评估模型】:基于217家机构实测数据的4级能力图谱与升级路线图 本模型基于对全球217家管理咨询、战略咨询与数字化转型服务商的实地调研与系统性能力测评,覆…...

观察Taotoken按Token计费模式如何帮助项目控制预算

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 观察Taotoken按Token计费模式如何帮助项目控制预算 对于依赖大模型API进行开发的团队和个人而言,成本控制是一个贯穿项…...

C++虚函数与多态机制

C虚函数与多态机制虚函数是C实现运行时多态的核心机制。通过虚函数表和虚函数指针,C能够在运行时根据对象的实际类型调用相应的函数实现。虚函数的基本语法使用virtual关键字声明,派生类可以重写基类的虚函数。#include #include #includeclass Animal {…...

【AI入门知识点】Harness 是什么?为什么 DeepSeek 要组建 Harness 团队?

最近,DeepSeek 招聘信息中出现了一个越来越高频的关键词——Harness 团队。 很多人第一反应是: Harness 是什么?一种新模型?还是某个框架?为什么 DeepSeek 专门成立团队来做这个?如果你第一次听到这个词&am…...

【AI入门知识点】告别繁琐配置!Claude Code + DeepSeek 直连方案打造最强 VSCode 编程助手

在 AI 编程领域,Claude Code 凭借其强大的 Agent 能力(自动读写文件、执行命令)一直是开发者的梦中情“器”。然而,官方 API 的高昂费用和网络限制,让许多国内开发者望而却步。 这篇文章我们不通过 cc-switch 转发请求…...

pycryptodome导入失败的四大底层原因与诊断方案

1. 这不是pycryptodome的问题,而是你没看清它真正依赖的底层逻辑“ImportError: No module named Crypto”、“AttributeError: module Crypto.Cipher has no attribute AES”、“ModuleNotFoundError: No module named Cryptography_cffi...”——这些报错我过去三…...

Python爬虫实战:爬取论文期刊 文献整理+管理表生成

写论文的时候最烦什么?不是写内容,是找文献和整理文献。相信每个研究生都有过这样的经历:打开十几个浏览器标签页,一篇一篇复制论文标题、作者、期刊、发表时间、摘要,然后粘贴到Excel里,一不小心还会复制错…...

通过curl命令直接测试Taotoken聊天补全接口的配置与调用方法

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 通过curl命令直接测试Taotoken聊天补全接口的配置与调用方法 在开发或调试大模型应用时,有时你可能希望绕过高级SDK&am…...

AI代理运行时基础设施:从上下文溢出到持久化事件日志

1. 这不是新赛道,是 runtime 层的“操作系统时刻”来了你有没有在深夜调试一个跑了三小时的 AI 代理,突然发现它开始胡言乱语?不是模型崩了,不是 prompt 写错了,而是——它的“记忆”被挤掉了。上下文窗口就那么大&…...

AI绘画中的诡异谷:从技术缺陷到可控美学的跃迁

1. 项目概述:当AI画笔开始颤抖——我们为什么该认真对待“诡异谷”里的美你有没有盯着一张AI生成的肖像画,越看越不对劲?眼睛太亮、皮肤太滑、手指多了一节,或者笑容弧度精准得像用圆规画出来的——那种说不上来哪里怪&#xff0c…...

2026出纳岗位新人如何快速提升能力:从基础上手到能力跃升的最快路径

2026年,出纳岗位已经不再只是“收付款、跑银行、登记现金日记账”这么简单。随着企业财务数字化、业财一体化和AI工具普及,新人想快速成长,必须同时具备规范意识、系统操作能力、数据思维和风险意识。这也是为什么越来越多财务新人会关注像CD…...

Mythos架构解析:大模型的可编程推理能力与Gated Release机制

1. 项目概述:一次被刻意“锁住”的能力跃迁如果你最近关注大模型前沿动态,大概率在技术社区、AI从业者群或邮件列表里见过“TAI #200”这个编号——它不是某篇论文的DOI,也不是某个开源项目的Release Tag,而是The AI Alignment Ne…...

SSH安全加固:禁用弱加密算法的实操指南

1. 为什么禁用弱加密算法不是“可选项”,而是SSH上线前的必过门槛我第一次在客户现场接手一台刚部署的CentOS 7跳板机时,安全扫描报告里赫然标红了三条:ssh-rsa签名算法被标记为CRITICAL,diffie-hellman-group1-sha1密钥交换被判定…...

Claude Mythos:AI驱动的自动化漏洞挖掘与攻防范式跃迁

1. 项目概述:一场静默却震耳欲聋的AI能力跃迁这周,整个AI安全圈没有爆炸性新闻稿,没有铺天盖地的发布会直播,只有一份措辞克制、数据密集的系统卡片(System Card)和一份由英国AI安全研究所(AISI…...

Python自动化登录:破解验证码与Cookie会话维持实战

1. 这不是“绕过验证”,而是理解会话机制的起点很多人看到“跳过验证码登陆”第一反应是:这合规吗?会不会被封?其实这个问题本身就暴露了一个关键误区——我们不是在“绕过”什么,而是在还原真实用户登录时浏览器自动完…...

工业AI落地:从数据冷启动到高质数据工程实战

1. 为什么“数据为中心”不是口号,而是工程现场的真实压力去年冬天,我帮一家做工业缺陷检测的初创公司做模型交付。他们拿来的数据集只有237张标注图,全是产线停机时人工拍的——光照不均、角度单一、连螺丝孔都只拍正面。当时团队信心满满&a…...

DeepSeek总结的从 DuckDB 迁移到 chDB基准测试

来源: https://github.com/chdb-io/cookbook/tree/main/migration-from-duckdbBENCHMARK.md 迁移基准测试 —— 深度探讨 本文是从 DuckDB 迁移到 chDB指南的配套文档。指南的第 5 节将环境/场景/结果/摘要内联呈现;本文件则包含不适合指南风格流程的部分&#xf…...

工业级房价预测实战:从数据清洗到可解释模型部署

1. 这不是“调个模型就完事”的房价预测——而是一次完整的工业级回归建模实战复盘你打开Kaggle,下载一个带“house price”字样的CSV文件,pandas读进来,train_test_split切两刀,RandomForestRegressor.fit()跑完,R显示…...

Anthropic Managed Agents:AI 运行时的事件日志革命

1. 这不是新赛道,是 runtime 层的“操作系统时刻”来了你有没有试过让一个 AI 代理连续工作四十分钟?不是闲聊,而是真正在查文档、调 API、写代码、改配置、再验证——一环扣一环地推进一个真实业务流程。我去年就带着团队跑过这样一个销售线…...

Mumu模拟器ADB连接Unity Profiler全攻略

1. 为什么连不上Mumu的ADB,90%的人卡在第一步就放弃了“ADB device not found”、“offline”、“unauthorized”,这几个词我去年在Unity项目组的晨会白板上写了整整三周。不是因为技术多难,而是因为Mumu模拟器的ADB服务默认不走标准路径&…...

RESTful API测试:从Postman点按到契约级可信的四层验证

1. 为什么RESTful API测试不是“把URL填进去点一下”就能完事?很多人第一次接触接口测试,看到Postman里输入一个GET请求、点下Send,返回200和一串JSON,就以为“测完了”。我带过三届测试新人,几乎每个人都踩过这个坑&a…...

案发现场时空回溯:UWB无法全域留痕,无感定位全链路可复盘

案发现场时空回溯:UWB无法全域留痕,无感定位全链路可复盘镜像视界浙江科技有限公司,作为数字孪生、视频孪生领域底层原创技术核心供给方,依托国家十四五重点课题专项研究、镜像视界浙江普陀时空大数据应用技术联合研究院深度产学研…...

无授权不感知、无穿戴可溯源:无感定位重构公安新型治安底座

无授权不感知、无穿戴可溯源:无感定位重构公安新型治安底座镜像视界浙江科技有限公司依托国家十四五重点课题研究成果、镜像视界浙江普陀时空大数据应用技术联合研究院联合研发体系与河南省电检院权威认证资质,以自研空间计算技术为根基打磨无感定位体系…...

JMeter HTTP接口压测实战:定位性能瓶颈的工程方法论

1. 这不是点几下就能出报告的“压测”,而是对系统真实承压能力的外科手术式探查很多人第一次打开JMeter,以为只要填个URL、设个线程数、点“启动”,跑完看个聚合报告就叫“压测完了”。我见过太多团队在上线前用JMeter跑出“99.9%成功率、平均…...

讲讲libevent底层机制

在 Linux 高并发网络编程领域,libevent 是最经典、最老牌的事件驱动 IO 库,Nginx、Redis、memcached、Tor 等知名项目都基于它二次开发。它封装了 select/poll/epoll/kqueue 等 IO 复用接口,实现了统一的事件驱动模型、定时器、信号处理&…...