APIGateway仅限CloudFront访问。
创始人
2024-09-07 16:00:43
0

API Gateway提供了许多不同的身份验证和授权选项。下面是一个示例命令,用于将API Gateway仅限由CloudFront Origin请求的访问:

  1. 首先,创建一个名为CFOriginRequest的AWS Lambda函数,以返回API Gateway Endpoint请求的授权策略。

import json

def build_policy(principal_id, effect, resource): auth_response = {} auth_response['principalId'] = principal_id if effect and resource: policy_document = {} policy_document['Version'] = '2012-10-17' statement = {} statement['Action'] = 'execute-api:Invoke' statement['Effect'] = effect statement['Resource'] = resource policy_document['Statement'] = [statement] auth_response['policyDocument'] = policy_document return auth_response

def handler(event, context): if 'headers' in event and 'cloudfront-forwarded-proto' in event['headers'] and 'cloudfront-forwarded-port' in event['headers']: print("CloudFront Origin request, allow access") return build_policy('user', 'Allow', event['methodArn']) else: print("Direct API Gateway request, deny access") return build_policy('user', 'Deny', event['methodArn'])

  1. 配置API Gateway的身份验证。

为API Gateway创建一个新的Lambda授权函数,该函数将上面的CFOriginRequest Lambda函数与API网关服务集成。随后,将API Gateway为“API Gateway资源”配置所需的授权方法设置为上方所定义的Lambda授权函数名。

  1. 配置您的CloudFront分发以跨AWS账户访问API Gateway。

为了允许CloudFront分发访问API Gateway,您需要添加允许符合指定域名要求的特定HTTP头的CORS(Cross-Origin Resource Sharing)规则。

在您的CloudFront配置中,找到“Behavior”选项卡,然后选择对应的API Gateway行并单击"Edit"。

在Highlighted Behavior Region中打开"CORS Rules"选项卡,然后按照下面审查好的模板输入跨域规则:

[ { "AllowedHeaders": [ "Authorization", "Content-Type", "X-Amz-Date", "X-Amz-Security-Token", "X-Forwarded-Proto" ], "AllowedMethods": [ "DELETE", "GET", "HEAD", "OPTIONS",

相关内容

热门资讯

安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
避免在粘贴双引号时向VS 20... 在粘贴双引号时向VS 2022添加反斜杠的问题通常是由于编辑器的自动转义功能引起的。为了避免这个问题...
Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
omi系统和安卓系统哪个好,揭... OMI系统和安卓系统哪个好?这个问题就像是在问“苹果和橘子哪个更甜”,每个人都有自己的答案。今天,我...
原生ios和安卓系统,原生对比... 亲爱的读者们,你是否曾好奇过,为什么你的iPhone和安卓手机在操作体验上有着天壤之别?今天,就让我...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...