久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

Springboot2.1.6集成activiti7出現(xiàn)登錄驗證的實現(xiàn)

瀏覽:4日期:2023-04-01 10:37:44
一、問題

Spring2.1.5集成activiti7.1.24時訪問要輸入用戶名和密碼。

@Autowired private ProcessRuntime processRuntime; /** * 啟動任務(wù) */ @Test void startProcess(){ /** * 流程變量 * 給<userTask 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框架,出現(xiàn)如下的異常:

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

當(dāng)我們自信的對著接口發(fā)起請求的時候,報了瀏覽器出現(xiàn)了500,控制臺報出上面的異常,中文意思:在SecurityContext中沒有找到身份驗證對象

why? 我明明已經(jīng)剔除了啊,為什么還是要驗證身份?

到底是哪里出了問題?想不明白!

如果上上面的問題,你只需要使用,老的API即可,因為新封裝的API使用SpringSecurity,所以需要身份驗證

注意:以下均是個人理解,如有錯誤,還請指正

其實,當(dāng)我們使用Activiti7的時候,要知道Activit7的開發(fā)團(tuán)隊,不在是之前Tom Baeyens的團(tuán)隊負(fù)責(zé)開發(fā),也就是下面這個哥們。

Springboot2.1.6集成activiti7出現(xiàn)登錄驗證的實現(xiàn)

Activiti7中,重新封裝了一些新的API,比如ProcessRuntime和TaskRuntime

既然是新封裝的,那一定和老的API會有所區(qū)別,那具體區(qū)別在哪里呢?

我們可以直接查看這兩個接口里面的內(nèi)容,去一探究竟!

@Autowired private ProcessRuntime processRuntime;

我這里拿ProcessRuntime舉例,我們可以直接查看下,找到實現(xiàn)的類

Springboot2.1.6集成activiti7出現(xiàn)登錄驗證的實現(xiàn)

或者直接使用快捷鍵 CTRL + H ,找出實現(xiàn)的類

Springboot2.1.6集成activiti7出現(xiàn)登錄驗證的實現(xiàn)

進(jìn)入實現(xiàn)類中:

Springboot2.1.6集成activiti7出現(xiàn)登錄驗證的實現(xiàn)

進(jìn)入實現(xiàn)類中,我們可以看到類上面使用:

@PreAuthorize('hasRole(’ACTIVITI_USER’)')

這個是什么?

SpringSecurity用來在方法調(diào)用前或者調(diào)用后進(jìn)行權(quán)限檢查

說到這里,您應(yīng)該明白了吧!因為Activiti7中封裝出來的新接口,都加了這個注解,所以當(dāng)我們即使照著最開始的方法剔除了,仍然還會出現(xiàn)身份認(rèn)證問題!

那為什么我們調(diào)用老的接口,卻不需要身份驗證呢,其實不用開源碼就可以推出,老的接口上并沒有添加該注解

我們可以看看老的接口 RuntimeService 的實現(xiàn)類:

@Autowired private RuntimeService runtimeService;

Springboot2.1.6集成activiti7出現(xiàn)登錄驗證的實現(xiàn)

所以,我們可以使用 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 新接口由于內(nèi)置SpringSecurity,在運(yùn)行時會報錯 // @Autowired // private ProcessRuntime processRuntime; // 老的接口方法,未內(nèi)置 SpringSecurity @Autowired private RuntimeService runtimeService; @Test void contextLoads() { System.out.println('hello world'); } /** * 在使用 SpringBoot + Activiti 時,啟動服務(wù)訪問模塊時,瀏覽器會彈出一個登錄界面。 * * 這是因為Activiti 框架整合了SpringSecurity框架,如果我們不需要安全驗證時可以禁用springsecurity。 * * * @SpringBootApplication( * exclude = { * org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class, * org.springframework.boot.actuate.autoconfigure.security.servlet.ManagementWebSecurityAutoConfiguration.class * }) */ /** * 啟動任務(wù) */ @Test void startProcess(){ /** * 流程變量 * 給<userTask 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()); }}

結(jié)果打印:

流程實例啟動:b0af0810-4801-11eb-b1ac-005056c00001

可以看到使用老接口,就可以成功執(zhí)行了。

相關(guān)文章:

SpringBoot2.x整合Activiti7后,禁用SpringBootSecurity問題

到此這篇關(guān)于Springboot2.1.6集成activiti7出現(xiàn)登錄驗證的實現(xiàn)的文章就介紹到這了,更多相關(guān)Springboot activiti7登錄驗證內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 成人免费在线观看视频 | 久久综合九九 | 亚洲网站在线观看 | 日韩欧美在线观看一区二区三区 | 欧美一区二区在线免费观看 | 亚洲综合第一页 | 国产精品久久久久久久久久久新郎 | 在线欧美日韩 | 日韩激情二区 | 亚洲欧美日韩精品 | 成人免费视频网站 | 日韩成人精品视频在线观看 | 搜一级毛片 | 精品中文字幕一区二区三区 | 日本久久www成人免 成人久久久久 | 91一区二区三区 | 真人一级毛片 | 久久精品一区二区三区不卡牛牛 | 欧美精品理论片大全 | 男人的天堂亚洲 | 日韩不卡一区二区三区 | 一本色道久久综合狠狠躁篇的优点 | 国产亚洲精品精品国产亚洲综合 | 欧美在线高清 | 色天天综合久久久久综合片 | 久久高清一区 | 一区二区三区在线视频播放 | 成人精品一区二区 | 日韩福利一区 | 成人在线免费观看 | 日韩在线大片 | 色综合天天 | 欧美激情在线狂野欧美精品 | 啵啵影院午夜男人免费视频 | 爱福利视频 | www..99re | 精品成人 | 久久99国产精品免费网站 | 九九精品视频在线观看 | 91精品国产欧美一区二区成人 | 一卡二卡久久 |