Android app跳转微信小程序,返回app遇到的各种坑

本文解决Android应用调起微信小程序并返回APP的常见问题,包括正确配置AppId、AndroidManifest.xml、WXEntryActivity及其实现IWXAPIEventHandler接口,确保onResp内finish避免透明界面,最后在onCreate中处理返回值。

Android app跳转微信小程序,返回app遇到的各种坑

在此,吐槽下微信官方文档写的太口吐芬芳了,开发如题的功能时候,一看微信官网文档app拉起小程序,发现如此简单,短短的几行代码就可以,如果你和我一样,按照官方文档,会发现我们还是太年轻,代码一模一样,但是没有效果。下面开始填坑之路:

填坑1:AppId

在这里插入图片描述
这里的AppId是Android应用的appid,不是小程序的AppId

填坑2:AndroidManifest.xml的配置

在AndroidManifest.xml的WXEntryActivity中加入如下属性:

    android:taskAffinity="your packagename"
    android:launchMode="singleTask" 

这里如果不加的话,小程序无法跳转回APP

填坑3:WXEntryActivity实现IWXAPIEventHandler接口

public class WXEntryActivity extends Activity implements IWXAPIEventHandler

填坑4:在onResp里面finish,不然WXEntryActivity是透明的,导致app无法操作

 public void onResp(BaseResp resp) {
        if (resp.getType() == ConstantsAPI.COMMAND_LAUNCH_WX_MINIPROGRAM) {
            WXLaunchMiniProgram.Resp launchMiniProResp = (WXLaunchMiniProgram.Resp) resp;
            String extraData = launchMiniProResp.extMsg; //对应小程序组件 <button open-type="launchApp"> 中的 app-parameter 属性
            LogUtils.i("小程序==" + extraData);
            finish();
        }
    }

填坑5:在onCreate处理返回值

// IWXAPI 是第三方app和微信通信的openapi接口
    private IWXAPI api;

    @Override
    protected void onCreate(Bundle bundle) {
        super.onCreate(bundle);
        // 通过WXAPIFactory工厂,获取IWXAPI的实例
        api = WXAPIFactory.createWXAPI(this, Constants.APP_ID, false);
        //注意:
        //第三方开发者如果使用透明界面来实现WXEntryActivity,需要判断handleIntent的返回值,如果返回值为false,则说明入参不合法未被SDK处理,应finish当前透明界面,避免外部通过传递非法参数的Intent导致停留在透明界面,引起用户的疑惑
        try {
            if (!api.handleIntent(getIntent(), this)) {
                finish();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

至此,app调起微信小程序,返回app一切正常了,大功告成。

要实现 Android App 跳转微信小程序并在操作后返回 App 的功能,需要通过微信开放平台提供的 SDK 和相关接口完成。以下是详细的实现方法: ### 配置微信开放平台 1. 首先,需要登录微信开放平台,创建一个移动应用,然后系统会返回一个 AppID。这个 AppID 是用于微信登录、分享、跳转小程序等操作的必要凭证,而非小程序AppID [^1]。 ### 集成微信 SDK 2. 在 Android 项目中集成微信 SDK,可以通过 Gradle 引入依赖或手动添加 SDK 文件。确保按照官方文档正确配置 。 ### 调用跳转微信小程序接口 3. 在 Android App 中调用微信 SDK 提供的 `WXLaunchMiniProgram.Req` 接口来跳转微信小程序。需要提供目标小程序的原始 ID 和路径(可带参数),同时指定小程序的版本类型(开发版、体验版或正式版) 。 ```java String appId = "wxd930ea5d5a258f4f"; // 填写移动应用的 AppID IWXAPI api = WXAPIFactory.createWXAPI(context, appId); WXLaunchMiniProgram.Req req = new WXLaunchMiniProgram.Req(); req.userName = "gh_d43f693ca31f"; // 填写目标小程序的原始 ID req.path = "pages/index/index?query=1"; // 拉起小程序页面的可带参路径 req.miniprogramType = WXLaunchMiniProgram.Req.MINIPTOGRAM_TYPE_RELEASE; // 打开正式版 api.sendReq(req); ``` ### 接收从小程序返回的数据 4. 在 Android App 中接收从小程序返回的数据,需要在 `WXEntryActivity` 中重写 `onResp` 方法,并解析返回的数据。通过 `extMsg` 字段可以获取小程序传递的参数 [^3]。 ```java public void onResp(BaseResp resp) { if (resp.getType() == ConstantsAPI.COMMAND_LAUNCH_WX_MINIPROGRAM) { WXLaunchMiniProgram.Resp launchMiniProResp = (WXLaunchMiniProgram.Resp) resp; String extraData = launchMiniProResp.extMsg; // 小程序传递的参数 // 处理返回的数据 } } ``` ### 注意事项 5. 确保 Android App 的包名和签名与微信开放平台中配置的一致,否则跳转可能会失败 [^1]。 6. 如果需要从小程序返回数据到 App,可以在小程序端使用 `<button open-type="launchApp">` 组件,并设置 `app-parameter` 属性传递参数 [^3]。 ### 示例代码 7. 以下是一个完整的示例代码,展示如何从 Android App 跳转微信小程序并接收返回的数据: ```java // 跳转微信小程序 String appId = "wxd930ea5d5a258f4f"; // 填写移动应用的 AppID IWXAPI api = WXAPIFactory.createWXAPI(context, appId); WXLaunchMiniProgram.Req req = new WXLaunchMiniProgram.Req(); req.userName = "gh_d43f693ca31f"; // 填写目标小程序的原始 ID req.path = "pages/index/index?query=1"; // 拉起小程序页面的可带参路径 req.miniprogramType = WXLaunchMiniProgram.Req.MINIPTOGRAM_TYPE_RELEASE; // 打开正式版 api.sendReq(req); // 接收返回的数据 public void onResp(BaseResp resp) { if (resp.getType() == ConstantsAPI.COMMAND_LAUNCH_WX_MINIPROGRAM) { WXLaunchMiniProgram.Resp launchMiniProResp = (WXLaunchMiniProgram.Resp) resp; String extraData = launchMiniProResp.extMsg; // 小程序传递的参数 // 处理返回的数据 } } ``` 通过以上步骤,Android App 可以成功跳转微信小程序,并在操作后返回 App,同时接收小程序传递的参数 [^1]。
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值