91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Springboot2.1.6中使用activiti7實現一個登錄驗證功能

發布時間:2020-12-28 16:29:36 來源:億速云 閱讀:320 作者:Leah 欄目:開發技術

怎么在Springboot2.1.6中使用activiti7實現一個登錄驗證功能?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

一、問題

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的團隊負責開發,也就是下面這個哥們。

怎么在Springboot2.1.6中使用activiti7實現一個登錄驗證功能

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

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

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

@Autowired
  private ProcessRuntime processRuntime;

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

怎么在Springboot2.1.6中使用activiti7實現一個登錄驗證功能

或者直接使用快捷鍵 CTRL + H ,找出實現的類

怎么在Springboot2.1.6中使用activiti7實現一個登錄驗證功能

進入實現類中:

怎么在Springboot2.1.6中使用activiti7實現一個登錄驗證功能

進入實現類中,我們可以看到類上面使用:

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

這個是什么?

SpringSecurity用來在方法調用前或者調用后進行權限檢查

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

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

我們可以看看老的接口 RuntimeService 的實現類:

  @Autowired
  private RuntimeService runtimeService;

怎么在Springboot2.1.6中使用activiti7實現一個登錄驗證功能

所以,我們可以使用 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.1.6中使用activiti7實現一個登錄驗證功能的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

三亚市| 赤壁市| 邻水| 望都县| 太谷县| 台山市| 景宁| 临颍县| 兴化市| 闻喜县| 开封县| 迁西县| 揭西县| 西青区| 郸城县| 田东县| 新竹市| 镇江市| 长寿区| 开远市| 襄汾县| 大庆市| 灵丘县| 怀宁县| 安阳县| 九龙坡区| 紫金县| 新和县| 屏东县| 吴忠市| 和静县| 那曲县| 锦屏县| 祁阳县| 剑阁县| 新泰市| 西乌珠穆沁旗| 客服| 南溪县| 开鲁县| 东明县|