博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
玩转spring boot——ajax跨域
阅读量:7109 次
发布时间:2019-06-28

本文共 7168 字,大约阅读时间需要 23 分钟。

前言


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

 

 一、准备工作


 

pom.xml:

4.0.0
com.example
spring-boot-15
0.0.1-SNAPSHOT
jar
spring-boot-15
Demo project for Spring Boot
org.springframework.boot
spring-boot-starter-parent
1.5.3.RELEASE
UTF-8
UTF-8
1.8
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-devtools
runtime
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-maven-plugin

 

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
findAllUser() { List
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文件代码如下:

                        <%= title %>                

<%= title %>

Welcome to <%= title %>

{
{row.id}}
{
{row.name}}
{
{row.age}}

 通过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
findAllUser() { List
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服务。

完整代码如下:

/** * Module dependencies. */var express = require('express')  , routes = require('./routes')  , user = require('./routes/user')  , http = require('http')  , path = require('path');var app = express();// all environmentsapp.set('port', process.env.PORT || 3000);app.set('views', __dirname + '/views');app.set('view engine', 'ejs');app.use(express.favicon());app.use(express.logger('dev'));app.use(express.bodyParser());app.use(express.methodOverride());app.use(app.router);app.use(express.static(path.join(__dirname, 'public')));// development onlyif ('development' == app.get('env')) {  app.use(express.errorHandler());}var proxy = require('express-http-proxy');var apiProxy = proxy('http://localhost:8080', {});app.use('/api', apiProxy);app.get('/', routes.index);app.get('/users', user.list);http.createServer(app).listen(app.get('port'), function(){  console.log('Express server listening on port ' + app.get('port'));});

 

修改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文件如下:

                        <%= title %>                

<%= title %>

Welcome to <%= title %>

{
{row.id}}
{
{row.name}}
{
{row.age}}

 

运行效果如下:

 

 

 

 

总结


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

 

参考:https://spring.io/guides/gs/rest-service-cors/

 

代码地址:https://github.com/carter659/spring-boot-15.git

 

 

作者:刘冬.NET 博客地址:http://www.cnblogs.com/GoodHelper/ 欢迎转载,但须保留版权

http://www.cnblogs.com/GoodHelper/p/6824562.html

 

你可能感兴趣的文章
完整复制/转移数据库
查看>>
Java中JSON字符串与java对象的互换实例详解
查看>>
HDU5152 线段树 + 数论
查看>>
MySQL执行计划
查看>>
flex布局的使用,纪念第一次开发手机网站
查看>>
Linux代理搭建TinyProxy
查看>>
关于解构
查看>>
P4389 付公主的背包
查看>>
SqlServer突破亿级数据操作瓶颈(出处:转载)
查看>>
AspNetCore 使用log4net+IExceptionFilter 记录错误日志
查看>>
linux命令之df
查看>>
VS中utf8转换为unicode
查看>>
Oracle错误代码案例总结及解决方案
查看>>
js调用WebService出现webserive未定义错误!
查看>>
excel2007内容转成xml
查看>>
教你tomcat配置ssl证书
查看>>
sublime快捷方式小结
查看>>
Web Deployment Tool 服务器端
查看>>
Codeforces Round #219 (Div. 2) B. Making Sequences is Fun
查看>>
Android编译系统详解(一)——build/envsetup.sh
查看>>