微信不是一个营销工具,腾讯对使用微信做营销是有限制的。你很难把商品直接退到微信用户面前。你需要解决两个问题
第一,如何将商品内容展现给用户
基本上只能由用户主动向你的公众号发起信息你才能给用户推相应的内容,而通过这种方式购物的体验是非常差的。订阅号每天只能想用户群发一条内容,基本满足不了电商网站的需求。
第二,如何支付
新推出的微信支付只有服务号可以使用,而服务号连每天一条的群发内容都没有。如果你是订阅号的话只能选择例如财付通等第三方的支付方式。
那么我的思路是:
用微信回复图文连接,这个连接会指向你的web网站,用户通过微信的内嵌浏览器访问web网站浏览并选择商品,下单后通过例如财付通等第三方支付方式进行支付。
这种思路与移动电商网站的差别仅仅是入口采用微信引入,利用微信这个入口提到电商网站的客流。
Ⅱ 请问,java语言开发微信公众号支付时。提示验签失败
ipc备案完会抄给一个验证文件,袭放到域名能直接访问的地方就可以。如你的域名是www.test.com,ipc给你的文件名为ipc.txt,则http://www.test.com/ipc.txt要能直接访问到。实际文件名大概是8位有字母数字组成的随机数。ipc备案需要单独申请。我们微网站是项目经理做的备案,备案自己查一下流程。微信api明确说要ipc备案。做完备案再测试可能就好了。
Ⅲ 微信公众平台开发,怎么样像银行一样当第三方平台有交易发生时,自动推送一条交易提醒给用户,采纳加分
js幻灯片
微信公众平台开发教程
专题导读:微信公众平台是腾讯公司在微信的基础上新增的功能模块,通过这一平台,个人和企业都可以打造一个微信的公众号,并实现和特定群体的文字、图片、语音的全方位沟通、互动。2013年8月5日,微信公众平台进行升级,将微信公众平台分成订阅号和服务号两种类型。本专题收集各种微信API接口开发教程,以您供参考学习。
微信调整公众平台规则:月度推送增至4条
微信团队对于公众账号的功能发展有三个阶段的定位。第一阶段就是互动沟通,最常用的就是群发消息等。第二阶段是用户管理,公众号天生是一个CRM平台。第三阶段则是服务...
发布时间:2014-04-16
微信新平台:开放图像识别和语音识别技术
利用语音识别技术,微信服务号的用户能够自定义词库,在识别到某些关键词后,自动返回特定的结果,微信称“后期也会考虑支持定制化的服务”。另外,微信开放的语音合...
发布时间:2014-04-10
微信支付向16类APP开放 拥有移动应用APP的商户即可申请
微信支付作为微信5 0版本上线时引入的一个重要功能,在3月4日已经向开发者们开放了扫码支付和公众号支付两个场景。此次,微信向第三方移动应用直接开放了微信支付申...
发布时间:2014-03-22
基于微信平台开发的十大火爆应用TOP10
如何从这个生态上赚到钱,同时又能找到避免被腾讯“微创新”的方法是无数创业者努力的方向。接下来为大家分析盘点十大基于微信开发的火爆应用,让我们一起看看这批创...
发布时间:2014-03-05
微信公众平台上传下载多媒体文件之开发文档详解
微信公众号在使用接口时,对多媒体文件、多媒体消息的获取和调用等操作,是通过media_id来进行的。通过本接口,公众号可以上传或下载多媒体文件。但请注意,每个多媒...
发布时间:2014-02-09
微信公众平台客服接口之开发文档详解
当用户主动发消息给公众号的时候(包括发送信息、点击自定义菜单click事件、订阅事件、扫描二维码事件、支付成功事件、用户维权),微信将会把消息数据推送给开发者,...
发布时间:2014-02-09
微信公众平台生成带参数的二维码之开发文档详解
为了满足用户渠道推广分析的需要,微信公众平台提供了生成带参数二维码的接口。使用该接口可以获得多个带不同场景值的二维码,用户扫描后,公众号可以接收到事件推送。
发布时间:2014-02-09
微信公众平台获取用户地理位置之开发文档详解
开通了上报地理位置接口的微信公众号,用户在关注后进入公众号会话时,会弹框让用户确认是否允许公众号使用其地理位置。弹框只在关注后出现一次,用户以后可以在公众...
发布时间:2014-02-09
微信公众平台获取用户基本信息之开发文档详解
在关注者与公众号产生消息交互后,微信公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的。对于不同公众号,同一用户的openid不同...
发布时间:2014-02-09
微信公众平台获取关注者列表之开发文档详解
微信公众号可通过本接口来获取帐号的关注者列表,关注者列表由一串OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的)组成。一次拉取调用最多拉取10000...
发布时间:2014-02-09
微信公众平台用户分组管理开发文档详解
微信开发者可以使用接口,对公众平台的分组进行查询、创建、修改操作,也可以使用接口在需要时移动用户到某个分组。一个公众账号,最多支持创建500个分组。
发布时间:2014-02-09
微信公众平台自定义菜单开发文档详解
目前微信自定义菜单最多包括3个一级菜单,每个一级菜单最多包含5个二级菜单。一级菜单最多4个汉字,二级菜单最多7个汉字,多出来的部分将会以“ ”代替。请注意...
发布时间:2014-02-09
微信公众平台自定义菜单创建的Java代码示例
微信公众平台自定义菜单创建的Java代码示例,完整最新版代码,支持创建,查询,删除。自定义菜单只有服务号可以申请,订阅号暂时无法申请(继续观望微信的开放政策)...
发布时间:2013-10-04
微信服务号申请自定义菜单的介绍
微信今日发布新版,此次除上线游戏中心功能外,对公众账号来说,也有巨大改变。公众账号分为订阅号和服务号,其中订阅号消息被折叠。
发布时间:2013-10-04
微信公众号自定义菜单申请与使用问题解答
有不少人询问自定义菜单的问题,所以还是写出来比较好,也可以与之前的教程连贯起来。这次我还归纳了大家对自定义菜单问得最多的一些问题,希望能让大家对自定义菜单...
发布时间:2013-09-30
微信公众平台群发消息的图文攻略
微信的公众账号平台具备了自动回复、开发平台和认证等功能。其中的一些操作大
Ⅳ 微信公众号给微信用户转账的Java实现
这个是开发文档页面:
https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2
用于企业向微信用户个人付款 目前支内持向指定微信用户的openid付款。容
我刚刚接到公司交待的这个任务,正在开发中。。。。
Ⅳ 支付失败如何编程跳过变成支付成功
热门频道
首页
博客
研修院
VIP
APP
问答
下载
社区
推荐频道
活动
招聘
专题
打开CSDN APP
Copyright © 1999-2020, CSDN.NET, All Rights Reserved
打开APP
南独酌酒nvn
关注
【Java 实现微信支付、Native 支付流程】,从编写代码到支付成功,一步到位! 原创
2020-10-17 14:30:03
8点赞
南独酌酒nvn
码龄4年
关注
文章目录
1. 项目环境介绍
2. 微信支付文档
2.1 业务流程说明
3. 准备信息
3.1 微信公众账号如何获取?
3.2 商户号如何获取?
3.3 API密钥如何获取?
3.4 准备工具类
4. 进入开发阶段
4.1 后端编写`生成微信支付二维码`的接口
4.2 前端实现
4.3 后端编写 `查询订单支付状态` 接口
4.4 前端调用 `查询订单支付状态` 接口
总结
1. 项目环境介绍
jdk 1.8
mysql 5.7
maven 3.6
在这里插入图片描述
项目前后端分离:后端 SpringBoot 项目、前端 Vue 项目
2. 微信支付文档
官方文档:https://pay.weixin.qq.com/wiki/doc/api/index.html
在这里插入图片描述
Native 场景介绍:用户扫描商户展示在各种场景的二维码进行支付。
这里我们支付流程选择方式二:
官方流程图:
在这里插入图片描述
2.1 业务流程说明
用我自己完成一次的过程来说。
在前端页面,用户肯定要点击某个按钮或者东西来触发事件,调用我们自己编写的接口,然后返回给前端一个二维码。
我们通过调用微信支付 【统一下单API】接口得到一个 code_url。
然后在前端通过某项技术跟据返回的 code_url 生成二维码。
用户打开微信 “扫一扫”,然后扫描这个二维码。
进入支付页面,支付指定金额后完成支付交易。
然后我们在调用微信支付【查询订单 API】查询用户支付状态
通过此支付状态可以判断用户支付成功还是支付失败。
支付成功就执行我们自己的业务逻辑,一般像修改定单状态改成已支付。
在这里插入图片描述
3. 准备信息
pom 文件引入微信支付 SDK 依赖
由于我们后面要调用微信支付的 AP
Ⅵ java怎么实现A用户怎么在微信公众号付款给B用户
不能实现这个逻辑 A只能把钱转给你
在B不是商户的情况下 你无法把钱转给B
微信不支持非商户的用户进行微信支付开发
Ⅶ 微信支付后端篇
微信支付系列文章
微信支付-java后端实现
微信支付-vue 前端实现
java demo: 下载地址文章底部
技术栈
Spring boot
java
XML (微信在http协议中数据传输方案)
MD5 签名
微信支付术语
openid (OpenID是公众号一对一对应用户身份的标识)
app_id (公众号id,登录微信公众号–开发–基本配置中获得;)
key (收款商户后台进行配置,登录微信商户平台–账户中心–API安全-设置秘钥,设置32位key值;)
mch_id (收款商家商户号;)
certPath (API证书, 登录微信商户平台–账户中心-API安全-下载证书)
后端流程
服务端需要的核心操作, 总共分为以下几步:
统一下单
前端调起微信支付必要参数 (需加密)
订单结果主动通知 (回调接口)
查询订单结果
结束订单支付接口(关闭订单,支付订单关闭)
代码
微信总共支持多种语言的sdk, 在官网可以下载例子, java程序也可以引入微信支付的sdk包, 但是github上的sdk已经很久没有更新了, 最好的选择, 也是我的选择, 在官网上下载sdk项目, 将其中所有java类到自己的项目中.
官网sdk下载目录
链接: 商户平台首页
####根据微信sdk生成配置类 WXPayConfig
创建IWxPayConfig.class, 继承sdk WXPayConfig.class, 实现sdk中部分抽象方法, 读取本地证书, 加载到配置类中.
package core.com.chidori.wxpay;
import core.com.wxpay.IWXPayDomain;
import core.com.wxpay.WXPayConfig;
import core.com.wxpay.WXPayConstants;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
@Service
public class IWxPayConfig extends WXPayConfig { // 继承sdk WXPayConfig 实现sdk中部分抽象方法
private byte[] certData;
@Value("${vendor.wx.config.app_id}")
private String app_id;
@Value("${vendor.wx.pay.key}")
private String wx_pay_key;
@Value("${vendor.wx.pay.mch_id}")
private String wx_pay_mch_id;
public IWxPayConfig() throws Exception { // 构造方法读取证书, 通过getCertStream 可以使sdk获取到证书
String certPath = "/data/config/chidori/apiclient_cert.p12";
File file = new File(certPath);
InputStream certStream = new FileInputStream(file);
this.certData = new byte[(int) file.length()];
certStream.read(this.certData);
certStream.close();
}
@Override
public String getAppID() {
return app_id;
}
@Override
public String getMchID() {
return wx_pay_mch_id;
}
@Override
public String getKey() {
return wx_pay_key;
}
@Override
public InputStream getCertStream() {
return new ByteArrayInputStream(this.certData);
}
@Override
public IWXPayDomain getWXPayDomain() { // 这个方法需要这样实现, 否则无法正常初始化WXPay
IWXPayDomain iwxPayDomain = new IWXPayDomain() {
@Override
public void report(String domain, long elapsedTimeMillis, Exception ex) {
}
@Override
public DomainInfo getDomain(WXPayConfig config) {
return new IWXPayDomain.DomainInfo(WXPayConstants.DOMAIN_API, true);
}
};
return iwxPayDomain;
}
}
发起统一下单 AND 前端调起微信支付必要参数
// 发起微信支付
WXPay wxpay = null;
Map result = new HashMap>();
try {
// ******************************************
//
// 统一下单
//
// ******************************************
wxpay = new WXPay(iWxPayConfig); // *** 注入自己实现的微信配置类, 创建WXPay核心类, WXPay 包括统一下单接口
Map data = new HashMap ();
data.put("body", "订单详情");
data.put("out_trade_no", transOrder.getGlobalOrderId()); // 订单唯一编号, 不允许重复
data.put("total_fee", String.valueOf(transOrder.getOrderAmount().multiply(new BigDecimal(100)).intValue())); // 订单金额, 单位分
data.put("spbill_create_ip", "192.168.31.166"); // 下单ip
data.put("openid", openId); // 微信公众号统一标示openid
data.put("notify_url", "http://wxlj.oopmind.com/payCallback"); // 订单结果通知, 微信主动回调此接口
data.put("trade_type", "JSAPI"); // 固定填写
logger.info("发起微信支付下单接口, request={}", data);
Map response = wxpay.unifiedOrder(data); // 微信sdk集成方法, 统一下单接口unifiedOrder, 此处请求 MD5加密 加密方式
logger.info("微信支付下单成功, 返回值 response={}", response);
String returnCode = response.get("return_code");
if (!SUCCESS.equals(returnCode)) {
return null;
}
String resultCode = response.get("result_code");
if (!SUCCESS.equals(resultCode)) {
return null;
}
String prepay_id = response.get("prepay_id");
if (prepay_id == null) {
return null;
}
// ******************************************
//
// 前端调起微信支付必要参数
//
// ******************************************
String packages = "prepay_id=" + prepay_id;
Map wxPayMap = new HashMap ();
wxPayMap.put("appId", iWxPayConfig.getAppID());
wxPayMap.put("timeStamp", String.valueOf(Utility.getCurrentTimeStamp()));
wxPayMap.put("nonceStr", Utility.generateUUID());
wxPayMap.put("package", packages);
wxPayMap.put("signType", "MD5");
// 加密串中包括 appId timeStamp nonceStr package signType 5个参数, 通过sdk WXPayUtil类加密, 注意, 此处使用 MD5加密 方式
String sign = WXPayUtil.generateSignature(wxPayMap, iWxPayConfig.getKey());
// ******************************************
//
// 返回给前端调起微信支付的必要参数
//
// ******************************************
result.put("prepay_id", prepay_id);
result.put("sign", sign);
result.putAll(wxPayMap);
return result;
} catch (Exception e) {
}
回调结果处理
核心是支付订单回调时, 需校验加密签名是否匹配, 防止出现模拟成功通知
@RequestMapping(value = "/payCallback", method = RequestMethod.POST)
public String payCallback(HttpServletRequest request, HttpServletResponse response) {
logger.info("进入微信支付异步通知");
String resXml="";
try{
//
InputStream is = request.getInputStream();
//将InputStream转换成String
BufferedReader reader = new BufferedReader(new InputStreamReader(is));
StringBuilder sb = new StringBuilder();
String line = null;
try {
while ((line = reader.readLine()) != null) {
sb.append(line + " ");
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
resXml=sb.toString();
logger.info("微信支付异步通知请求包: {}", resXml);
return wxTicketService.payBack(resXml);
}catch (Exception e){
logger.error("微信支付回调通知失败",e);
String result = " ";
return result;
}
}
@Override
public String payBack(String notifyData) {
logger.info("payBack() start, notifyData={}", notifyData);
String xmlBack="";
Map notifyMap = null;
try {
WXPay wxpay = new WXPay(iWxPayConfig);
notifyMap = WXPayUtil.xmlToMap(notifyData); // 转换成map
if (wxpay.(notifyMap)) {
// 签名正确
// 进行处理。
// 注意特殊情况:订单已经退款,但收到了支付结果成功的通知,不应把商户侧订单状态从退款改成支付成功
String return_code = notifyMap.get("return_code");//状态
String out_trade_no = notifyMap.get("out_trade_no");//订单号
if (out_trade_no == null) {
logger.info("微信支付回调失败订单号: {}", notifyMap);
xmlBack = " ";
return xmlBack;
}
// 业务逻辑处理 ****************************
logger.info("微信支付回调成功订单号: {}", notifyMap);
xmlBack = " ";
return xmlBack;
} else {
logger.error("微信支付回调通知签名错误");
xmlBack = " ";
return xmlBack;
}
} catch (Exception e) {
logger.error("微信支付回调通知失败",e);
xmlBack = " ";
}
return xmlBack;
}
统一下单的签名和后续前端拉取微信支付的签名需要统一, 也就是都采用MD5加密, 如果2者不同, 会导致前端拉取微信支付fail, 这是一个巨大的坑, 因为这个原因调试了好久, 微信在文档里没有明确标出统一下单的签名校验方式 需要和前端拉取微信支付的签名校验保持一致.
微信sdk里的源码需要针对这个问题调整一下, 调整如下:
WXPay类需要修改下加密判断,在WXPay构造方法中,调整如下
public WXPay(final WXPayConfig config, final String notifyUrl, final boolean autoReport, final boolean useSandbox) throws Exception {
this.config = config;
this.notifyUrl = notifyUrl;
this.autoReport = autoReport;
this.useSandbox = useSandbox;
if (useSandbox) {
this.signType = SignType.MD5; // 沙箱环境
}
else {
this.signType = SignType.MD5;// 将这里的加密方式修改为SignType.MD5, 保持跟前端吊起微信加密方式保持一致
}
this.wxPayRequest = new WXPayRequest(config);
}
结束语
做完以后, 微信支付的后端逻辑还是很清晰的, 但是在开发过程中很煎熬, 不清楚每个专业术语在微信哪里配置, 加密方式乱的很
Ⅷ java开发微信扫码支付,怎么做测试,公众账号ID,商户号这些怎么来
一、直接接入微信支付二、通过微信二次开发商的平台接入支付功能,三、在微信平台中加入微网页,四、通过第三方APP收款,
Ⅸ 如何使用java开发微信公众平台接口
1、首先,要在微信公众平台给你的账号申请到“高级功能” ;前台也就是菜单要想个性化设置必须要有这个功能,不然你只能添加菜单和关闭,但不能删除,还有自动回复也是。
2、后台要看你自己了。
Ⅹ 初学微信公众号使用java开发,出现错误,提示公众号服务出现故障,怎么办,求大神指点迷津!
1,你可以看一下编程工具里有没有出现错误提示
2,设置一些输出点,用来检查代码
3,确保你的appid和token填写正确
4,确保你的公众号有这个权限
5,所需的外网能放问的域名配置正确