-
然后用户向网站请求包含了恶意 JavaScript脚本的页面
-
当用户浏览该页面的时候,恶意脚本就会将用户的cookie信息等数据上传到服务器
存储型XSS
举一个简单的例子,一个登陆页面,点击登陆的时候,把数据存储在后端,登陆完成之后跳转到首页,首页请求一个接口将当前的用户名显示到页面
客户端代码
登陆
服务端代码
const Koa = require(“koa”);
const app = new Koa();
const route = require(‘koa-route’);
var bodyParser = require(‘koa-bodyparser’);
const cors = require(‘@koa/cors’);
// 临时用一个变量来存储,实际应该存在数据库中
let currentUserName = ‘’;
app.use(bodyParser()); // 处理post请求的参数
const login = ctx => {
const req = ctx.request.body;
const userName = req.userName;
currentUserName = userName;
ctx.response.body = {
msg: ‘登陆成功’
};
}
const home = ctx => {
ctx.body = currentUserName;
}
app.use(cors());
app.use(route.post(‘/login’, login));
app.use(route.get(‘/home’, home));
app.listen(3200, () => {
console.log(‘启动成功’);
});
点击登陆将输入信息提交到服务端,服务端使用变量