Springboot对接企业微信,获取access_tokenjsapi_ticket,实现全局缓存,Sha1加密

本文主要是介绍Springboot对接企业微信,获取access_tokenjsapi_ticket,实现全局缓存,Sha1加密,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

不善言辞,看得懂就看吧!!!

一、编写配置yml文件

elink: agentid: xxxxxcorpid: xxxxxcorpsecret: XXXXXXXXXXXXXXelinkUrl: 127.0.0.1

二、获取access_token&jsapi_ticket写入Redis内存中

通过定时任务实现官网要求的7200秒缓存机制

access_token

@Component
@EnableScheduling
@Slf4j
public class ElinkTokenScheduler{@Value("${elink.corpid}")private String corpid;@Value("${elink.corpsecret}")private String corpsecret;@Value("${elink.elinkUrl}")private String elinkUrl;@Resourceprivate RedisTokenHelper redisTokenHelper;/*** 定时获取access_token* @throws SQLException */@Scheduled(fixedDelay=7180000)public void getAccessToken() throws SQLException{String accessToken = null;String jsapiTicket = null;StringBuilder urlToken = new StirngBuilder("http://"+elinkUrl+"/cgi-bin/gettoken?");urlToken.append("corpid="+corpid); urlToken.append("&corpsecret="+corpsecret);try {  //获取access_tokenHttpClient client = HttpClientBuilder.create().build();//构建ClientHttpGet getToken = new HttpGet(urlToken.toString());//构建GET请求HttpResponse response = client.execute(getToken);//提交GET请求HttpEntity result = response.getEntity();String tokenMessage = EntityUtils.toString(result);JSONObject tokenJson = JSONObject.parseObject(tokenMessage);accessToken = tokenJson.getString("access_token");//获取jsapi_ticketStringBuilder urlTicket = new StringBuilder("http://"+elinkUrl+"/cgi-bin/get_jsapi_ticket?");urlTicket.append("access_token="+accessToken);HttpGet getTicket = new HttpGet(urlTicket.toString());//构建GET请求response = client.execute(getTicket);//提交GET请求result = response.getEntity();String ticketMessage = EntityUtils.toString(result);JSONObject ticketJson = JSONObject.parseObject(ticketMessage);jsapiTicket = tokenJson.getString("ticket");} catch (Exception e) {  e.printStackTrace();  }logger.info("==============开始写入access_token&jsapi_ticket===============");redisTokenHelper.saveObject("access_token", accessToken);redisTokenHelper.saveObject("jsapi_ticket", jsapiTicket);logger.info("==============写入access_token&jsapi_ticket成功===============");}}

 三、redis工具类

import java.util.concurrent.TimeUnit;import javax.annotation.Resource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.stereotype.Repository;/*** 封装Redis存取Token对的工具类* @author spd**/@Repositorypublic class RedisTokenHelper {@AutowiredStringRedisTemplate stringRedisTemplate;@AutowiredRedisTemplate<Object, Object> redisTemplate;@Resource(name="stringRedisTemplate")ValueOperations<String, String> ops;@Resource(name="redisTemplate")ValueOperations<Object, Object> objOps;/*** 键值对存储 字符串 :有效时间3分钟* @param tokenType Token的key* @param Token Token的值*/public void save(String tokenType,String Token){ops.set(tokenType, Token, 180, TimeUnit.SECONDS);}/*** 根据key从redis获取value * @param tokenType* @return String*/public String getToken(String tokenType){return ops.get(tokenType);}/*** redis 存储一个对象* @param key* @param obj* @param timeout 过期时间  单位:s*/public void saveObject(String key,Object obj,long timeout){objOps.set(key, obj,timeout,TimeUnit.SECONDS);}/*** redis 存储一个对象  ,不过期* @param key* @param obj*/public void saveObject(String key,Object obj){objOps.set(key, obj);}/*** 从redis取出一个对象* @param key* @param obj*/public Object getObject(String key){return objOps.get(key);}/*** 根据Key删除Object* @param key*/public void removeObject(String key){redisTemplate.delete(key);}}

四、Sha1的加密方式

public static String SHA1(String decript) {try {MessageDigest digest = java.security.MessageDigest.getInstance("SHA-1");digest.update(decript.getBytes());byte messageDigest[] = digest.digest();// Create Hex StringStringBuffer hexString = new StringBuffer();// 字节数组转换为 十六进制 数for (int i = 0; i < messageDigest.length; i++) {String shaHex = Integer.toHexString(messageDigest[i] & 0xFF);if (shaHex.length() < 2) {hexString.append(0);}hexString.append(shaHex);}return hexString.toString();} catch (NoSuchAlgorithmException e) {e.printStackTrace();}return "";
}

 

五、JUnit测试获取数据

 

    import org.apache.log4j.Logger;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.boot.test.SpringApplicationConfiguration;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import org.springframework.test.context.web.WebAppConfiguration;import org.springframework.transaction.annotation.Transactional;import com.bjb.Application;import com.bjb.dao.impl.RedisTokenHelper;/*** Junit单元测试类* @author spd**/@RunWith(SpringJUnit4ClassRunner.class)@SpringApplicationConfiguration(classes=Application.class)@WebAppConfiguration@Transactionalpublic class JUnitTest {private final Logger logger = Logger.getRootLogger();@Resourceprivate RedisTokenHelper redisTokenHelper;@Testpublic void test(){String access_token = (String) redisTokenHelper.getObject("access_token");System.out.println("access_token:"+access_token);}}

 

 

 

这篇关于Springboot对接企业微信,获取access_tokenjsapi_ticket,实现全局缓存,Sha1加密的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/643484

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory