From c3e81c06e7e491902672cedb2d9683e8763d6330 Mon Sep 17 00:00:00 2001 From: luoyang Date: Mon, 30 Mar 2020 13:51:01 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E4=BC=98=E5=8C=96gateway=20=E4=B8=8A?= =?UTF-8?q?=E4=BC=A0=E6=96=87=E4=BB=B6=E6=8A=A5=E9=94=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pom.xml | 2 +- .../manage/gateway/web/GtwPayController.java | 14 ++++++++++++-- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/pom.xml b/pom.xml index be6d056b7..57a345101 100644 --- a/pom.xml +++ b/pom.xml @@ -9,7 +9,7 @@ 4.0.0 manage - 1.4.20 + 1.4.21 UTF-8 1.8.0 diff --git a/src/main/java/au/com/royalpay/payment/manage/gateway/web/GtwPayController.java b/src/main/java/au/com/royalpay/payment/manage/gateway/web/GtwPayController.java index 5079ba76b..280863f6d 100644 --- a/src/main/java/au/com/royalpay/payment/manage/gateway/web/GtwPayController.java +++ b/src/main/java/au/com/royalpay/payment/manage/gateway/web/GtwPayController.java @@ -5,7 +5,10 @@ import au.com.royalpay.payment.core.utils.PaymentValidUtils; import au.com.royalpay.payment.manage.gateway.advice.Gtw2Ctrl; import au.com.royalpay.payment.manage.gateway.core.GatewayMerchantApply; import au.com.royalpay.payment.tools.connections.attachment.core.AttachmentClient; +import au.com.royalpay.payment.tools.exceptions.BadRequestException; import com.alibaba.fastjson.JSONObject; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.springframework.validation.Errors; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; @@ -19,6 +22,7 @@ import javax.annotation.Resource; @RequestMapping("/api/v1.0/org_gateway/partners/{shortId}") @Gtw2Ctrl public class GtwPayController { + private Logger logger = LoggerFactory.getLogger(getClass()); @Resource private GatewayMerchantApply gatewayMerchantApply; @Resource @@ -41,12 +45,18 @@ public class GtwPayController { } @PostMapping("/attachment/files") - public JSONObject uploadFile(@PathVariable String shortId,@RequestParam MultipartFile file) throws Exception { + public JSONObject uploadFile(@PathVariable String shortId,@RequestParam MultipartFile file) { JSONObject org = gatewayMerchantApply.validOrgV200(shortId); if (org == null) { throw new InvalidShortIdException(); } - JSONObject fileInfo = attachmentClient.uploadFile(file, false); + JSONObject fileInfo = new JSONObject(); + try { + fileInfo = attachmentClient.uploadFile(file, false); + } catch (Exception e) { + logger.error("file upload fail :{}" , e.getMessage()); + throw new BadRequestException("File upload failed"); + } fileInfo.put("file_type", fileInfo.getString("filetype")); fileInfo.remove("filepath"); fileInfo.remove("length"); From 697c687c223c662a29466c513a3760e058295072 Mon Sep 17 00:00:00 2001 From: "taylor.dang" Date: Mon, 30 Mar 2020 16:52:40 +0800 Subject: [PATCH 2/2] =?UTF-8?q?[Y]=20h5=E7=BD=91=E5=85=B3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/ui/static/images/guide.png | Bin 0 -> 1011 bytes .../ui/static/templates/skip_wxbrowser.css | 193 ++++++++++++++++++ .../ui/static/templates/skip_wxbrowser.js | 50 +++++ 3 files changed, 243 insertions(+) create mode 100644 src/main/ui/static/images/guide.png create mode 100644 src/main/ui/static/templates/skip_wxbrowser.css create mode 100644 src/main/ui/static/templates/skip_wxbrowser.js diff --git a/src/main/ui/static/images/guide.png b/src/main/ui/static/images/guide.png new file mode 100644 index 0000000000000000000000000000000000000000..1f1e23f74467d92fb7420ec0bbf5653084f7b9ff GIT binary patch literal 1011 zcmeAS@N?(olHy`uVBq!ia0vp^UO+sBgBeINTlvcXsdWK9A+A9B|Ih)tU0<|-F19QQ z@(X78^P^qr)4MI4V!ZoyPR+7Zd9kUU~}1(8-o7knBAJO?NN=?rJD8EcN(&n_Hc%HIj*{Ds!FX% zOFGv+zdN6}{`2wYp4)yYynMC#&r*iv=d*)PKXP6&FIf54sl9*Bzy9rY(mD0{mVJK% zdH+2-clqPn&pZauVWPGY! zcdJV3Nz2r>HFB*{uXrXZW#3l}@hxRO z>Z!{0b%|+f)~i;hUXz6Z%x5*G1Pdyi-D(i<#X@&W$ijf^#A)9m_iIe)KhrV$Yr~`I zZ83)OJCgEJH*CBf+U(()cOu;M!~@=#;>ndKLKiHzbFnIZTyiLK^&B%1t$^uHx*ImV zJpI_`OfegKxO4Kl$Xvysd8ezwRsCLDa)mzH@@{2=?H*lT5m{5C8`s%a1zo!}3};j@xfZgSNLJxX^l|8=W`U9<{VD?)BMOib9T^~sRC_^P>J?K$|2dHr z$B$j>xc#DJ#kvPmmM=LMd4VCi;?10;GG}HOS2LFV|8?%0W^K{hRXsod?JTwC*m^K0 zIpp}fht)Cvc{Zp9-?Q=x$@kjuT_EDp?pwwG*7WA;Jr>a3Z{A@t*?np}b8(gF>lO3r z4wT78XFtF3c6GwtqwQRlyAqu0FWEJ{D|W-rRTK9;4a}^VuhwOXl@! zP8Z-aIW*_1(5e~B{z!!yyyN1vTg{mwrn~g4d0_OvuAKJ3G=<|P(-yDa!Sz>#wUTMd z=cn?V*%K@>LmcKb<}^pn)BB@l+Isjxidr3WK!?}HQw6g$fO&zz)78&qol`;+0I*s$ A`2YX_ literal 0 HcmV?d00001 diff --git a/src/main/ui/static/templates/skip_wxbrowser.css b/src/main/ui/static/templates/skip_wxbrowser.css new file mode 100644 index 000000000..e91cd1866 --- /dev/null +++ b/src/main/ui/static/templates/skip_wxbrowser.css @@ -0,0 +1,193 @@ +* { + margin: 0; + padding: 0; +} + +a { + text-decoration: none; +} + +img { + max-width: 100%; + height: auto; +} + +.weixin-tip { + padding-top: 10px; + display: none; + position: fixed; + left: 0; + top: 0; + bottom: 0; + background: rgba(0, 0, 0, 0.8); + filter: alpha(opacity=80); + height: 100%; + width: 100%; + z-index: 100; +} + +.weixin-tip p { + text-align: center; + margin-top: 10%; + padding: 0 5%; +} + +body { + font-weight: 500; + font-family: PingFangSC-Regular, "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif; +} + +.am-header { + display: none; +} + +.alipay-logo { + display: none; +} + +.result { + margin-top: 40px; + width: 100%; +} + +.result-alipay-logo { + width: 70px; + height: 98px; + margin: auto; + background-image: url(); + background-repeat: no-repeat; + background-size: contain; +} + +.result-royalpay-logo { + width: 70px; + height: 98px; + margin: auto; + background-image: url(); + background-repeat: no-repeat; + background-size: contain; +} + +.result-title { + margin: 40px 0 14px; + text-align: center; + font-size: 21px; + color: #f06101; + line-height: 25px; +} + +.result-tips { + max-width: 370px; + margin: 0 auto 10px; + padding: 0 15px; + font-size: 15px; + color: #a5a5a5; + line-height: 18px; + text-align: left; + word-break: break-all; + word-wrap: break-word; +} + +.guide-tips { + max-width: 200px; + margin: 0 auto 10px; + padding: 0 15px; + font-size: 16px; + color: #a5a5a5; + line-height: 30px; + text-align: left; + word-break: break-all; + word-wrap: break-word; +} + +.result-botton { + margin: 0 15px 20px; +} + +.result-botton a { + display: block; + margin: auto; + -webkit-box-sizing: border-box; + box-sizing: border-box; + max-width: 384px; + height: 44px; + text-align: center; +} + +.result-botton a.am-button-white { + color: #f06101; + background: #ffffff; + border: 1px solid #f06101; +} + +.result-botton .am-button[disabled=disabled] { + color: #e6e6e6; + background: #f8f8f8; + border: 1px solid #dedede; +} + +.loading { + display: none; +} + +.close-weixin-tip img { + padding-left: 30px; + padding-top: 30px; + width: 25px; +} + +.guide-tip { + display: inline; + float: right; + height: 20%; +} + + +.am-button { + -ms-box-sizing: border-box; + box-sizing: border-box; + display: inline-block; + margin: 0; + padding: 4px 8px; + width: 100%; + text-align: center; + font-size: 18px; + line-height: 2; + border-radius: 4px; + background-clip: padding-box; +} + +.am-button-royalpay { + border: 1px solid #f06101; + color: #fff; + background: #f06101; +} + +.pay-brands { + text-align: center; + line-height: 20px; + font-size: 24px; + margin-top: 12px; + color: #dddddd; +} + +.pay-brands img { + height: 18px; +} + + +ol { + padding: 2%; + counter-reset: sectioncounter; + color: #ffffff; +} + +ol > li:before { + counter-increment: sectioncounter; + color: #ffffff; + text-align: center; +} + +ol li { + list-style-position: outside; +} diff --git a/src/main/ui/static/templates/skip_wxbrowser.js b/src/main/ui/static/templates/skip_wxbrowser.js new file mode 100644 index 000000000..fbf786dcd --- /dev/null +++ b/src/main/ui/static/templates/skip_wxbrowser.js @@ -0,0 +1,50 @@ +window = {}; +$(function () { + 'use strict'; + var winHeight = $(window).height(); + var ua = navigator.userAgent.toLowerCase(); + if (ua.indexOf('micromessenger') >= 0) { + $(".weixin-tip").show().css("height", winHeight); + } else { + location.href = window.target_href; + } + $('.close-weixin-tip').bind('touchstart', function () { + $(".weixin-tip").hide(); + checkOrderStd(window.client_moniker, window.partner_order_id, true); + }); + $('#complete').bind('touchstart', function () { + checkOrderStd(window.client_moniker, window.partner_order_id, false); + }); + $('#continue_use_browser').bind('touchstart', function () { + location.href = window.target_href; + }); + + function checkOrderStd(clientMoniker, merchantOrderId, needLoop) { + if (!clientMoniker || !merchantOrderId) { + return; + } + $.ajax({ + url: '/api/v1.0/payment/clients/' + clientMoniker + '/orders/' + merchantOrderId + '/status', + method: 'GET', + dataType: 'json', + success: function (res) { + if (res.paid) { + location.href = window.redirect + (window.redirect.indexOf('?') < 0 ? '?' : '&') + 'success=true&time=' + res.time + '&nonce_str=' + res.nonce_str + '&sign=' + res.sign; + } else { + if (needLoop) { + setTimeout(checkOrderStd(clientMoniker, merchantOrderId, needLoop), 3000); + } + if (!needLoop && !res.paid) { + alert("订单未支付,请稍后再试"); + } + } + }, + error: function (res) { + if (needLoop && res.message) { + alert(res.message); + } + } + }) + } +}) +;