springboot项目实战之获取微信JSDK签名信息

目标

现实项目的需要,需要获取微信jssdk签名信息

步骤

  1. 初始化配置信息

    public Map initJSSDKConfigInfo(String shareUrl) throws Exception {
    //String accessToken = this.getAccessToken();
    String jsapiTicket = this.getJsApiTicket();
    String timestamp = Long.toString(System.currentTimeMillis() / 1000);
    String nonceStr = UUID.randomUUID().toString();
    String signature = this.buildJSSDKSignature(jsapiTicket,timestamp,nonceStr,shareUrl);

    复制代码
         Map<String,String> map = new HashMap<String,String>();
         map.put("shareUrl", shareUrl);
         map.put("jsapi_ticket", jsapiTicket);
         map.put("nonceStr", nonceStr);
         map.put("timestamp", timestamp);
         map.put("signature", signature);
         map.put("appid", WeChatConfig.appId);
         return map;
     }
  2. ticket信息获取

    private String getJsApiTicket() {
    String jsApiTicket =redisCache.getCacheObject(JS_API_TICKET);
    if (!StrUtil.isNotEmpty(jsApiTicket)){
    //获取全局的access_token,唯一票据
    String accessToken = redisCache.getCacheObject(ACCESS_TOKEN_KEY);
    //log.info("getJsApiTicket"+accessToken);
    if (StringUtils.isNotBlank(accessToken)) {
    //获取jsapi_ticket
    String url = WeChatConfig.getTicketUrl+"access_token="+accessToken+"&type=jsapi";
    HttpHeaders headers = new HttpHeaders();
    headers.setContentType(MediaType.APPLICATION_JSON);
    //请求
    RestTemplate restTemplate = new RestTemplate();
    HttpEntity request = new HttpEntity<>(headers);
    ResponseEntity responseString = restTemplate.postForEntity(url, request, String.class);
    JSONObject json = JSONObject.parseObject(responseString.getBody());
    jsApiTicket = json.getString("ticket");
    redisCache.setCacheObject(JS_API_TICKET, jsApiTicket, 115, TimeUnit.MINUTES);
    }else {
    //access为空打印
    log.info("accessToken","重新获取");
    this.creatAccessToken();
    accessToken = redisCache.getCacheObject(ACCESS_TOKEN_KEY);
    String url = WeChatConfig.getTicketUrl+"access_token="+accessToken+"&type=jsapi";
    HttpHeaders headers = new HttpHeaders();
    headers.setContentType(MediaType.APPLICATION_JSON);
    //请求
    RestTemplate restTemplate = new RestTemplate();
    HttpEntity request = new HttpEntity<>(headers);
    ResponseEntity responseString = restTemplate.postForEntity(url, request, String.class);
    JSONObject json = JSONObject.parseObject(responseString.getBody());
    jsApiTicket = json.getString("ticket");
    redisCache.setCacheObject(JS_API_TICKET, jsApiTicket, 115, TimeUnit.MINUTES);

    复制代码
             }
         }
         log.info("getJsApiTicket jsApiTicket: {}", jsApiTicket);
         return jsApiTicket.trim();
     }
  3. 信息处理封装

    public static String buildJSSDKSignature(String ticket,String timestamp,String nonceStr ,String url) throws Exception {

    复制代码
         String orderedString = "jsapi_ticket=" + ticket
                 + "&noncestr=" + nonceStr + "&timestamp=" + timestamp
                 + "&url=" + url;
         return sha1(orderedString);
     }
     public static String sha1(String orderedString) throws Exception {
         String ciphertext = null;
         MessageDigest md = MessageDigest.getInstance("SHA-1");
         byte[] digest = md.digest(orderedString.getBytes());
         ciphertext = byteToStr(digest);
         return ciphertext.toLowerCase();
     }
     private static String byteToStr(byte[] byteArray) {
         String strDigest = "";
         for (int i = 0; i < byteArray.length; i++) {
             strDigest += byteToHexStr(byteArray[i]);
         }
         return strDigest;
     }
     private static String byteToHexStr(byte mByte) {
         char[] Digit = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
         char[] tempArr = new char[2];
         tempArr[0] = Digit[(mByte >>> 4) & 0X0F];
         tempArr[1] = Digit[mByte & 0X0F];
    
         String s = new String(tempArr);
         return s;
     }

欢迎点赞,转发,留言,批评

相关推荐
像我这样帅的人丶你还20 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩20 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia21 小时前
Mybatis的日志输入
java
亦暖筑序1 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao1 天前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试
鹤望兰6751 天前
字节跳动国际支付-后端开发-三面面经
java
Flittly1 天前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring
RainCity1 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端