XSS(Cross Site Scripting)攻击全称跨站脚本攻击。
它与 CSS(Cascading Style Sheets)没什么关系,避免缩写混淆。
XSS 是一种在 web 应用中的常见的安全漏洞,恶意将代码植入到提供给其它用户使用的页面。
XSS 漏洞和著名的 SQL 注入漏洞一样,都是利用了 Web 页面的编写不完善,向后端发起了脚本请求。
XSS 攻击在前端部分只能预防,实际需要后端同步配合处理。
不能以单一特征来概括所有XSS攻击。
常见的防御 XSS 攻击是通过前后台校验的方式禁止不合法的攻击脚本传入产生攻击行为。
前端界面一般通过字段校验来限制用户输入特殊符号。
但实际上我们有些字段是支持特殊符号的传入,那么单纯通过校验规则无法避免这类攻击。
如何判定你的界面是会受到XSS攻击呢?
当你定义某个字段值为一段JS脚本的时候,当这个字段在界面上展示的时候,如果能够被触发则说明你的界面能够被 XSS 攻击。
界面有个用户名选择按钮,点击后在弹出层选择一条用户记录。
该记录的用户名为:
<script>alert('XSS');</script>
选择确认后,用户名被展示在用户名字段后面(不可编辑)。
但此时你点击这用户名的时候,发现会触发弹窗 "XSS" ,由于这个字段的 script 脚本生效了。
如果用户通过注入其他的 script 脚本,比如 ajax 请求向服务端发数据。
前端防御XSS攻击只需要关注一个点。
所以我们需要定义公共的字段编解码方法。
// 编码,用于展示界面或编码向后端传递
function htmlEncode(HtmlString)
{
var str = HtmlString;
if(HtmlString != null && typeof (HtmlString) === "string")
{
HtmlString.replace(/&/g,"&");
str = str.replace(/</g,"<");
str = str.replace(/>/g,">");
str = str.replace(/"/g,""");
str = str.replace(/'/g,"'");
str = str.replace(/(/g,"(");
str = str.replace(/)/g,")");
str = str.replace(/%/g,"%");
str = str.replace(/+/g,"+");
str = str.replace(/,/g,",");
}
return str;
}
// 解码,用于获取字段真实值放入input框等
function htmlDecode(HtmlString)
{
var str = HtmlString;
if(HtmlString != null && typeof (HtmlString) === "string")
{
str = HtmlString.replace(/&/g,"&");
str = str.replace(/</g,"<");
str = str.replace(/>/g,">");
str = str.replace(/"/g,""");
str = str.replace(/'/g,"'");
str = str.replace(/(/g,"(");
str = str.replace(/)/g,")");
str = str.replace(/%/g,"%");
str = str.replace(/+/g,"+");
str = str.replace(/,/g,",");
}
return str;
}
//实际使用直接调用即可
//如上文攻击实例过程中,我们可以对用户名进行编码展示htmlEncode(userName)
实际上,防御 XSS 最好的方式是后端处理。
当前还没有观点发布,欢迎您留下足迹!
严谨的页面开发需要着重关注前台校验相关的内容,确保请求参数的合法以保证服务器安全,界面参数众多需要建立一个公共方法,公共校验器的核心方法是Jquery.bind()
HTML 中加载 SVG 有很多种方式,但如果需要在 HTML 中通过 CSS 样式自由控制 SVG 样式就必须将 svg 标签插入网页找那个成为 DOM 的一部分,本文借助 SVGInject 插件可以快速完成这一操作
多数网站首页的数据往往是最庞大的,三到五秒打开都算比较优秀,因此设置一个开场(预加载)动画特效能够大幅度提升用户感官体验,这里分享本站使用的加载动画,整体比较简约清新
Vuex 是一个专为 Vue 应用程序开发的状态管理模式,通过集中式存储应用所有组件的状态,依照规则确保状态可以进行标准方式变化,比较适合应用在公共基础数据存放,如:用户信息
instantclick.js利用预加载技术使得网站页面跳转时的速度得到大大提升,通过预加载数据替换当前的DOM结构体来达到减少页面请求返回的数据量,提供事件监听钩子函数便于完成页面初始化
在业务中我们会出现不同的项目依赖与不同版本的 node.js,总不能每次跑项目的时候都去重新安装对应版本的 node.js 和依赖,使用 nvm 可以让多个版本的 node.js 共存,并提供管理和切换