微信不是一個營銷工具,騰訊對使用微信做營銷是有限制的。你很難把商品直接退到微信用戶面前。你需要解決兩個問題
第一,如何將商品內容展現給用戶
基本上只能由用戶主動向你的公眾號發起信息你才能給用戶推相應的內容,而通過這種方式購物的體驗是非常差的。訂閱號每天只能想用戶群發一條內容,基本滿足不了電商網站的需求。
第二,如何支付
新推出的微信支付只有服務號可以使用,而服務號連每天一條的群發內容都沒有。如果你是訂閱號的話只能選擇例如財付通等第三方的支付方式。
那麼我的思路是:
用微信回復圖文連接,這個連接會指向你的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,所需的外網能放問的域名配置正確