SpringBoot项目问题总结

SpringBoot项目启动问题整理
1、启动SpringBoot报错,报错信息:
错误1:

SLF4J: Actual binding is of type [org.apache.logging.slf4j.Log4jLoggerFactory]
Exception in thread "main" java.lang.ExceptionInInitializerError
	at com.tsingvast.SpringBootTest.main(SpringBootTest.java:27)
Caused by: org.apache.logging.log4j.LoggingException: log4j-slf4j-impl cannot be present with log4j-to-slf4j
	at org.apache.logging.slf4j.Log4jLoggerFactory.validateContext(Log4jLoggerFactory.java:49)
	at org.apache.logging.slf4j.Log4jLoggerFactory.newLogger(Log4jLoggerFactory.java:39)
	at org.apache.logging.slf4j.Log4jLoggerFactory.newLogger(Log4jLoggerFactory.java:30)
	at org.apache.logging.log4j.spi.AbstractLoggerAdapter.getLogger(AbstractLoggerAdapter.java:54)
	at org.apache.logging.slf4j.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:30)
	at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:270)
	at org.apache.commons.logging.LogAdapter$Slf4jAdapter.createLocationAwareLog(LogAdapter.java:130)
	at org.apache.commons.logging.LogAdapter.createLog(LogAdapter.java:91)
	at org.apache.commons.logging.LogFactoryService.getInstance(LogFactoryService.java:46)
	at org.apache.commons.logging.LogFactoryService.getInstance(LogFactoryService.java:41)
	at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:657)
	at org.springframework.boot.SpringApplication.<clinit>(SpringApplication.java:196)
	... 1 more

解决办法:
根据报错关键信息:Caused by: org.apache.logging.log4j.LoggingException: log4j-slf4j-impl cannot be present with log4j-to-slf4j
两个依赖包冲突,查找相关的依赖,去掉log4j-to-slf4j的依赖
命令行查看依赖树:mvn dependency:tree
查找与log4j-to-slf4j依赖相关的jar包,发现与spring-boot-starter-logging相关

            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>

错误2:

Caused by: org.apache.catalina.LifecycleException: Failed to start component [NonLoginAuthenticator[StandardEngine[Tomcat].StandardHost[localhost].TomcatEmbeddedContext[]]]
	at org.apache.catalina.util.LifecycleBase.handleSubClassException(LifecycleBase.java:440)
	at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:198)
	at org.apache.catalina.core.StandardPipeline.startInternal(StandardPipeline.java:176)
	at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
	at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5063)
	at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
	at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1384)
	at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1374)
	at java.util.concurrent.FutureTask.run(FutureTask.java:266)
	at org.apache.tomcat.util.threads.InlineExecutorService.execute(InlineExecutorService.java:75)
	at java.util.concurrent.AbstractExecutorService.submit(AbstractExecutorService.java:134)
	at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:909)

解决方法:
百度查找,发现servlet-api有关,去掉依赖

             <exclusions>
                <exclusion>
                    <groupId>javax.servlet</groupId>
                    <artifactId>servlet-api</artifactId>
                </exclusion>
            </exclusions>

错误3:

Web server failed to start. Port 8080 was already in use.

Action:

Identify and stop the process that's listening on port 8080 or configure this application to listen on another port.

解决方法:
默认的端口号是8080,错误显示8080已经被占用,需要在xml配置文件中增加port的设置

server:
  port: 7071

2、无法获取@Value注解的静态属性的值,报null,静态属性定义

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component
public class Constantfig {

    public static String offset;//impala 处理时间戳为unixtime时的偏移量
    @Value("${offset}")
    public  void setOffset(String offset) {
        Constantfig.offset = offset;
    }
}

在调用的类前加注解:@SpringBootApplication
非静态类属性的获取

ApplicationContext context = SpringUtils.getApplicationContext();
Constantfig config = context.getBean(Constantfig.class);
String ip = config.getIp();
System.out.println(ip);

用到的SpringUtils类

package com.tsingvast;

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

/**
 * @author xujun on 2020/2/20.
 */
@Component
public class SpringUtils implements ApplicationContextAware {
    private static ApplicationContext applicationContext = null;

    @Override
    public void setApplicationContext(ApplicationContext context) throws BeansException {
        if(SpringUtils.applicationContext == null){
            SpringUtils.applicationContext  = context;
        }
    }

    // 非@import显式注入,@Component是必须的,且该类必须与main同包或子包
    // 若非同包或子包,则需手动import 注入,有没有@Component都一样
    // 可复制到Test同包测试
    //获取applicationContext
    public static ApplicationContext getApplicationContext() {
        return applicationContext;
    }

    //通过name获取 Bean.
    public static Object getBean(String name){
        return getApplicationContext().getBean(name);
    }

    //通过class获取Bean.
    public static <T> T getBean(Class<T> clazz){
        return getApplicationContext().getBean(clazz);
    }

    //通过name,以及Clazz返回指定的Bean
    public static <T> T getBean(String name,Class<T> clazz){
        return getApplicationContext().getBean(name, clazz);
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于Spring Boot项目的权限管理系统,你可以采用类似的框架和技术来实现。Spring Security仍然是一种常用的选择,它提供了完善的安全性解决方案,并与Spring Boot框架无缝集成。 首先,在你的Spring Boot项目中,你可以引入Spring Security依赖并配置相关的安全策略。你可以定义用户认证的方式,例如基于用户名和密码的认证,或者第三方登录认证。同时,你可以定义用户角色和权限,并将其与具体的资源进行关联。 其次,你可以使用注解或配置方式来限制用户对资源的访问权限。Spring Security提供了一系列注解和配置选项,帮助你在控制器或方法级别上添加权限验证。你可以指定哪些角色或权限可以访问某个资源,以及如何处理未授权的请求。 另外,你也可以通过数据库来管理用户信息和权限信息。你可以定义用户表、角色表和权限表,并建立它们之间的关系。通过操作数据库,你可以进行用户角色和权限的分配、修改和删除等操作。 除了Spring Security,你还可以考虑使用其他相关的库或技术来增强权限管理系统的功能。例如,你可以使用JSON Web Token(JWT)来实现无状态的身份验证,或者使用OAuth 2.0来支持第三方登录。 总结而言,Spring Boot项目的权限管理系统可以通过使用Spring Security来实现用户认证、授权和权限管理等功能。同时,你可以结合数据库来存储用户信息和权限信息,并使用相应的技术来增强系统的功能和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值