Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 605|回复: 0

解决跨域问题,前端 live-server --port=1802 后端启动 localhost:1801,以及解决 vue 的 axios 请求整合

[复制链接]
  • TA的每日心情
    奋斗
    4 天前
  • 签到天数: 802 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726006
    发表于 2021-5-30 19:17:38 | 显示全部楼层 |阅读模式

    • 测试的源码文件内容 点击跳转
    •  

       

    •  

       

    •  前端引入 vue.js 与 axios.min.js

      <script src="https://cdn.bootcss.com/vue/2.6.10/vue.js"></script>
      <script src="https://unpkg.com/axios/dist/axios.min.js"></script>

       

    • 测试

      1.  

        前端请求 不带 http://

        axios.get("localhost:1801/user/get");
        后端不配置跨域

         前端报错,后台进不去方法

         

      2.  

        前端请求 不带 http://
        axios.get("localhost:1801/user/get");
        后端配置跨域

         前端报错,后台进不去方法

         

      3.  

        前端请求带 http:// 
        
        axios.get("http://localhost:1801/user/get").then((res) =>
        {
            alert("成功")
        }).catch((res) =>
        {
            alert("失败")
        })
        
        
        后端不配置跨域

         

         前端报错,弹框"失败",也就是异常了

        但是,后端方法正常跑完了

         

      4.  

        前端请求带 http:// 
        
        axios.get("http://localhost:1801/user/get").then((res) =>
        {
            alert("成功")
        }).catch((res) =>
        {
            alert("失败")
        })
        
        
        后端配置跨域

         前端正常,弹框"成功",也就是正常访问,正常接收到返回数据了

        后端方法自然也是正常跑完了

         

         


    • 前端,测试在方法 get

       

      <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <title>Title</title>
      </head>
      <body>
      <div id="app">
          <input type="button" @click="get" value="get">
          <input type="button" @click="get1" value="get1">
          <input type="button" @click="get2" value="get2">
          <hr/>
          <input type="button" @click="post" value="post">
          <input type="button" @click="post1" value="post1">
          <input type="button" @click="post2" value="post2">
          <hr/>
          <input type="button" @click="del" value="delete">
          <input type="button" @click="del1" value="delete1">
          <input type="button" @click="del2" value="delete2">
          <hr/>
          <input type="button" @click="put" value="put">
          <input type="button" @click="put1" value="put1">
          <input type="button" @click="put2" value="put2">
      </div>
      
      <script src="https://cdn.bootcss.com/vue/2.6.10/vue.js"></script>
      <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
      <script>
          new Vue({
              el: "#app",
              data: {
                  request_get: {
                      get1_id: "111",
                      get2_id: "222"
                  },
                  request_post: {
                      post: {
                          username: "我是用户名_post_data",
                          password: "我是密码_post_data",
                      }
                  },
                  request_delete: {
                      delete1_id: "111",
                      delete2_id: "222"
                  },
                  request_put: {
                      put: {
                          username: "我是用户名_put_data",
                          password: "我是密码_put_data",
                      }
                  },
              },
              methods: {
                  get()
                  {
                      //axios.get("localhost:1801/user/get");
                      //axios.get("http://localhost:1801/user/get");
                      axios.get("http://localhost:1801/user/get").then((res) =>
                      {
                          alert("成功")
                      }).catch((res) =>
                      {
                          alert("失败")
                      })
                  },
                  get1()
                  {
                      axios.get("http://localhost:1801/user/get1?id=" + this.request_get.get1_id);
                  },
                  get2()
                  {
                      axios.get("http://localhost:1801/user/get2/" + this.request_get.get2_id);
                  },
                  post()
                  {
                      axios.post("http://localhost:1801/user/post");
                  },
                  post1()
                  {
                      /*方式1*/
                      axios.post("http://localhost:1801/user/post1", {
                          "username": "我是用户名_post1_加引号",
                          "password": "我是密码_post1_加引号"
                      });
                      /*方式2*/
                      axios.post("http://localhost:1801/user/post1", {
                          username: "我是用户名__post1_不引号",
                          password: "我是密码_post1_不引号"
                      });
                      /*方式3*/
                      axios.post("http://localhost:1801/user/post1", this.request_post.post);
                  },
                  post2()
                  {
                      /*方式1*/
                      axios.post("http://localhost:1801/user/post2?username=我是用户名_post2_1&password=我是密码_post2_1");
                      /*方式2*/
                      axios.post("http://localhost:1801/user/post2", "username=我是用户名_post2_2&password=我是密码_post2_2");
                      /*方式3*/
                      axios.post("http://localhost:1801/user/post2", "username="+this.request_post.post.username+"&password="+this.request_post.post.password);
      
                  },
                  del()
                  {
                      axios.delete("http://localhost:1801/user/delete");
                  },
                  del1()
                  {
                      axios.delete("http://localhost:1801/user/delete1?id=" + this.request_delete.delete1_id);
                  },
                  del2()
                  {
                      axios.delete("http://localhost:1801/user/delete2/" + this.request_delete.delete2_id);
                  },
                  put()
                  {
                      axios.put("http://localhost:1801/user/put");
                  },
                  put1()
                  {
                      /*方式1*/
                      axios.put("http://localhost:1801/user/put1", {"username": "我是用户名_put1_加引号", "password": "我是密码_put1_加引号"});
                      /*方式2*/
                      axios.put("http://localhost:1801/user/put1", {username: "我是用户名__put1_不引号", password: "我是密码_put1_不引号"});
                      /*方式3*/
                      axios.put("http://localhost:1801/user/put1", this.request_put.put);
                  }
              }
          })
      </script>
      </body>
      </html>
      index.html

       

    • 后端

       

       

      • <?xml version="1.0" encoding="UTF-8"?>
        <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
            <modelVersion>4.0.0</modelVersion>
            <parent>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-parent</artifactId>
                <version>2.1.7.RELEASE</version>
                <relativePath/> <!-- lookup parent from repository -->
            </parent>
            <groupId>com.example</groupId>
            <artifactId>test_01</artifactId>
            <version>0.0.1-SNAPSHOT</version>
            <name>test_01</name>
            <description>Demo project for Spring Boot</description>
        
            <properties>
                <java.version>1.8</java.version>
            </properties>
        
            <dependencies>
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-web</artifactId>
                </dependency>
        
                <dependency>
                    <groupId>org.projectlombok</groupId>
                    <artifactId>lombok</artifactId>
                    <version>1.18.8</version>
                </dependency>
        
        
            </dependencies>
        
            <build>
                <plugins>
                    <plugin>
                        <groupId>org.springframework.boot</groupId>
                        <artifactId>spring-boot-maven-plugin</artifactId>
                    </plugin>
                </plugins>
            </build>
        
        </project>
        pom.xml

         

      • server.port=1801
        application.properties

         

      • package panfeng;
        
        import org.springframework.boot.SpringApplication;
        import org.springframework.boot.autoconfigure.SpringBootApplication;
        
        @SpringBootApplication
        public class Test01Application
        {
            public static void main(String[] args)
            {
                SpringApplication.run(Test01Application.class, args);
            }
        }
        Test01Application.java

         

      • package panfeng.config;
        
        import org.springframework.context.annotation.Bean;
        import org.springframework.context.annotation.Configuration;
        import org.springframework.web.cors.CorsConfiguration;
        import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
        import org.springframework.web.filter.CorsFilter;
        /*
         * 描述:配置跨域
         * 【时间 2019-08-23 10:52 作者 陶 攀 峰】
         */
        @Configuration
        public class MyCors
        {
            @Bean
            // import org.springframework.web.filter.CorsFilter;
            public CorsFilter corsFilter()
            {
                CorsConfiguration config = new CorsConfiguration();
                // 添加允许信任域名
                // 1) 允许跨域的域名,不要写*,否则cookie就无法使用了,*表示所有域名都可跨域访问
                // live-server --port=1802
                config.addAllowedOrigin("http://127.0.0.1:1802");//浏览器顶部搜索框http://localhost:1802/
                config.addAllowedOrigin("http://localhost:1802");//浏览器顶部搜索框http://127.0.0.1:1802/
                // 2) 是否发送Cookie信息
                config.setAllowCredentials(true);
                // 3) 允许的请求方式
                // *表示所有请求方式:GET POST DELETE PUT...
                config.addAllowedMethod("*");
                // 4) 允许的头信息
                config.addAllowedHeader("*");
                // 初始化cors数据源对象
                // import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
                UrlBasedCorsConfigurationSource configurationSource = new UrlBasedCorsConfigurationSource();
                configurationSource.registerCorsConfiguration("/**", config);
                // 返回CorsFilter实例,参数:cors配置源对象
                return new CorsFilter(configurationSource);
            }
        }
        MyCors.java

         

      • package panfeng.entity;
        
        import lombok.AllArgsConstructor;
        import lombok.Data;
        import lombok.NoArgsConstructor;
        import org.hibernate.validator.constraints.Length;
        
        @Data
        @NoArgsConstructor
        @AllArgsConstructor
        public class User
        {
            private String username;
            private String password;
            private int age;
        }
        User.java

         

      • package panfeng.controller;
        
        
        import org.springframework.http.ResponseEntity;
        import org.springframework.stereotype.Controller;
        import org.springframework.web.bind.annotation.*;
        import panfeng.entity.User;
        
        @Controller
        @RequestMapping("user")
        public class UserController
        {
            @GetMapping("get")
            public ResponseEntity<String> get()
            {
                System.out.println("get...");
                return ResponseEntity.ok("w s return");
            }
        
            @GetMapping("get1")
            public void get1(@RequestParam("id") Integer id)
            {
                System.out.println("get1..." + id);
            }
        
            @GetMapping("get2/{id}")
            public void get2(@PathVariable("id") Integer id)
            {
                System.out.println("get2..." + id);
            }
        
            @PostMapping("post")
            public void post()
            {
                System.out.println("post...");
            }
        
            @PostMapping("post1")
            public void post1(@RequestBody(required = false) User user)
            {
                System.out.println("post1..." + user);
            }
        
            @PostMapping("post2")
            public void post2(@RequestParam("username") String username, @RequestParam("password") String password)
            {
                System.out.println("post2..." + username + "---" + password);
            }
        
            @DeleteMapping("delete")
            public void delete()
            {
                System.out.println("delete...");
            }
        
            @DeleteMapping("delete1")
            public void delete1(@RequestParam("id") Integer id)
            {
                System.out.println("delete1..." + id);
            }
        
            @DeleteMapping("delete2/{id}")
            public void delete2(@PathVariable("id") Integer id)
            {
                System.out.println("delete1..." + id);
            }
        
            @PutMapping("put")
            public void put()
            {
                System.out.println("put...");
            }
        
            @PutMapping("put1")
            public void put1(@RequestBody(required = false) User user)
            {
                System.out.println("put1..." + user);
            }
        
        
        }
        UserController.java

         


    大坑

    都要配置,如果只配置了localhost 顶部栏为127.0.0.1的时候就会报跨域的错误

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-11-15 12:41 , Processed in 2.028896 second(s), 30 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表