关于springboot:Springboot216集成-activiti7-出现登录验证

6次阅读

共计 4546 个字符,预计需要花费 12 分钟才能阅读完成。

一、问题

Spring2.1.5 集成 activiti7.1.24 时拜访要输出用户名和明码。


    @Autowired
    private ProcessRuntime processRuntime;
    
/**
     * 启动工作
     */
    @Test
    void startProcess(){
        /**
         * 流程变量
         *   给 <userTask id="销假申请" name="销假申请" activiti:assignee="#{student}"></userTask>
         *     的 student 赋值
         */

        HashMap<String, Object> variables = new HashMap<>();

        // String username = SecurityUtils.getNickName();
        String username = "小王";
        variables.put("staff", username);

        ProcessInstance processInstance = processRuntime.start(ProcessPayloadBuilder
                .start()
                .withProcessDefinitionKey("baoxiao")
                .withName("报销测试")
                //.withBusinessKey(id)
                // .withVariable("deptLeader", join)
                .withVariables(variables)
                .build());

        System.out.println(processInstance.getId());
    }

在单元测试中测试 Activiti 框架,呈现如下的异样:

org.springframework.security.authentication.AuthenticationCredentialsNotFoundException: An Authentication object was not found in the SecurityContext

    at org.springframework.security.access.intercept.AbstractSecurityInterceptor.credentialsNotFound(AbstractSecurityInterceptor.java:379)
    at org.springframework.security.access.intercept.AbstractSecurityInterceptor.beforeInvocation(AbstractSecurityInterceptor.java:223)
    at org.springframework.security.access.intercept.aopalliance.MethodSecurityInterceptor.invoke(MethodSecurityInterceptor.java:65)
    ...
    at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:33)
    at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:220)
    at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:53)

其余的形式大家如果试过胜利就能够了,如果不行,可试下这个:勾销登录验证如下:

@SpringBootApplication(
        exclude = {
                org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class,
                org.springframework.boot.actuate.autoconfigure.security.servlet.ManagementWebSecurityAutoConfiguration.class
        }
)

这是我在他人那找来的,困了我好长时间,晓得看到这个货色。

二、新版验证

其实这个都很简略,然而我看了不少博客下的评论都说依照这个形式剔除了,然而还是不行

An Authentication object was not found in the SecurityContext

当咱们自信的对着接口发动申请的时候,报了浏览器呈现了 500,控制台报出下面的异样,中文意思:在 SecurityContext 中没有找到身份验证对象

why? 我明明曾经剔除了啊,为什么还是要验证身份?

到底是哪里出了问题?想不明确!

如果上下面的问题,你只须要应用,老的 API 即可,因为新封装的 API 应用 SpringSecurity, 所以须要身份验证

留神:以下均是集体了解,如有谬误,还请斧正

其实,当咱们应用 Activiti7 的时候,要晓得 Activit7 的开发团队,不在是之前 Tom Baeyens 的团队负责开发,也就是上面这个哥们。

Activiti7 中,从新封装了一些新的 API,比方 ProcessRuntime 和 TaskRuntime

既然是新封装的,那肯定和老的 API 会有所区别,那具体区别在哪里呢?

咱们能够间接查看这两个接口外面的内容,去一探到底!

    @Autowired
    private ProcessRuntime processRuntime;

我这里拿 ProcessRuntime 举例,咱们能够间接查看下,找到实现的类

或者间接应用快捷键 CTRL + H,找出实现的类

进入实现类中:

进入实现类中,咱们能够看到类下面应用:

@PreAuthorize("hasRole('ACTIVITI_USER')")

这个是什么?

SpringSecurity 用来在办法调用前或者调用后进行权限查看

说到这里,您应该明确了吧!因为 Activiti7 中封装进去的新接口,都加了这个注解,所以当咱们即便照着最开始的办法剔除了,依然还会呈现身份认证问题!

那为什么咱们调用老的接口,却不须要身份验证呢,其实不必开源码就能够推出,老的接口上并没有增加该注解

咱们能够看看老的接口 RuntimeService 的实现类:

    @Autowired
    private RuntimeService runtimeService;

所以,咱们能够应用 RuntimeService 来代替 ProcessRuntime 启动实例。

单元测试实例:

package com.example.demo;

import com.ruoyi.RuoYiApplication;
import org.activiti.engine.RuntimeService;
import org.activiti.engine.runtime.ProcessInstance;
import org.junit.jupiter.api.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.HashMap;

@RunWith(SpringRunner.class)

@SpringBootTest(classes = RuoYiApplication.class)
public class DemoApplicationTests {

    // Activiti7 新接口因为内置 SpringSecurity,在运行时会报错
    // @Autowired
    // private ProcessRuntime processRuntime;

    // 老的接口办法,未内置 SpringSecurity
    @Autowired
    private RuntimeService runtimeService;

    @Test
    void contextLoads() {System.out.println("hello world");
    }

    /**
     * 在应用 SpringBoot + Activiti 时,启动服务拜访模块时,浏览器会弹出一个登录界面。*
     * 这是因为 Activiti 框架整合了 SpringSecurity 框架,如果咱们不须要平安验证时能够禁用 springsecurity。*
     *
     * @SpringBootApplication(
     *         exclude = {
     *                 org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class,
     *                 org.springframework.boot.actuate.autoconfigure.security.servlet.ManagementWebSecurityAutoConfiguration.class
     *         })
     */
    /**
     * 启动工作
     */
    @Test
    void startProcess(){
        /**
         * 流程变量
         *   给 <userTask id="销假申请" name="销假申请" activiti:assignee="#{student}"></userTask>
         *     的 student 赋值
         */

        HashMap<String, Object> variables = new HashMap<>();

        // String username = SecurityUtils.getNickName();
        String username = "小王";
        variables.put("staff", username);


        /*
        ProcessInstance processInstance = processRuntime.start(ProcessPayloadBuilder
                .start()
                .withProcessDefinitionKey("baoxiao")
                .withName("报销测试")
                //.withBusinessKey(id)
                // .withVariable("deptLeader", join)
                .withVariables(variables)
                .build());
         */

        ProcessInstance processInstance = runtimeService.startProcessInstanceByKey("baoxiao", variables);
        System.out.println("流程实例启动:");
        System.out.println(processInstance.getId());
    }

}

后果打印:

 流程实例启动:b0af0810-4801-11eb-b1ac-005056c00001

能够看到应用老接口,就能够胜利执行了。


相干文章:
SpringBoot2.x 整合 Activiti7 后,禁用 SpringBootSecurity 问题

正文完
 0