设置 X-Frame-Options HTTP 响应头防止点击劫持攻击
X-Frame-Options
是一个 HTTP 响应头,设置 X-Frame-Options HTTP 响应头为 DENY 或 SAMEORIGIN,用于控制页面是否可以被嵌入到 <iframe>
, <frame>
, <embed>
, 或 <object>
等元素中。这有助于防止点击劫持攻击。
DENY 或 SAMEORIGIN 分别是什么意思?
-
DENY
:- 当设置为
DENY
时,页面不能被嵌入到任何<iframe>
,<frame>
,<embed>
, 或<object>
中,无论这些元素是在同一个网站上还是在其他网站上。 - 这意味着其他任何网站都不能将此页面嵌入到它们的页面中。
- 例如, 如果
example.com/page
设置了X-Frame-Options: DENY
, 那么无论是example.com
还是other-site.com
, 都不能在其页面中嵌入example.com/page
。
- 当设置为
-
SAMEORIGIN
:- 当设置为
SAMEORIGIN
时, 页面只能被同一源 (origin) 的页面嵌入。 - 这意味着只有与内容相同的协议、域名和端口的页面才能嵌入这个页面。其他所有的外部源都不能嵌入。
- 例如, 如果
example.com/page
设置了X-Frame-Options: SAMEORIGIN
, 那么只有example.com
上的其他页面可以嵌入它。其他域名,如other-site.com
, 不能嵌入这个页面。
- 当设置为
不同服务器或应用框架设置X-Frame-Options的方法
根据您使用的服务器或应用框架,设置 X-Frame-Options
的方法可能会有所不同。以下是一些常见的服务器和框架的设置方法:
1. Apache HTTP Server:
在 .htaccess
文件或 Apache 配置文件中添加以下行:
Header set X-Frame-Options "DENY"
或者,如果你只允许同源页面嵌入:
Header set X-Frame-Options "SAMEORIGIN"
然后重启 Apache 服务器。
2. Nginx:
在 Nginx 配置文件的 server
或 location
区块中添加:
add_header X-Frame-Options "DENY";
或者:
add_header X-Frame-Options "SAMEORIGIN";
然后重启 Nginx。
3. Express (Node.js):
如果您使用的是 Express 框架,可以使用以下代码:
app.use((req, res, next) => { res.setHeader('X-Frame-Options', 'DENY'); next(); });
或者:
app.use((req, res, next) => { res.setHeader('X-Frame-Options', 'SAMEORIGIN'); next(); });
4. Django (Python):
在 Django 的 settings.py
文件中添加或修改以下设置:
X_FRAME_OPTIONS = 'DENY'
或者:
X_FRAME_OPTIONS = 'SAMEORIGIN'
然后,确保 django.middleware.clickjacking.XFrameOptionsMiddleware
中间件已被启用。
5. Flask (Python):
在 Flask 应用中,您可以使用以下代码:
或者:
以上是一些常见的服务器和框架的示例。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示