xxljob在业务代码中添加任务(登录后token验证)

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 之前做过一次在业务代码中调用xxljob的接口添加任务启动任务,xxljob的接口添加免登录验证注解后直接调用,博文地址:xxl-job 在业务代码中添加任务,后面用到的groupId获取方法也在这里面。

之前做过一次在业务代码中调用xxljob的接口添加任务启动任务,xxljob的接口添加免登录验证注解后直接调用,博文地址:xxl-job 在业务代码中添加任务,后面用到的groupId获取方法也在这里面。


这次再这样操作的时候,加了免登录验证注解还是会验证token,第一次拦截器里面确实过了,但不知道为什么还会走第二遍拦截器,这次又会验证token。又试了一下在配置拦截器拦截路径的时候把自己复制出来的接口配置不拦截,但是也没有成功。


所以只能登录之后再携带token调接口了


http请求工具还是使用的forest,官网地址:forest官网


代码如下


package com.gt.gxjhpt.controller;
import cn.hutool.core.util.IdUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.dtflys.forest.http.ForestCookie;
import com.gt.gxjhpt.entity.bo.XxlJobInfo;
import com.gt.gxjhpt.enumeration.RedisKeyEnum;
import com.gt.gxjhpt.http.XxlJobHttp;
import com.gt.gxjhpt.utils.RedisUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.atomic.AtomicReference;
/**
 * @author vhukze
 * @date 2022/3/28 16:24
 */
@RestController
@RequestMapping("demo")
public class DemoController {
    @Resource
    private XxlJobHttp xxlJobHttp;
    @Resource
    private RedisUtil redisUtil;
    @Value("${xxl.job.groupId}")
    private Integer groupId;
    @Value("${xxl.job.userName}")
    private String userName;
    @Value("${xxl.job.password}")
    private String password;
    @GetMapping(value = "addJob", produces = MediaType.APPLICATION_JSON_VALUE)
    public String addJob() {
        XxlJobInfo jobInfo = new XxlJobInfo();
        jobInfo.setJobCron("0 0 0 1 * ? *");
        jobInfo.setGlueType("BEAN");
        jobInfo.setJobGroup(groupId);
        jobInfo.setExecutorHandler("testJob");
        jobInfo.setAuthor("vhukze");
        jobInfo.setJobDesc("描述");
        // 路由策略 第一个
        jobInfo.setExecutorRouteStrategy("FIRST");
        // 阻塞处理策略 单机串行
        jobInfo.setExecutorBlockStrategy("SERIAL_EXECUTION");
        // 执行参数
        JSONObject jsonParam = new JSONObject();
        jsonParam.set("redisKey", "vhukze");
        jobInfo.setExecutorParam(jsonParam.toString());
        // 任务超时时间
        jobInfo.setExecutorTimeout(10);
        // 失败重试次数
        jobInfo.setExecutorFailRetryCount(5);
        String result = xxlJobHttp.addJob(jobInfo, (request, cookies) -> {
            // 将之前调用登入接口获得的Cookie传入请求发送到服务端
            cookies.addCookie(this.getXxlToken());
        });
        return JSONUtil.parseObj(result).get("content").toString();
//        xxlJobHttp.startJob(xxlJobAddresses, JSONUtil.parseObj(result).get("content").toString());
    }
    @GetMapping(value = "startJob", produces = MediaType.APPLICATION_JSON_VALUE)
    public String startJob(String id) {
        Map<String, Object> map = new HashMap<>(2, 1);
        map.put("id", id);
        // 执行任务参数
        String runId = IdUtil.objectId();
        JSONObject jsonObject = new JSONObject();
        jsonObject.set("redisKey", runId);
        map.put("executorParam", jsonObject.toString());
        String result = xxlJobHttp.triggerJob(map, (request, cookies) -> {
            // 将之前调用登入接口获得的Cookie传入请求发送到服务端
            cookies.addCookie(this.getXxlToken());
        });
        if (!"200".equals(JSONUtil.parseObj(result).get("code").toString())) {
            return null;
        }
        return runId;
    }
    private ForestCookie getXxlToken() {
        Object token = redisUtil.get(RedisKeyEnum.XXL_TOKEN.getKey());
        if (token != null) {
            return (ForestCookie) token;
        }
        AtomicReference<ForestCookie> cookieAtomic = new AtomicReference<>(null);
        xxlJobHttp.login(new HashMap<String, Object>() {{
            this.put("userName", userName);
            this.put("password", password);
        }}, (request, cookies) -> {
            // 将服务端传来的Cookie放入cookieAtomic
            cookieAtomic.set(cookies.allCookies().get(0));
        });
        redisUtil.set(RedisKeyEnum.XXL_TOKEN.getKey(), cookieAtomic.get());
        return cookieAtomic.get();
    }
}


http请求接口,#{}参数是在配置文件配置的,forest支持读取配置文件

package com.gt.gxjhpt.http;
import com.dtflys.forest.annotation.*;
import com.dtflys.forest.callback.OnLoadCookie;
import com.dtflys.forest.callback.OnSaveCookie;
import com.dtflys.forest.http.ForestCookie;
import com.gt.gxjhpt.entity.bo.XxlJobInfo;
import com.gt.gxjhpt.enumeration.RedisKeyEnum;
import com.gt.gxjhpt.utils.RedisUtil;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.atomic.AtomicReference;
/**
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1月前
|
微服务
jeecg微服务项目调用接口报错Token验证失效的解决方法
jeecg微服务项目调用接口报错Token验证失效的解决方法
31 0
|
1月前
|
存储 NoSQL 前端开发
【SpringBoot】Redis集中管理Session和自定义用户参数解决登录状态及校验问题
【SpringBoot】Redis集中管理Session和自定义用户参数解决登录状态及校验问题
|
3月前
|
SQL 数据安全/隐私保护
带token的多用户登录(注册直接粗暴解决)
带token的多用户登录(注册直接粗暴解决)
带token的多用户登录(注册直接粗暴解决)
|
3月前
|
SQL 安全 前端开发
Security登录认证流程分析
Security登录认证流程分析
35 5
|
9月前
|
安全 Java 数据库连接
四.SpringSecurity基础-自定义登录流程
SpringSecurity基础-自定义登录流程
|
4月前
|
存储 缓存 NoSQL
【视频+源码】登录鉴权的三种方式:token、jwt、session实战分享
【视频+源码】登录鉴权的三种方式:token、jwt、session实战分享
|
5月前
|
存储 中间件 API
fastadmin框架token验证
fastadmin框架token验证
108 0
|
10月前
|
存储 缓存 SpringCloudAlibaba
SpringCloud Alibaba微服务实战三十五 - 退出登录注销 jwt token
SpringCloud Alibaba微服务实战三十五 - 退出登录注销 jwt token
766 0
|
安全 Java 数据安全/隐私保护
OAuth2.0实战!玩转认证、资源服务异常自定义这些骚操作!
OAuth2.0实战!玩转认证、资源服务异常自定义这些骚操作!

热门文章

最新文章