博客
关于我
支付模块-第三方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/

你可能感兴趣的文章
oracle 限制用户并行,insert /*parallel */ 到不同用户,并行起不来的问题
查看>>
oracle--用户,权限,角色的管理
查看>>
oracle00205报错,Oracle控制文件损坏报错场景
查看>>
Oracle10g EM乱码之快速解决
查看>>
Oracle10g下载地址--多平台下的32位和64位
查看>>
Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
查看>>
oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
查看>>
Oracle11G基本操作
查看>>
Oracle11g服务详细介绍及哪些服务是必须开启的?
查看>>
Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
查看>>
oracle12安装软件后安装数据库,然后需要自己配置监听
查看>>
Oracle——08PL/SQL简介,基本程序结构和语句
查看>>
Oracle——distinct的用法
查看>>
Oracle、MySQL、SQL Server架构大对比
查看>>
oracle下的OVER(PARTITION BY)函数介绍
查看>>
Oracle中DATE数据相减问题
查看>>
Oracle中merge into的使用
查看>>
oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
查看>>
oracle中sql的case语句运用--根据不同条件去排序!
查看>>
Oracle中Transate函数的使用
查看>>