start_time: 2024-04-29 18:36:51 +0800

支付宝App支付10070、10146问题解决记

96
夜色001
IP属地: 江西
2020.08.25 17:45 字数 347

困扰了2周的支付宝支付问题终于解决了,网上的资料都翻了个底朝天。

最初报ALIN10070。

【解决办法】AppId错误,确定appid进行替换

更换后继续,报ALIN10146。

网上有一篇文章写的非常好,可以排查支付宝对接的方方面面的问题
https://openclub.alipay.com/club/history/read/6918
【解决办法】

  • 1、找客户确认发现应用未上线。——让客户上线即可
  • 2、应用私钥错误
    这个错误很坑,用户发的资料包含了两个与私钥相关的文件,一个是CSR目录下,包含了.csr文件的;一个是RSA文件夹下,直接命名为"应用私钥2048.txt";
    由于我们用的是证书模式,所以应该使用CSR目录下的应用私钥,而不是“应用私钥2048.txt”,我们这里根本不用。


    证书模式下使用.png

    普通模式下使用.png
  • 3、金额错误
    调试接口后发现输出的金额是0.00,经检查发现1/100后变成了0,转成double型后再处理。

总结

网上已经有很多服务端和用户端的例子了,多找找。
另外附上自己的代码

public static final String GATEWAY = "https://openapi.alipay.com/gateway.do";

@Override
    @Transactional
    public String aliPay(UnifiedOrderDTO unifiedOrderDTO) {
        try {
            //实例化客户端
            DefaultAlipayClient alipayClient = initDefaultAlipayClient();
            //实例化具体API对应的request类,类名称和接口名称对应,当前调用接口名称:alipay.trade.app.pay
            AlipayTradeAppPayRequest request = new AlipayTradeAppPayRequest();
            //SDK已经封装了公共参数,这里只需要传入业务参数。
            UnifiedOrderTO unifiedOrderTO = createUnifiedOrderTO(unifiedOrderDTO);
            //封装支付宝业务参数
            AlipayTradeAppPayModel model = generatePayModel(unifiedOrderTO);
            request.setBizModel(model);
            request.setNotifyUrl(rootDom + AlipayConstant.notify_url);
            //请求执行
            //以前调用certificateExecute老报nullpoint,后改成了sdkExecute正常了
            AlipayTradeAppPayResponse response = alipayClient.sdkExecute(request);
            boolean success = response.isSuccess();
            if (success) {
                return response.getBody();
            } else {
                throw new OpenException(OpenResponseCode.ALIPAY_APPLAY_FAILD);
            }
        } catch (AlipayApiException e) {
            e.printStackTrace();
            throw new OpenException(OpenResponseCode.ALIPAY_APPLAY_EXCEPTION);
        }
    }

private DefaultAlipayClient initDefaultAlipayClient() throws AlipayApiException {
        CertAlipayRequest certAlipayRequest = new CertAlipayRequest();
        certAlipayRequest.setServerUrl(AlipayConstant.GATEWAY);
        certAlipayRequest.setAppId(sysconfigCache.getKey("AliAppid"));
        certAlipayRequest.setPrivateKey(AlipayConstant.PRIVATE_KEY);
        certAlipayRequest.setFormat("json");
        certAlipayRequest.setCharset(AlipayConstant.CHARSET);
        certAlipayRequest.setSignType(AlipayConstant.SIGNTYPE);
        certAlipayRequest.setCertPath(getKeyFilePath("AliAppCert"));
        certAlipayRequest.setAlipayPublicCertPath(getKeyFilePath("AliPayCert"));
        certAlipayRequest.setRootCertPath(getKeyFilePath("AliPayRootCert"));
        return new DefaultAlipayClient(certAlipayRequest);
    }

private AlipayTradeAppPayModel generatePayModel(UnifiedOrderTO unifiedOrderTO) {
        AlipayTradeAppPayModel model = new AlipayTradeAppPayModel();
        //对一笔交易的具体描述信息。如果是多种商品,请将商品描述字符串累加传给body。
        model.setBody(unifiedOrderTO.getBody());
        //商品的标题/交易标题/订单标题/订单关键字等
        model.setSubject(unifiedOrderTO.getBody());
        //商户网站唯一订单号
        model.setOutTradeNo(unifiedOrderTO.getOut_trade_no());
        //该笔订单允许的最晚付款时间,逾期将关闭交易。取值范围:1m~15d。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。 该参数数值不接受小数点, 如 1.5h,可转换为 90m。
        model.setTimeoutExpress("30m");
        //订单总金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000]
        DecimalFormat df = new DecimalFormat("######0.00");
        model.setTotalAmount(df.format(Double.valueOf(unifiedOrderTO.getTotal_fee()) / 100));
        //公用参数(附加数据)
        try {
            model.setPassbackParams(URLEncoder.encode(unifiedOrderTO.getAttach(), "utf-8"));
        } catch (UnsupportedEncodingException e) {
        }
        return model;
    }
最后编辑于 :2020-08-25 17:45:29
©著作权归作者所有,转载或内容合作请联系作者
序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
783c64db 45e5 48d7 82e4 95736f50533e 沈念sama 阅读 159716 评论 4 赞 364
序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
783c64db 45e5 48d7 82e4 95736f50533e 沈念sama 阅读 67558 评论 1 赞 294
文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
8 开封第一讲书人 阅读 109431 评论 0 赞 244
文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
8 开封第一讲书人 阅读 44127 评论 0 赞 209
正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
388e473c fe2f 40e0 9301 e357ae8f1b41 茶点故事 阅读 52511 评论 3 赞 287
文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
8 开封第一讲书人 阅读 40692 评论 1 赞 222
那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
783c64db 45e5 48d7 82e4 95736f50533e 沈念sama 阅读 31915 评论 2 赞 313
文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
8 开封第一讲书人 阅读 30664 评论 0 赞 202
序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
783c64db 45e5 48d7 82e4 95736f50533e 沈念sama 阅读 34412 评论 1 赞 246
正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
388e473c fe2f 40e0 9301 e357ae8f1b41 茶点故事 阅读 30616 评论 2 赞 245
正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
388e473c fe2f 40e0 9301 e357ae8f1b41 茶点故事 阅读 32105 评论 1 赞 260
序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
783c64db 45e5 48d7 82e4 95736f50533e 沈念sama 阅读 28424 评论 2 赞 254
正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
388e473c fe2f 40e0 9301 e357ae8f1b41 茶点故事 阅读 33098 评论 3 赞 238
文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
8 开封第一讲书人 阅读 26096 评论 0 赞 8
文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
8 开封第一讲书人 阅读 26869 评论 0 赞 197
我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
783c64db 45e5 48d7 82e4 95736f50533e 沈念sama 阅读 35748 评论 2 赞 276
正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
388e473c fe2f 40e0 9301 e357ae8f1b41 茶点故事 阅读 35641 评论 2 赞 271
end_time: 2024-04-29 18:36:52 +0800 Completed in 69.581433ms