APP接入微信支付的详情步骤

本文详细介绍如何在Android应用中集成微信支付功能,包括添加依赖、创建支付入口Activity、配置清单文件、实现支付逻辑及调用支付接口等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.在build.gradle文件中加入如下依赖

    //微信支付
    implementation 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:5.4.3'

2.在当前包名下新建一个wxapi的包,新建一个 WXPayEntryActivity 

public class WXPayEntryActivity extends AppCompatActivity implements IWXAPIEventHandler {
    private IWXAPI api;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        api = WXAPIFactory.createWXAPI(this, "输入你的AppID");
        api.handleIntent(getIntent(), this);
    }

    @Override
    protected void onNewIntent(Intent intent) {
        super.onNewIntent(intent);
        setIntent(intent);
        api.handleIntent(intent, this);
    }

    @Override
    public void onReq(BaseReq req) {
    }

    @Override
    public void onResp(BaseResp resp) {
        if (resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {
            switch (resp.errCode) {
                case 0://成功
                    Toast.makeText(this, getString(R.string.pay_success), Toast.LENGTH_SHORT).show();
                    EventBus.getDefault().post(Constants.WECHAT_PAY_SUCCESS);
                    break;
                case -1://错误
                    Toast.makeText(this, getString(R.string.pay_failed), Toast.LENGTH_SHORT).show();
                    EventBus.getDefault().post(Constants.WECHAT_PAY_FAILED);
                    break;
                case -2://用户取消
                    Toast.makeText(this, getString(R.string.pay_cancel), Toast.LENGTH_SHORT).show();
                    EventBus.getDefault().post(Constants.WECHAT_PAY_CANCEL);
                    break;
                default:
                    break;
            }
            finish();
        }
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        api.detach();
    }
}

3.清单文件配置activity

<activity android:name="你的包名.wxapi.WXPayEntryActivity"
            android:exported="true"
            android:launchMode="singleTop"
            android:screenOrientation="portrait"/>

4.在当前包名下新建一个wxpay的包,新建一个WXPay的类

/**
 * 调起微信支付
 *
 * @author Administrator
 */
public class WXPay {

    private static IWXAPI msgApi;

    private static void registerApp(Context context, String appid) {
        msgApi = WXAPIFactory.createWXAPI(context, appid);
        msgApi.registerApp(appid);
    }


    /**
     * 自定义方法开始传入参数调起微信
     * @param context context
     * @param appid 你的AppID
     * @param prepay 通过服务端返回的数据解析的WXPayInfo类
     */
    public static void pay(Context context, String appid, WXPayInfo prepay) {
        if (msgApi == null) {
            registerApp(context, appid);
        }
        if (!msgApi.isWXAppInstalled()) {
            Toast.makeText(context, R.string.uninstall_wechat, Toast.LENGTH_LONG).show();
            return;
        }
        PayReq request = new PayReq();
        if (prepay != null) {
            request.appId = appid;
            request.partnerId = prepay.getPartnerid();
            request.prepayId = prepay.getPrepayid();
            request.packageValue = Constants.WEIXIN_PACKAGE_VALUE;
            request.nonceStr = prepay.getNoncestr();
            request.timeStamp = "" + prepay.getTimestamp();
            request.sign = prepay.getSign();
            msgApi.sendReq(request);
        } else {
            Toast.makeText(context, R.string.params_null, Toast.LENGTH_LONG).show();
        }
    }
}

5.最后开始调用

WXPay.pay(this, "你的AppID", "服务端返回的json解析以后的bean");

 

### Java 应用程序接入微信支付 API 教程 #### 依赖引入 为了使Java应用程序能够顺利调用微信支付接口,需先在项目中加入必要的依赖项。具体来说,应添加如下所示的Maven配置来引入微信支付SDK: ```xml <!-- 微信支付 SDK --> <dependency> <groupId>com.github.wxpay</groupId> <artifactId>wxpay-sdk</artifactId> <version>0.0.3</version> </dependency> ``` 此操作确保了后续开发过程中可以方便地利用该库所提供的各类方法和服务[^1]。 #### 工具类支持 对于希望提高集成效率并简化代码编写的开发者而言,可考虑采用专门设计用于辅助Java环境下的微信支付集成工作的一个工具类。这类工具不仅适用于电商平台建设者也适合其他涉及在线付款业务的应用场景,能有效减少重复劳动并加快部署速度[^2]。 #### App 支付流程概述 当涉及到移动客户端内的购买行为时,则会运用到所谓的“App支付”。这种模式下,用户的整个购物流程始于商家自有软件内部;之后经由特定链接转向至微信客户端完成实际的资金转移过程;最后再返回原点继续未竟之事。这期间包含了多个环节的数据交互以及状态同步机制的设计与实现[^3]。 #### 实现步骤详解 虽然上述部分已经提及了一些基础概念和技术准备事项,但对于完整的接入流程描述仍不可或缺。以下是更为具体的指导建议: - **初始化配置**:创建`WxPayConfig`实例对象,并设置好相应的参数如商户号、密钥等基本信息。 - **统一下单请求构建**:依据官方文档说明组装下单所需字段信息,注意区分不同类型的订单(例如商品详情、金额等),并通过HTTP POST方式提交给指定URL地址获取预支付交易会话标识(`prepay_id`)。 - **签名算法处理**:按照规定格式计算待发送数据包中的数字摘要值作为验证凭证之一,在这里推荐使用MD5或HMAC-SHA256两种加密哈希函数任选其一执行此项任务。 - **前端页面适配**:针对Web端应用场景,需要编写一段JavaScript脚本负责接收来自后台传递过来的结果集进而触发唤起微信内置浏览器插件的动作;而对于移动端则直接嵌入相应组件即可达成相同效果。 - **回调通知监听器设立**:考虑到网络延迟或者其他不可预见因素可能导致最终确认消息未能及时送达的情况发生,因此有必要预先安排一套完善的异常捕获及重试策略以保障资金流转的安全性和准确性。 以上便是关于如何借助于Java语言特性顺利完成一次标准意义上的微信支付服务对接工作的全部要点介绍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值