首页>>后端>>java->netty系列之:在netty中处理CORS

netty系列之:在netty中处理CORS

时间:2023-11-29 本站 点击:34

简介

CORS的全称是跨域资源共享,他是一个基于HTTP-header检测的机制,通过对HTTP-header进行控制,可以实现对跨域资源的权限管理功能。在之前的CORS详解文章中,我们已经对CORS有了基本的解释。

本文将会从Netty的实现角度,讲解如何在netty中实现CORS。

服务端的CORS配置

熟悉CORS的朋友应该知道,CORS所有的操作都是在HTTP协议之上通过控制HTTP头来实现的。所以说如果要在服务器端实现CORS的支持,事实上也是对HTTP协议的头进行各种设置完成的。

为了方便大家的使用,netty提供了一个CorsConfig类,来统一CORS的头设置。

先看下CorsConfig类中定义的属性:

privatefinalSet<String>origins;privatefinalbooleananyOrigin;privatefinalbooleanenabled;privatefinalSet<String>exposeHeaders;privatefinalbooleanallowCredentials;privatefinallongmaxAge;privatefinalSet<HttpMethod>allowedRequestMethods;privatefinalSet<String>allowedRequestHeaders;privatefinalbooleanallowNullOrigin;privatefinalMap<CharSequence,Callable<?>>preflightHeaders;privatefinalbooleanshortCircuit;

这些属性和CORS的HTTP头设置是一一对应的。比如说origins表示的是允许的源,anyOrigin表示允许所有的源。

是和下面的设置对应的:

Origin:<origin>

exposeHeaders是和Access-Control-Expose-Headers一一对应的,表示服务器端允许客户端获取CORS资源的同时能够访问到的header信息。其格式如下:

Access-Control-Expose-Headers:<header-name>[,<header-name>]*

allowCredentials表示是否开启CORS的权限认证。表示服务器端是否接受客户端带有credentials字段的请求。如果用在preflight请求中,则表示后续的真实请求是否支持credentials,其格式如下:

Access-Control-Allow-Credentials:true

allowedRequestMethods表示访问资源允许的方法,主要用在preflight request中。其格式如下:

Access-Control-Allow-Methods:<method>[,<method>]*

allowedRequestHeaders用在preflight request中,表示真正能够被用来做请求的header字段,其格式如下:

Access-Control-Allow-Headers:<header-name>[,<header-name>]*

当客户端发送OPTIONS方法给服务器的时候,为了安全起见,因为服务器并不一定能够接受这些OPTIONS的方法,所以客户端需要首先发送一个preflighted requests,等待服务器响应,等服务器确认之后,再发送真实的请求。我们举一个例子。preflightHeaders表示的就是服务器允许额preflight的请求头。

shortCircuit表示请求是否是一个有效的CORS请求,如果请求被拒绝之后,就会返回一个true。

CorsConfigBuilder

CorsConfig使用来表示Cors的配置类,那么怎么去构造这个配置类呢?我们看下CorsConfig的构造函数:

CorsConfig(finalCorsConfigBuilderbuilder){origins=newLinkedHashSet<String>(builder.origins);anyOrigin=builder.anyOrigin;enabled=builder.enabled;exposeHeaders=builder.exposeHeaders;allowCredentials=builder.allowCredentials;maxAge=builder.maxAge;allowedRequestMethods=builder.requestMethods;allowedRequestHeaders=builder.requestHeaders;allowNullOrigin=builder.allowNullOrigin;preflightHeaders=builder.preflightHeaders;shortCircuit=builder.shortCircuit;}

可以看到CorsConfig是通过CorsConfigBuilder来构造的。通过设置CorsConfigBuilder中的各种属性即可。CorsConfigBuilder中提供了多种设置属性的方法。

可以使用这样的方法来构造CorsConfig如下:

CorsConfigcorsConfig=CorsConfigBuilder.forAnyOrigin().allowNullOrigin().allowCredentials().build();

CorsHandler

有了corsConfig,我们还需要将这个config配置在netty的handler中,netty提供了一个CorsHandler类来专门处理corsConfig,这个类就叫CorsHandler。

首先看下CorsHandler的构造函数:

publicCorsHandler(finalCorsConfigconfig){this(Collections.singletonList(checkNotNull(config,"config")),config.isShortCircuit());}publicCorsHandler(finalList<CorsConfig>configList,booleanisShortCircuit){checkNonEmpty(configList,"configList");this.configList=configList;this.isShortCircuit=isShortCircuit;}

CorsHandler有两个构造函数,一个是传入CorsConfig,一个是传入一个CorsConfig的列表。

CorsHandler的主要工作原理就是在channelRead的时候,对responseHeader进行处理,设置CORS头。

netty对cors的支持

上面我们已经讲过了netty中cors的核心类和方法,最后一步就是把cors的支持类加入到netty的pipeline中,其核心代码如下:

publicvoidinitChannel(SocketChannelch){ChannelPipelinepipeline=ch.pipeline();pipeline.addLast(newHttpResponseEncoder());pipeline.addLast(newHttpRequestDecoder());pipeline.addLast(newHttpObjectAggregator(65536));pipeline.addLast(newChunkedWriteHandler());CorsConfigcorsConfig=CorsConfigBuilder.forAnyOrigin().allowNullOrigin().allowCredentials().build();pipeline.addLast(newCorsHandler(corsConfig));pipeline.addLast(newCustResponseHandler());}

总结

cors比较简单,netty也为其提供了住够的方法支持。大家可以直接使用。

本文的例子可以参考:learn-netty4

最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!

欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/java/65.html