• Java 获取小程序openid(基于SpringBoot)


    Java 获取小程序openid(基于SpringBoot)

    官方文档 wx.login

    1.引入Request封装依赖

    <!--Request依赖-->
    <dependency>
       <groupId>com.github.kevinsawicki</groupId>
       <artifactId>http-request</artifactId>
       <version>6.0</version>
    </dependency>
    

    2.封装请求

    可以在开发者后台获取AppIdAppSecret

    WxMiniConfig

    public class WxMiniConfig {
        public static String AppId = "";
        public static String AppSecret="";
    }
    
    

    构建接口请求

    WxOpenData

    
    import com.github.kevinsawicki.http.HttpRequest;
    
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RequestParam;
    import org.springframework.web.bind.annotation.RestController;
    
    import java.util.HashMap;
    import java.util.Map;
    @RestController
    public class WxOpenData {
        @RequestMapping(value = "/WxOpenData")
        public String getWxOpenData(@RequestParam(value = "js_code",required = true) String js_code){
            Map<String, String> data = new HashMap<String, String>();
            data.put("appid", WxMiniConfig.AppId);
            data.put("secret", WxMiniConfig.AppSecret);
            data.put("js_code", js_code);
            data.put("grant_type", "authorization_code");
    
            String response = HttpRequest.get("https://api.weixin.qq.com/sns/jscode2session").form(data).body();
    
            //JSONObject obj= JSON.parseObject(response);//将json字符串转换为json对
            return response.toString();
        }
    
    }
    
    

    3.小程序端请求写法

    wx.login({
        success: res => {
            wx.request({
              url: 服务地址 + '/WxOpenData',
              data: {
                js_code: res.code
              },
              success: _res => {
                  console.log(_res);//打印返回的openid 等信息 ,可以JSON.parse()提取
              },
              fail: _res => {
    
              }
            })
          }
    })
    

    4. SSL证书校验问题

    sun.security.provider.certpath.SunCertPathBuilderException

    Protocol handler initialization failed

    可以自己下载SSL证书Tomcat版,配置到Resource目录下。

    application.properties配置证书部分内容如下所示

    #server.ssl.key-store=classpath:atlab.pfx
    server.ssl.key-store=classpath:coms.pfx
    #证书密码,请修改为您自己证书的密码.
    server.ssl.key-store-password=ARU3dlCp
    #秘钥库类型
    #server.ssl.key-store-type:PKCS12
    server.ssl.key-store-type=JKS
    

    之后重启后多请求几次即可恢复正常服务。

    参考文档

    https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/login/auth.code2Session.html

  • 相关阅读:
    ubuntu下手动安装autoconf
    解决VMware下的ubuntu桌面鼠标键盘失效的问题
    DP搬运工1
    把数字转换成货币格式
    指定字符隐藏
    JS 时间获取 (常用)
    electron 安装
    el-form表单校验包含循环
    算法-07| 动态规划
    纯手撸——归并排序
  • 原文地址:https://www.cnblogs.com/masterchd/p/14213349.html
Copyright © 2020-2023  润新知