乐闻世界logo
搜索文章和话题

How do I set the HttpOnly flag of a cookie with javascript?

5 个月前提问
5 个月前修改
浏览次数22

1个答案

1

在JavaScript中,直接设置带有 HttpOnly 标志的 Cookie 并不可行,因为 HttpOnly 旨在阻止 JavaScript 访问标记为 HttpOnly 的 Cookie,以增加安全性,防止跨站脚本攻击(XSS)。HttpOnly 标志必须在服务器端设置。

服务器端设置示例

Node.js(使用 Express.js)

如果你使用的是 Node.js 和 Express.js,可以使用 res.cookie() 方法来设置带有 HttpOnly 标志的 Cookie。

javascript
const express = require('express'); const app = express(); app.get('/', (req, res) => { // 设置 HttpOnly Cookie res.cookie('id', '123456', { httpOnly: true }); res.send('HttpOnly cookie has been set!'); }); app.listen(3000, () => { console.log('Server is running on http://localhost:3000'); });

在这个例子中,当向服务器发送 GET 请求到根目录时,服务器会设置一个名为 id 的 Cookie,其值为 123456,并且设置了 HttpOnly 标志。这意味着这个 Cookie 不能被客户端的 JavaScript 访问。

PHP

在 PHP 中,你可以使用 setcookie 函数来设置带有 HttpOnly 标志的 Cookie。

php
<?php $value = '123456'; setcookie("id", $value, [ 'expires' => time() + 3600, // 1 hour 'path' => '/', 'domain' => '', 'secure' => true, 'httponly' => true, // HttpOnly 设置为 true 'samesite' => 'Lax' // SameSite 设置 ]); echo 'HttpOnly cookie has been set!'; ?>

在这个例子中,httponly 参数被设置为 true,这意味着 Cookie 有 HttpOnly 标志,从而不能被 JavaScript 访问。

总结

虽然你无法使用纯 JavaScript 在客户端直接设置带有 HttpOnly 标志的 Cookie,但你可以通过服务器端脚本来进行设置。这是提升 web 应用安全性的一种常见做法,特别是用于保护敏感信息免受 XSS 攻击。

2024年8月12日 12:52 回复

你的答案