diff --git a/weixin-java-miniapp/src/main/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeExtConfig.java b/weixin-java-miniapp/src/main/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeExtConfig.java index c7d4de549..13ef6000b 100644 --- a/weixin-java-miniapp/src/main/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeExtConfig.java +++ b/weixin-java-miniapp/src/main/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeExtConfig.java @@ -1,17 +1,17 @@ package cn.binarywang.wx.miniapp.bean.code; -import java.io.Serializable; -import java.util.List; -import java.util.Map; - import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.NoArgsConstructor; +import java.io.Serializable; +import java.util.List; +import java.util.Map; + /** * 上传代码需要用到的第三方自定义的配置 - * 详细文档,参考:https://developers.weixin.qq.com/miniprogram/dev/framework/config.html + * 详细文档,参考:文档 * * @author Charming * @since 2018-04-26 19:44 @@ -75,13 +75,33 @@ public class WxMaCodeExtConfig implements Serializable { */ private TabBar tabBar; + /** + * 关于新增 requiredPrivateInfos 说明 + * 关于地理位置接口新增与相关流程调整可以查看社区公告: + * ... + * 7.14后,在代码中使用的地理位置相关接口(共计 8 个,见表1),第三方开发者均需要在 ext_json 参数中 requiredPrivateInfos 配置项中声明 + * 在ext_json参数中配置requiredPrivateInfos,其规则为「整体替换」。即如果在 app.json 里也配置了,那么最终会是ext_json的配置会覆盖 app.json + * 配置的requiredPrivateInfos。其余规则可查看下方的「ext_json补充说明」 + * 在ext_json参数中配置 requiredPrivateInfos 示例如下 + * { + * "template_id": "95", + * "ext_json": "{\"requiredPrivateInfos\":[\"onLocationChange\",\"startLocationUpdate\"]}", + * "user_version": "V1.0", + * "user_desc": "test" + * } + * requiredPrivateInfos主要会检查格式是否正确,填入的 api 名称是否正确,填入的 api 名称是否有权限,填入的 api 名称是否互斥。对应的错误码可查看文档末尾的错误码文档。 + * requiredPrivateInfos在2022.7.14后才会生效,文档提前更新是为了方便开发者可以提前了解接口的参数变更规则,提前进行调整。 + */ + private String[] requiredPrivateInfos; + /** * page.json 配置,页面配置 - * 文档:https://mp.weixin.qq.com/debug/wxadoc/dev/framework/config.html + * 文档 */ @Data @Builder - public static class PageConfig { + public static class PageConfig implements Serializable { + private static final long serialVersionUID = -8615574764987479723L; /** * 导航栏背景颜色,如"#000000" HexColor. * 默认:#000000 @@ -128,7 +148,9 @@ public class WxMaCodeExtConfig implements Serializable { */ @Data @Builder - public static class TabBar { + public static class TabBar implements Serializable { + private static final long serialVersionUID = -3037016532526129399L; + /** * HexColor, tab 上的文字默认颜色. */ @@ -159,7 +181,8 @@ public class WxMaCodeExtConfig implements Serializable { */ @Data @Builder - public static class Item { + public static class Item implements Serializable { + private static final long serialVersionUID = -5824322265161612460L; /** * 页面路径,必须在 pages 中先定义. */ @@ -184,7 +207,9 @@ public class WxMaCodeExtConfig implements Serializable { */ @Data @Builder - public static class NetworkTimeout { + public static class NetworkTimeout implements Serializable { + private static final long serialVersionUID = -9180176522015880991L; + /** * wx.request的超时时间,单位毫秒,默认为:60000. * 必填:否 diff --git a/weixin-java-miniapp/src/test/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeCommitRequestTest.java b/weixin-java-miniapp/src/test/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeCommitRequestTest.java index 36cf1c484..f31119378 100644 --- a/weixin-java-miniapp/src/test/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeCommitRequestTest.java +++ b/weixin-java-miniapp/src/test/java/cn/binarywang/wx/miniapp/bean/code/WxMaCodeCommitRequestTest.java @@ -1,5 +1,6 @@ package cn.binarywang.wx.miniapp.bean.code; +import com.google.gson.JsonParser; import org.testng.annotations.Test; import static org.testng.Assert.assertEquals; @@ -20,6 +21,28 @@ public class WxMaCodeCommitRequestTest { .extEnable(true) .build()) .build(); - assertEquals(commitRequest.toJson(), "{\"template_id\":1,\"user_version\":\"v0.1.0\",\"user_desc\":\"init\",\"ext_json\":\"{\\\"extEnable\\\":true,\\\"extAppid\\\":\\\"app123\\\"}\"}"); + assertEquals(commitRequest.toJson(), "{\"template_id\":1,\"user_version\":\"v0.1.0\",\"user_desc\":\"init\"," + + "\"ext_json\":\"{\\\"extEnable\\\":true,\\\"extAppid\\\":\\\"app123\\\"}\"}"); + } + + @Test + public void testToJsonWithRequiredPrivateInfos() { + WxMaCodeCommitRequest commitRequest = WxMaCodeCommitRequest.builder() + .templateId(95L) + .userVersion("V1.0") + .userDesc("test") + .extConfig(WxMaCodeExtConfig.builder() + .requiredPrivateInfos(new String[]{ + "onLocationChange", "startLocationUpdate" + }) + .build()) + .build(); + + assertEquals(commitRequest.toJson(), JsonParser.parseString("{\n" + + " \"template_id\": \"95\",\n" + + " \"ext_json\": \"{\\\"requiredPrivateInfos\\\":[\\\"onLocationChange\\\",\\\"startLocationUpdate\\\"]}\",\n" + + " \"user_version\": \"V1.0\",\n" + + " \"user_desc\": \"test\"\n" + + "}").toString()); } } diff --git a/weixin-java-open/src/main/java/me/chanjar/weixin/open/bean/ma/WxMaOpenCommitStandardExt.java b/weixin-java-open/src/main/java/me/chanjar/weixin/open/bean/ma/WxMaOpenCommitStandardExt.java index 73c2356db..a4039fb81 100644 --- a/weixin-java-open/src/main/java/me/chanjar/weixin/open/bean/ma/WxMaOpenCommitStandardExt.java +++ b/weixin-java-open/src/main/java/me/chanjar/weixin/open/bean/ma/WxMaOpenCommitStandardExt.java @@ -8,8 +8,9 @@ import java.util.Map; /** * 微信第三方平台上传代码到小程序代码标准模板时的参数 - * ext_json补充说明 - * 文档地址:https://developers.weixin.qq.com/doc/oplatform/Third-party_Platforms/2.0/api/code/commit.html + *
+ * ext_json 补充说明
+ * 文档
  * 为了便于第三方平台使用同一个小程序模板为不同的小程序提供服务,第三方可以将自定义信息放置在 ext_json 中,在模板小程序中,可以使用 wx.getExtConfigSync 接口获取自定义信息,从而区分不同的小程序。详见:小程序模板开发
  * ext_json 中的参数可选,参数详见小程序配置;但是,如果是模板id为标准模板库的模板id,则ext_json可支持的参数为:{"extAppid":'', "ext": {}, "window": {}}
  * ext_json 中有限支持 pages,支持配置模板页面的子集(ext_json 中不可新增页面)。
@@ -28,7 +29,7 @@ import java.util.Map;
  * subPackages整体替换
  * navigateToMiniProgaramAppIdList:整体替换
  * plugins整体替换
- * 

+ *
* * @author 广州跨界 * @since 2021/08/12