java掃碼支付
⑴ java建行支付判斷訂單狀態
使用後端進行數據判斷。
首先在後端平台設置銀行卡賬號和密碼用來判斷支付,支付完成後,建行會自動調用回調地址,這個地址是在建行商戶平台配置的,反饋有兩種,網頁反饋和伺服器反饋,頁面反饋付款人付款完成後,點擊返回商戶網站按鈕,觸發頁面反饋,伺服器反饋只要支付成功,無需觸發,由建行支付網關,以post 方法,發信息給反饋URL還分為網上銀行和手機銀行反饋,網上銀行就是微信支付寶調用url支付,手機銀行就是建行手機銀行支付客戶端,其實手機、網銀,區分不是很嚴格,一般都設置成一樣的,同一筆支付,可能會觸發多渠道的同時反饋,所以,反饋機制,在響應的時候,是允許重復的,一般來說,伺服器,頁面,是寫成兩個不同的回調處理,或者,加個條件判斷,同時允許post和get,寫成一個,就不太好判斷反饋的來源了,寫成兩個,再通過日誌,能區分反饋的來源。
⑵ java開發微信掃碼支付,怎麼做測試,公眾賬號ID,商戶號這些怎麼來
一、直接接入微信支付二、通過微信二次開發商的平台接入支付功能,三、在微信平台中加入微網頁,四、通過第三方APP收款,
⑶ 我現在在做一個javaweb的畢業設計,購物網站,請問能在項目中使用支付寶的二維碼支付技術嗎
您好, 我這有幾套javaweb的在線商城, 裡面也是帶支付的功能, 由於平台對個人不開放許可權, 所以用官方方案就不太可能了
可以用的方案是直接早幾個四方聚合支付 這個用來測試一下還行
或者基於手機監控的方案去做, 這個能保證演示成功, 而且成本特別低
⑷ java 微信支付介面為什麼用安卓手機支付不成功
微信支付有很多不同類型,掃碼支付、公眾號支付等等。安卓手機也是可以成功的。Java是伺服器端語言,與手機操作系統無關。
⑸ java微信掃碼支付的demo怎麼運行
要使用此功能,用戶只需在微信中關聯一張銀行卡,並完成身份認證,即可將裝有app的智能手機變成一個全能錢包,之後即可購買合作商戶的商品及服務,在付費時只需在自己的智能手機上輸入密碼,無需任何刷卡步驟即可完成整個過程且簡便流暢。
目前,微信支付已實現多種支付方式,並提供多種營銷新工具,滿足用戶及商戶的不同場景。
⑹ 支付寶掃碼支付java 有jdk要求嗎
得看什麼平台 了 。。。。。。。。。。。。。。。。。。。。。。。。
⑺ Java端怎麼實現模擬支付
1、這是一個模擬支付的流程圖
2、如果你要用java實現,要分成前後端,前端可以找一個前端框架(如bootstrap),後端用springboot
3、如果你對這些技術不熟悉,可以直接在github上搜索一個web項目(基本上就都配置好了),自己改一下就行
⑻ java掃描微信二維碼成功付款後,怎麼跳轉到成功頁面
用意圖intent即可轉跳到指定界面
android中,激活所有的界面都是通過intent(意圖)來激活的
用法:
intent
intent
=
new
intent(context,目標界面activity.class);
startactivity(intent);
⑼ 怎麼用java調用微信支付介面
java調用微信支付介面方法:
RequestHandler requestHandler = new RequestHandler(super.getRequest(),super.getResponse());
//獲取token //兩小時內有效,兩小時後重新獲取
Token = requestHandler.GetToken();
//更新token 到應用中
requestHandler.getTokenReal();
System.out.println("微信支付獲取token=======================:" +Token);
//requestHandler 初始化
requestHandler.init();
requestHandler.init(appid,appsecret, appkey,partnerkey, key);
// --------------------------------本地系統生成訂單-------------------------------------
// 設置package訂單參數
SortedMap<String, String> packageParams = new TreeMap<String, String>();
packageParams.put("bank_type", "WX"); // 支付類型
packageParams.put("body", "xxxx"); // 商品描述
packageParams.put("fee_type", "1"); // 銀行幣種
packageParams.put("input_charset", "UTF-8"); // 字元集
packageParams.put("notify_url", "http://xxxx.com/xxxx/wxcallback"); // 通知地址 這里的通知地址使用外網地址測試,注意80埠是否打開。
packageParams.put("out_trade_no", no); // 商戶訂單號
packageParams.put("partner", partenerid); // 設置商戶號
packageParams.put("spbill_create_ip", super.getRequest().getRemoteHost()); // 訂單生成的機器IP,指用戶瀏覽器端IP
packageParams.put("total_fee", String.valueOf(rstotal)); // 商品總金額,以分為單位
// 設置支付參數
SortedMap<String, String> signParams = new TreeMap<String, String>();
signParams.put("appid", appid);
signParams.put("noncestr", noncestr);
signParams.put("traceid", PropertiesUtils.getOrderNO());
signParams.put("timestamp", timestamp);
signParams.put("package", packageValue);
signParams.put("appkey", this.appkey);
// 生成支付簽名,要採用URLENCODER的原始值進行SHA1演算法!
String sign ="";
try {
sign = Sha1Util.createSHA1Sign(signParams);
} catch (Exception e) {
e.printStackTrace();
}
// 增加非參與簽名的額外參數
signParams.put("sign_method", "sha1");
signParams.put("app_signature", sign);
// api支付拼包結束------------------------------------
//獲取prepayid
String prepayid = requestHandler.sendPrepay(signParams);
System.out.println("prepayid :" + prepayid);
// --------------------------------生成完成---------------------------------------------
//生成預付快訂單完成,返回給android,ios 掉起微信所需要的參數。
SortedMap<String, String> payParams = new TreeMap<String, String>();
payParams.put("appid", appid);
payParams.put("noncestr", noncestr);
payParams.put("package", "Sign=WXPay");
payParams.put("partnerid", partenerid);
payParams.put("prepayid", prepayid);
payParams.put("appkey", this.appkey);
//這里除1000 是因為參數長度限制。
int time = (int) (System.currentTimeMillis() / 1000);
payParams.put("timestamp",String.valueOf(time));
System.out.println("timestamp:" + time);
//簽名
String paysign ="";
try {
paysign = Sha1Util.createSHA1Sign(payParams);
} catch (Exception e) {
e.printStackTrace();
}
payParams.put("sign", paysign);
//拼json 數據返回給客戶端
BasicDBObject backObject = new BasicDBObject();
backObject.put("appid", appid);
backObject.put("noncestr", payParams.get("noncestr"));
backObject.put("package", "Sign=WXPay");
backObject.put("partnerid", payParams.get("partnerid"));
backObject.put("prepayid", payParams.get("prepayid"));
backObject.put("appkey", this.appkey);
backObject.put("timestamp",payParams.get("timestamp"));
backObject.put("sign",payParams.get("sign"));
String backstr = dataObject.toString();
System.out.println("backstr:" + backstr);
return backstr;
====================到此為止,預付款訂單已生成,並且已返回客戶端====================
//坐等微信伺服器通知,通知的地址就是生成預付款訂單的notify_url
ResponseHandler resHandler = new ResponseHandler(request, response);
resHandler.setKey(partnerkey);
//創建請求對象
//RequestHandler queryReq = new RequestHandler(request, response);
//queryReq.init();
if (resHandler.isTenpaySign() == true) {
//商戶訂單號
String out_trade_no = resHandler.getParameter("out_trade_no");
System.out.println("out_trade_no:" + out_trade_no);
//財付通訂單號
String transaction_id = resHandler.getParameter("transaction_id");
System.out.println("transaction_id:" + transaction_id);
//金額,以分為單位
String total_fee = resHandler.getParameter("total_fee");
//如果有使用折扣券,discount有值,total_fee+discount=原請求的total_fee
String discount = resHandler.getParameter("discount");
//支付結果
String trade_state = resHandler.getParameter("trade_state");
//判斷簽名及結果
if ("0".equals(trade_state)) {
//------------------------------
//即時到賬處理業務開始
//------------------------------
System.out.println("----------------業務邏輯執行-----------------");
//——請根據您的業務邏輯來編寫程序(以上代碼僅作參考)——
System.out.println("----------------業務邏輯執行完畢-----------------");
System.out.println("success"); // 請不要修改或刪除
System.out.println("即時到賬支付成功");
//給財付通系統發送成功信息,財付通系統收到此結果後不再進行後續通知
resHandler.sendToCFT("success");
//給微信伺服器返回success 否則30分鍾通知8次
return "success";
}else{
System.out.println("通知簽名驗證失敗");
resHandler.sendToCFT("fail");
response.setCharacterEncoding("utf-8");
}
}else {
System.out.println("fail -Md5 failed");