springboot webflux 跨域示例


springboot webflux 跨域示例

 

 

**********************

应用 1

 

***************

controller 层

 

RedirectController

@Controller
public class RedirectController {

    @RequestMapping("/index")
    public String index(){
        return "index";
    }
}

 

HelloController

@RestController
public class HelloController {

    @RequestMapping("/hello")
    public Map<String,String> hello(ServerWebExchange exchange){
        exchange.getRequest().getHeaders().forEach((key,value) ->{
            System.out.println(key+" ==> "+value);
        });

        Map<String,String> map=new HashMap<>();
        map.put("info","hello world");

        return map;
    }
}

 

***************

前端页面

 

index.html

<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml"
      xmlns:th="http://www.thymeleaf.org" xmlns:sec="https://www.thymeleaf.org/thymeleaf-extras-springsecurity4">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="/js/jquery-3.5.1.min.js"></script>
    <script type="text/javascript">
        $(function () {
            $("#btn").click(function () {
                $.get({
                    url: "/hello",
                    success: function (result) {
                        $("#data").html(result.info)
                    }
                })
            });

            $("#btn2").click(function () {
                $.get({
                    url: "http://localhost:8081/hello",
                    success: function (result) {
                        $("#data2").html(result.info)
                    }
                })
            });
        })
    </script>
</head>
<body>
<div th:align="center">
    <button id="btn">获取数据</button>
    <button id="btn2">获取数据2</button><br>
    <span id="data"></span><br>
    <span id="data2"></span>
</div>
</body>
</html>

 

 

**********************

应用 2

 

***************

配置文件

 

application.properties

server.port=8081

 

***************

controller 层

 

HelloController

@RestController
public class HelloController {

    @RequestMapping("/hello")
    public Map<String,String> hello(ServerWebExchange exchange){
        exchange.getRequest().getHeaders().forEach((key,value) -> {
            System.out.println(key+" ==> "+value);
        });

        Map<String,String> map=new HashMap<>();
        map.put("info","hello world2");

        return map;
    }
}

 

 

**********************

使用测试

 

localhost:8080/index

                        

 

点击获取数据,可正常获取数据

点击获取数据2,由于跨域,不能正常获取数据

                 

 

***************

控制台输出

 

应用1

Host ==> [localhost:8080]
Connection ==> [keep-alive]
Accept ==> [*/*]
X-Requested-With ==> [XMLHttpRequest]
User-Agent ==> [Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36]
Referer ==> [http://localhost:8080/index]
Accept-Encoding ==> [gzip, deflate, br]
Accept-Language ==> [zh-CN,zh;q=0.9]

 

应用2

Host ==> [localhost:8081]
Connection ==> [keep-alive]
Accept ==> [*/*]
Origin ==> [http://localhost:8080]
User-Agent ==> [Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36]
Referer ==> [http://localhost:8080/index]
Accept-Encoding ==> [gzip, deflate, br]
Accept-Language ==> [zh-CN,zh;q=0.9]

由于跨域,请求头多了一个Origin,用来标识请求的来源

 

 

 

**********************

应用 2 添加跨域配置

 

***************

config 层

 

WebFluxConfig

@Configuration
public class WebFLuxConfig implements WebFluxConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/hello")
                .allowedOrigins("http://localhost:8080");
    }
}

 

 

**********************

使用测试

 

添加跨域配置后,可正常获取数据

               

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值