spring boot——ajax跨域

前言



 java语言在多数时,会作为一个后端语言,为前端的php,node.js等提供API接口。前端通过ajax请求去调用java的API服务。今天以node.js为例,介绍两种跨域方式:CrossOrigin和反向代理。

 一、准备工作



pom.xml:

 pom.xml

App.java

package com.example;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication

@SpringBootApplicationpublic class App {    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }
}

User.java

package com.example;public class User {    public int id;    public String name;    public int age;
}

MainController.java:

package com.example;import java.util.ArrayList;import java.util.List;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;/**
 * 控制器 博客出处:http://www.cnblogs.com/GoodHelper/
 * */@RestControllerpublic class MainController {

    @GetMapping("findAllUser")    public List<User> findAllUser() {
        List<User> list = new ArrayList<>();        for (int i = 0; i < 20; i++) {
            User user = new User();
            list.add(user);
            user.id = i;
            user.name = "name_" + i;
            user.age = 20 + i;
        }        return list;
    }

}

项目结构如下图所示:

访问http://localhost:8080/findAllUser

使用HBuilder创建node.js express项目:

选择ejs模板引擎:

index.ejs文件代码如下:

<!DOCTYPE html><html>

    <head>
        <title>
            <%= title %>
        </title>
        <link rel=‘stylesheet‘ href=‘/stylesheets/style.css‘ />
        <script src="//cdn.bootcss.com/angular.js/1.5.6/angular.min.js"></script>
        <script type="text/javascript">
            var app = angular.module(‘app‘, []);
            app.controller(‘MainController‘, function($rootScope, $scope, $http) {
                $http({
                    method: ‘GET‘,
                    url: ‘http://localhost:8080/findAllUser‘
                }).then(function successCallback(r) {
                    $scope.rows = r.data;
                });
            });        </script>
    </head>

    <body ng-app="app" ng-controller="MainController">
        <h1><%= title %></h1>
        <p>Welcome to            <%= title %>
        </p>

        <br />
        <table>
            <tr ng-repeat="row in rows">
                <td>{{row.id}}</td>
                <td>{{row.name}}</td>
                <td>{{row.age}}</td>
            </tr>
        </table>

    </body></html>

通过angular.js的http方法调用api请求

右键运行项目:

运行效果:

发现调用ajax请求时跨域失败。

二、spring boot后台设置允许跨域



这时,修改MainController类,在方法前加@CrossOrigin注解:

/**
 * 控制器 博客出处:http://www.cnblogs.com/GoodHelper/
 * */@RestControllerpublic class MainController {

    @CrossOrigin(origins = "http://localhost:3000")
    @GetMapping("findAllUser")    public List<User> findAllUser() {
        List<User> list = new ArrayList<>();        for (int i = 0; i < 20; i++) {
            User user = new User();
            list.add(user);
            user.id = i;
            user.name = "name_" + i;
            user.age = 20 + i;
        }        return list;
    }

}

这是声明findAllUser方法允许跨域,

也可以修改App.java,来实现全局跨域:

package com.example;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.context.annotation.Bean;import org.springframework.web.servlet.config.annotation.CorsRegistry;import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@SpringBootApplicationpublic class App {    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }

    @Bean    public WebMvcConfigurer corsConfigurer() {        return new WebMvcConfigurerAdapter() {
            @Override            public void addCorsMappings(CorsRegistry registry) {
                registry.addMapping("/**").allowedOrigins("http://localhost:3000");
            }
        };
    }
}

registry.addMapping("/**"):为根目录的全部请求,也可以设置为"/user/**",这意味着是user目录下的所有请求。

在访问http://localhost:3000,效果如下:

三、通过node.js的反向代理实现跨域



node.js提供了一些反向代理的中间件,能轻而易举的实现跨域,而不需要spring boot做任何设置。

安装express-http-proxy中间件

npm install --save-dev express-http-proxy

修改app.js文件,使其支持反向代理:

var proxy = require(‘express-http-proxy‘);var apiProxy = proxy(‘http://localhost:8080‘, {});
app.use(‘/api‘, apiProxy);

以“/api”开头的请求转发为spring boot的API服务。

完整代码如下:

 app.js

修改index.ejs文件:

            var app = angular.module(‘app‘, []);
            app.controller(‘MainController‘, function($rootScope, $scope, $http) {
                $http({
                    method: ‘GET‘,
                    url: ‘/api/findAllUser‘
                }).then(function successCallback(r) {
                    $scope.rows = r.data;
                });
            });

完整的index.ejs文件如下:

 index.ejs

运行效果如下:

总结



  第二种通过反向代理的方式是最佳方案。在正式项目中,可以使用node.js控制web前端渲染与spring boot后端提供API服务的组合。这样,可以控制用户在node.js端登录后才能调用spring boot的API服务。在大型web项目中也可以使用node.js的反向代理,把很多子站点关联起来,这样便发挥出了网站灵活的扩展性。

时间: 2024-12-05 11:16:58

spring boot——ajax跨域的相关文章

spring boot Cors 跨域

在访问web工程的时候,经常会报一些跨域的错误:CORS header 'Access-Control-Allow-Origin' missing spring boot中的cors设定方式 @Configuration  public class WebConfig extends WebMvcConfigurerAdapter {            @Override         public void addCorsMappings(CorsRegistry registry) {

spring boot 配置跨域

spring boot 跨域 import org.springframework.stereotype.Component; import javax.servlet.*; import javax.servlet.http.HttpServletResponse; import java.io.IOException; @Component public class CorsFilter implements Filter { public void doFilter(ServletRequ

【Spring Boot】Spring Boot之跨域解决方案

一.什么是跨域 跨域,指的是从一个域名去请求另外一个域名的资源.即跨域名请求!跨域时,浏览器不能执行其他域名网站的脚本,是由浏览器的同源策略造成的,是浏览器施加的安全限制. 跨域的严格一点来讲就是只要协议,域名,端口有任何一个的不同,就被当作是跨域. 常见于前端Ajax请求 二.如何模拟跨域请求 三.后台解决方案 1.步骤一:WebMvcConfigurer中添加跨域策略 @Configuration public class ApiSecurityConfig implements WebMv

Spring Boot + Vue 跨域请求问题

使用Spring Boot + Vue 做前后端分离项目搭建,实现登录时,出现跨域请求 Access to XMLHttpRequest at 'http://localhost/open/login' from origin 'http://localhost:8080' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. V

jQuery中Ajax+Spring MVC实现跨域请求

项目开发中,某个可独立.也可集成的子业务模块须要向外开放相关API接口,先说下项目本身使用了jersery来实现RESTful webservice以名词形式公布API.有意思的是在实际的操作中同事却通过Ajax跨域请求的方式去调用该API,先不说成功与否,这样的方式本就是"滑稽"的.和他一起探讨了此种做法的不合理性,之后选择jersey client的方式进行远程调用.只是他在跨域请求中遇到了问题,自己闲暇时间予以解决,这才是此篇文章的由来. jQuery对跨域请求有两种解决方式各自

spring +mybatis+strut2框架下 实现ajax跨域访问的问题

做项目中遇到一个ajax跨域请求的问题,在网上找了很多,这个介绍的相对详细一点儿,但是后台处理跟我的还有一点儿不一样,特贴出来,以供参考. 1:action中是一般常用方式: 2:在struts的配置文件中增加一条 <param name="callbackParameter">callback</param> 3:在ajax中修改原来json为jsonp,再增加两个属性 jsonp:"callback", jsonpCallback:&qu

ajax跨域,这应该是最全的解决方案了

前言 从刚接触前端开发起,跨域这个词就一直以很高的频率在身边重复出现,一直到现在,已经调试过N个跨域相关的问题了,16年时也整理过一篇相关文章,但是感觉还是差了点什么,于是现在重新梳理了一下. 个人见识有限,如有差错,请多多见谅,欢迎提出issue,另外看到这个标题,请勿喷~ 题纲 关于跨域,有N种类型,本文只专注于ajax请求跨域(,ajax跨域只是属于浏览器"同源策略"中的一部分,其它的还有Cookie跨域iframe跨域,LocalStorage跨域等这里不做介绍),内容大概如下

ajax跨域相关

ajax 技术使用xmlhttprequest组件附送请求时,发送请求的url和本网页的url地址必须在同一个域名下如果需要跨域,可以使用iframe或者<javascript src="url"></script>的方式   http://www.cnblogs.com/Spring/archive/2008/10/21/1315882.html http://exceptioneye.iteye.com/blog/1405495     新的W3C策略实现了

AJAX跨域完全讲解

AJAX跨域完全讲解 今天在慕课网上学习了AJAX跨域完全讲解:https://www.imooc.com/learn/947 我在收集AJAX面试题的时候其实就已经有过AJAX跨域的问题的了,当时候知道了为什么会存在跨域,以及跨域解决的方案有哪些,今天随着课程的学习,又加深了AJAX跨域的理解,以此记录下来. 为什么会发生产生跨域问题? 上面的图也很清晰了,因为浏览器为了安全(同源),本身就限制了. 当我们发送XMLHttpRequest请求的时候,如果请求的是别的域(主机域名.端口)不同时,