博客
关于我
支付模块-第三方APP如何拉取微信小程序支付(编码篇)
阅读量:357 次
发布时间:2019-03-04

本文共 3573 字,大约阅读时间需要 11 分钟。

【实现过程】

(1)获取参数

由于我这个接口是小程序调取的,获取的参数第一个是从小程序获取的code值,第二个参数是服务传给小程序,然后小程序再传给服务的orderId。

static String wxXcxUrl = "https://api-mop.chinaums.com/v1/netpay/wx/unified-order";

(2)获取OpenId

通过code值获取到OpenId。

@Service@AllArgsConstructorpublic class WxXcxServiceImpl implements WxXcxService {    private static final Logger log = LoggerFactory.getLogger(WxXcxServiceImpl.class);    @Override    public String getOpenId(String code) throws Exception {        log.debug("通过code值获取到OpenId");        Map
rtnMap = new HashMap<>(); String url = "https://api.weixin.qq.com/sns/jscode2session"; url += "?appid=" + getAppId(); url += "&secret=" + getSecret(); url += "&js_code=" + code; url += "&grant_type=authorization_code"; CloseableHttpClient httpClient = HttpClientBuilder.create().build(); HttpGet httpGet = new HttpGet(url); CloseableHttpResponse response = null; RequestConfig requestConfig = RequestConfig.custom() .setConnectTimeout(5000) .setConnectionRequestTimeout(5000) .setSocketTimeout(5000) .setRedirectsEnabled(false) .build(); httpGet.setConfig(requestConfig); response = httpClient.execute(httpGet); HttpEntity responseEntity = response.getEntity(); if (responseEntity != null) { String res = EntityUtils.toString(responseEntity); log.debug("响应内容为: {}", res); JSONObject jo = JSON.parseObject(res); String openid = jo.getString("openid"); log.debug("openid: {}", openid); return openid; } throw new RuntimeException("获取OpenId失败"); }}

(3)银联的鉴权

@Service @AllArgsConstructorpublic class AppXiaDanServiceImpl implements AppXiaDanService {    private static final String appId = "";    private static final String appKey = "";    private static String authorization;    @Override    public String send(String url, String entity) throws Exception {        authorization = getOpenBodySig(appId, appKey, entity);        CloseableHttpClient httpClient = HttpClients.createDefault();        HttpPost httpPost = new HttpPost(url);        httpPost.addHeader("Authorization", authorization);        StringEntity se = new StringEntity(entity, "UTF-8");        se.setContentType("application/json");        httpPost.setEntity(se);        CloseableHttpResponse response = httpClient.execute(httpPost);        HttpEntity entity1 = response.getEntity();        String resStr = null;        if (entity1 != null) {            resStr = EntityUtils.toString(entity1, "UTF-8");        }        httpClient.close();        response.close();        return resStr;    }    private static String getOpenBodySig(String appId, String appKey, String body) throws Exception {        String timestamp = new SimpleDateFormat("yyyyMMddHHmmss").format(new Date());        String nonce = UUID.randomUUID().toString().replace("-", "");        byte[] data = body.getBytes("UTF-8");        byte[] localSignature = hmacSHA256(data, appKey.getBytes());        String st1_C = appId + timestamp + nonce + bytesToHex(localSignature);        return "OPEN-BODY-SIG AppId=" + "\"" + appId + "\"" + ", Timestamp=" + "\"" + timestamp + "\", Nonce=" + "\"" + nonce + "\", Signature=" + "\"" + st1_C + "\"";    }    private static byte[] hmacSHA256(byte[] data, byte[] key) throws NoSuchAlgorithmException, InvalidKeyException {        Mac mac = Mac.getInstance("HmacSHA256");        mac.init(new SecretKeySpec(key, "HmacSHA256"));        return mac.doFinal(data);    }}

【测试返回】

测试结果:

转载地址:http://hphe.baihongyu.com/

你可能感兴趣的文章
Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
查看>>
Openlayers高级交互(4/20):手绘多边形,导出KML文件,可以自定义name和style
查看>>
Openlayers高级交互(5/20):右键点击,获取该点下多个图层的feature信息
查看>>
Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
查看>>
Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
查看>>
Openlayers高级交互(8/20):选取feature,平移feature
查看>>
Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
查看>>
Openlayers:DMS-DD坐标形式互相转换
查看>>
openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
查看>>
OpenLDAP(2.4.3x)服务器搭建及配置说明
查看>>
OpenLDAP编译安装及配置
查看>>
Openmax IL (二)Android多媒体编解码Component
查看>>
OpenMCU(一):STM32F407 FreeRTOS移植
查看>>
OpenMCU(三):STM32F103 FreeRTOS移植
查看>>
OpenMCU(三):STM32F103 FreeRTOS移植
查看>>
OpenMCU(二):GD32E23xx FreeRTOS移植
查看>>
OpenMCU(五):STM32F103时钟树初始化分析
查看>>
OpenMCU(四):STM32F103启动汇编代码分析
查看>>
OpenMetadata 命令执行漏洞复现(CVE-2024-28255)
查看>>
OpenMMLab | AI玩家已上线!和InternLM解锁“谁是卧底”新玩法
查看>>