基于黑白名单的访问控制
有时候,你需要比身份验证插件提供的更精确的访问控制。例如,你可能希望保留可以访问 API 的消费者白名单。现在,消费者必须发送经过身份验证的请求,并且在白名单上(而且不在黑名单上)才能访问 API。
备注
在实施基于消费者的访问控制之前,请考虑 API 门户 是否是更好的解决方案。
本教程将指导你通过 Consumer Restriction 插件创建消费者白名单来配置精确的访问控制。
前提条件
通过消费者名称限制访问
当消费者发出经过身份验证的请求时,API7 网关会将消费者的名称传递给路由。因此,路由不需要直接访问消费者的凭据,这对用户更加友好。
- 控制台
- ADC
- Ingress Controller
- 从侧边栏选择网关组的 已发布服务,然后选择要配置的服务,例如,版本为
1.0.0
的httpbin API
。 - 从侧边栏选择 插件。
- 搜索
consumer-restriction
插件。 - 点击 加号图标 (+)。
- 在对话框中,执行以下操作:
如果你已按照前提条件教程操作,那么你应该已经拥有一个启用了
key-auth
插件的消费者Alice
。将以下配置添加到JSON 编辑器:{
"whitelist": [
"Alice"
]
}
- 点击 启用。
用同样的方法添加一个新的消费者
Lisa
并使用以下配置启用key-auth
插件。{
"key": "secret-key2"
}
下面的配置启用了 consumer-restriction
插件并创建了一个新的消费者 Lisa
:
adc.yaml
services:
- name: httpbin Service
upstream:
name: default
scheme: http
nodes:
- host: httpbin.org
port: 80
weight: 100
plugins:
consumer-restriction:
_meta:
disable: false
whitelist:
- Alice
key-auth:
_meta:
disable: false
routes:
- uris:
- /ip
name: api-security-ip
methods:
- GET
consumers:
- username: Alice
plugins:
key-auth:
_meta:
disable: false
key: secret-key
- username: Lisa
plugins:
key-auth:
_meta:
disable: false
key: secret-key-2
将配置同步到 API7 网关:
adc sync -f adc.yaml
创建一个 Kubernetes manifest 文件来配置另一个消费者 lisa
:
consumer2.yaml
apiVersion: apisix.apache.org/v2
kind: ApisixConsumer
metadata:
name: lisa
# namespace: api7 # replace with your namespace
spec:
authParameter:
keyAuth:
value:
key: "secret-key2"
对于消费者限制,由于 ApisixService 自定义资源尚不可用,你可以在 ApisixRoute 上配置 consumer-restriction
插件:
httpbin-route.yaml
apiVersion: apisix.apache.org/v2
kind: ApisixRoute
metadata:
name: httpbin-route
# namespace: api7 # replace with your namespace
spec:
http:
- name: httpbin-route
match:
paths:
- /ip
methods:
- GET
backends:
- serviceName: httpbin
servicePort: 80
plugins:
- name: consumer-restriction
enable: true
config:
whitelist:
- alice
将配置应用到你的集群:
kubectl apply -f consumer2.yaml -f httpbin-route.yaml
验证
以消费者 Alice
的身份向服务发起请求:
curl -i "http://127.0.0.1:9080/ip" -H "apikey: secret-key"
你将看到请求成功,并收到 200 OK
响应,因为消费者 Alice
在白名单中。
现在,以新创建的消费者 Lisa 的身份向服务发起请求:
curl -i "http://127.0.0.1:9080/ip" -H "apikey: secret-key2"
你将收到 403 Forbidden
响应,并附带以下请求正文,因为消费者 Lisa 未添加到白名单中:
{"message":"The consumer_name is forbidden."}
相关阅读
- 核心概念
- API 安全
- API 消费