小王 学JAVA 2022-04-02 16:57 采纳率: 100%
浏览 123
已结题

SpringSecurity + JWT + Vue 实现登录出现403

问题遇到的现象和发生背景

SpringSecurity + JWT + Vue实现登录时出现403拒绝访问错误,后端开启了关闭跨域保护,可依旧报错

问题相关代码,请勿粘贴截图
/**
     * 核心配置,认证用户
     * @param http
     * @throws Exception
     */
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.authorizeRequests()
                .antMatchers("/hello").hasRole("user")
                .antMatchers("/admin").hasRole("system_manage")
                .antMatchers("/login").permitAll()
                .anyRequest().authenticated()
                .and()
                .addFilterBefore(new JwtLoginFilter("/login",authenticationManager()), UsernamePasswordAuthenticationFilter.class)
                .addFilterBefore(new JwtFilter(),UsernamePasswordAuthenticationFilter.class)
                .csrf().disable();
    }
运行结果及报错内容

img

我的解答思路和尝试过的方法

加了任何跨域解决方案依旧是403

我想要达到的结果

正常实现登录

  • 写回答

6条回答 默认 最新

  • Bug 终结者 Java领域优质创作者 2022-04-04 15:07
    关注

    跨域出错,使用Nginx开启反向代理然后进行跨域请求

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • CSDN专家-微编程 2022-04-02 20:58
    关注

    你的vue对应的axios是怎么设置的,也发出来看看,登录是否使用了qs,请求类型是否像这样的

     //登录
        login<T = any>(url: string, pas: LoginParam): Promise<Result<T>> {
            return new Promise(((resolve, reject) => {
                this.instance.post<T>(url, pas, {
                    transformRequest: [pas => {
                        return qs.stringify(pas)
                    }],
                    headers: {
                        'Content-Type': 'application/x-www-form-urlencoded'
                    }
                }).then(res => {
                    resolve(res as any)
                }).catch(error => {
                    reject(error)
                })
            }))
        }
    
    评论
  • 帅杰!!! 2022-04-02 17:10
    关注

    你这一个是跨域了vue跨域 使用proxy代理,
    403 是访问被拒绝,看是不是你的heard 里加入了过期得token导致访问被拒绝

    评论
  • 一起随缘 2022-04-02 17:25
    关注

    跨域类改成如下代码试试:

    @Configuration
    public class CorsConfig implements WebMvcConfigurer {
    
        @Override
        public void addCorsMappings(CorsRegistry registry) {
            registry.addMapping("/**")    // 允许跨域访问的路径
            .allowedOrigins("*")    // 允许跨域访问的源
            .allowedMethods("POST", "GET", "PUT", "OPTIONS", "DELETE")    // 允许请求方法
            .maxAge(168000)    // 预检间隔时间
            .allowedHeaders("*")  // 允许头部设置
            .allowCredentials(true);    // 是否发送cookie
        }
    }
    
    评论
  • 小王 学JAVA 2022-04-02 18:24
    关注

    postman测试正常,vue就403了

    评论
  • 有问必答小助手 2022-04-04 15:09
    关注
    您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
    PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632
    评论
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 4月12日
  • 已采纳回答 4月4日
  • 创建了问题 4月2日

悬赏问题

  • ¥20 C语言字符串不区分大小写字典排序相关问题
  • ¥15 关于#python#的问题:我希望通过逆向技术爬取1688搜索页下滑加载的数据
  • ¥15 学习C++过程中遇到的问题
  • ¥15 关于Linux的终端里,模拟实现一个带口令保护的屏保程序遇到的输入输出的问题!(语言-c语言)
  • ¥15 学习C++过程中遇到的问题
  • ¥15 请问,这个嵌入式Linux系统怎么分析,crc检验区域在哪
  • ¥15 二分类改为多分类问题
  • ¥15 Unity微信小游戏上调用ReadPixels()方法报错
  • ¥15 如何通过求后验分布求得样本中属于两种物种其中一种的概率?
  • ¥15 q从常量变成sin函数,怎么改写python代码?