解决博客回复区被脚本注入的问题

我的博客回复区被注入脚本,导致评论下边的回复都是脚本和混乱字符,应该是别人注入脚本攻击的。

解决这个问题分三步走:

1  web层调用js判断页面是否为已登录状态

2  在回复请求发送给服务器的同时携带token或者cookie

3   服务器也要加上判断,判断请求是否合法

4   清楚被脚本注入的垃圾评论

目前先将第一个实现了,2,3留作以后不忙的时候补充即可。

那么下面要修正的问题是被污染的回复,我的回复和评论写在一张评论表里,评论和回复的不同之处在于评论的parent字段是文章id,而回复的parent字段则是其父节点评论id,评论和回复都有一个字段是artid,表示所属文章id。

所以根据这个思路只要在评论表里找出那些artid和parent不相等的条目即可。

mongodb比较两个字段是否相等可以通过如下代码

db.comments.find({$where:"this.parent !=this.artid"})

所以批量删除就很简单了

db.comments.deleteMany({$where:"this.parent !=this.artid"})

所以,以后我们为了防止脚本注入,一定要验证输入来源的合法性,并且过滤其中的脚本信息等。服务器也要增加验证。

热门评论
  • secondtonone1
    2022-06-01 12:39:56

    走到现在我忽然明白一个道理,无论工作也好生活也罢,最重要的是开心,即使一份安稳的工作不能给我带来事业上的积累也要合理的舍弃,所以我还是想去做喜欢的方向。

热门文章

  1. Linux环境搭建和编码

    喜欢(594) 浏览(15573)
  2. 使用hexo搭建个人博客

    喜欢(533) 浏览(13915)
  3. MarkDown在线编辑器

    喜欢(514) 浏览(15823)
  4. vscode搭建windows C++开发环境

    喜欢(596) 浏览(98126)
  5. 聊天项目(28) 分布式服务通知好友申请

    喜欢(507) 浏览(7160)

最新评论

  1. 无锁并发队列 TenThousandOne:_head  和 _tail  替换为原子变量。那里pop的逻辑,val = _data[h] 可以移到循环外面吗
  2. 解决博客回复区被脚本注入的问题 secondtonone1:走到现在我忽然明白一个道理,无论工作也好生活也罢,最重要的是开心,即使一份安稳的工作不能给我带来事业上的积累也要合理的舍弃,所以我还是想去做喜欢的方向。
  3. 处理网络粘包问题 zyouth: //消息的长度小于头部规定的长度,说明数据未收全,则先将部分消息放到接收节点里 if (bytes_transferred < data_len) { memcpy(_recv_msg_node->_data + _recv_msg_node->_cur_len, _data + copy_len, bytes_transferred); _recv_msg_node->_cur_len += bytes_transferred; ::memset(_data, 0, MAX_LENGTH); _socket.async_read_some(boost::asio::buffer(_data, MAX_LENGTH), std::bind(&CSession::HandleRead, this, std::placeholders::_1, std::placeholders::_2, shared_self)); //头部处理完成 _b_head_parse = true; return; } 把_b_head_parse = true;放在_socket.async_read_some前面是不是更好
  4. C++ 线程池原理和实现 mzx2023:两种方法解决,一种是改排序算法,就是当线程耗尽的时候,使用普通递归,另一种是当在线程池commit的时候,判断线程是否耗尽,耗尽的话就直接当前线程执行task
  5. 利用指针和容器实现文本查询 越今朝:应该添加一个过滤功能以解决部分单词无法被查询的问题: eg: "I am a teacher."中的teacher无法被查询,因为在示例代码中teacher.被解释为一个单词从而忽略了teacher本身。

个人公众号

个人微信