`

前端知识点分享

 
阅读更多
  1. XSS,XFS攻击与防范
    /***The Cross Frame Scripting 缩写为“XFS”也就是说是跨框架的脚本攻击,主要是由于被访问的页面中的frame地址里的变量缺乏检测所导致的漏洞。Cross Frame Scripting主要用于钓鱼攻击,因为该漏洞具备一定的危害性
    
    简单的来说,就是别人发给你一个网站地址,你点击进去,你看到一个熟悉的网站。
    比如说别人告诉你一个网站的短码是某某银行的网站。然后你点击进去啦,看到的还真是银行的界面,然后你输入你的密码,然后就被盗啦。为什么呢。
    ***/
    <frameset onload="this.focus();" onblur="this.focus();" cols="100%" onkeypress="getYourMessage(event);">  
     <frame src="http://xxxx银行的网页/" scrolling="auto">  
    </frameset>  
    
    //进入页面首先给你聚焦,然后你每次按下去一个按钮别人就可以捕捉你输入啦什么。
    
    那么怎么防范呢?
    
    1:防止自己的网站被钓鱼使用,就说检查自己的顶层是否为自己,如果不为自己就进行替换window.top。
    2:这段代码会让异地外域的JS文件在使用document.write()时,被document.close()强制关闭。这个时侯JS挂马的内容往往还没有来得及写完,只有部分被强制输出了,Writer后面的内容再不会被写入访问者的电脑中,从而起到防范JS脚本挂马的作用。
    <style type=”text/css”>
    /*<![CDATA[*/
    iframe{mdy1:expression(this.src='about:blank',this.outerHTML='');}
    script{mzm2:expression((this.src.indexOf('http')==0)?document.close():'');}
    /*]]>*/
    </style>
    

    SS

    攻击:

    跨站脚本攻击

    (Cross Site Scripting)

    XSS攻击:跨站脚本攻击(Cross Site Scripting)
    百度有篇文章讲解的非常详细,建议去看看。见附件
    
    
    
     
  2. 如何优化网站性能

    来自雅虎的军规():
    以下网址解释的比较详细
    http://developer.51cto.com/art/201207/347525.htm
    
    http://www.infoq.com/cn/articles/etags
    
    1.Minimize HTTP Requests 减少HTTP请求
    图片、css、script、flash等等这些都会增加http请求数,减少这些元素的数量就能减少响应时间。把多个JS、CSS在可能的情况下写进一个文件,页面里直接写入图片也是不好的做法,应该写进CSS里,利用 CSS sprites 将小图拼合后利用background来定位。
    2.Use a Content Delivery Network 利用CDN技术
    CDN 确实是好东西,8过服务器提供商的这项服务一般是要收费的,我以前买的国内空间是有这个的但是我当时根本不知道啥用,现在没了。。。
    3.Add an Expires or a Cache-Control Header 设置头文件过期或者静态缓存
    浏览器会用缓存来减少http请求数来加快页面加载的时间,如果页面头部加一个很长的过期时间,浏览器就会一直缓存页面里的元素。不过这样如果 页面里的东西变动的话就要改名字了,否则用户端不会主动刷新,看自己衡量了~ 这项可以通过修改.htaccess文件来实现。
    4.Gzip Components Gzip压缩
    Gzip格式是一种很普遍的压缩技术,几乎所有的浏览器都有解压Gzip格式的能力,而且它可以压缩的比例非常大,一般压缩率为85%。压缩没压缩,可以到 这里 做下测试。
    5.Put Stylesheets at the Top 把CSS放顶部
    让浏览者能尽早的看到网站的完整样式。
    6.Put Scripts at the Bottom 把JS放底部
    网站呈现完毕后再进行功能设置,当然这些JS要在你的加载过程中不影响内容表现。
    7.Avoid CSS Expressions 避免CSS Expressions
    CSS表达式很可怕,这个只被IE支持的东西执行时候的运算量非常大,你移动一下鼠标它都要进行重计算的,但有时候为了做浏览器的兼容必须要用到这个||| IE6去死去死!~
    8.Make JavaScript and CSS External 将JS和CSS外链
    前面讲到了缓存这个事情,一些较为公用的JS和CSS,我们可以使用外链的形式,譬如我就是从Google外链来的Jquery文件,如果我的浏览者在浏览别的使用了这个外链文件的网站时已经下载并缓存了这个文件,那么他在浏览我的网站的时候就不需要再进行下载了!~
    9.Reduce DNS Lookups 减少DNS查找
    貌似是要减少网站从外部调用资源,我的Google分析和picasa的外链图片都算在里面了。
    10.Minify JavaScript and CSS 减小JS和CSS的体积
    写JS和CSS都是有技巧的,用最少的代码实现同样的功能,减少空白,增强逻辑性,用缩写方式等等,当然也有不少工具也能够帮你实现这一点。
    11. Avoid Redirects 避免重定向
    再写入链接时,虽然”http://www. today-s-ooxx. com”和”http://www. today-s-ooxx. com/” 仅有一个最后的”/”只差,但是结果是不同的,服务器需要花时间把前者重定向为后者然后进行跳转,这个要自己注意,也可以在Apache里用Alias 或者mod_rewrite或者DirectorySlash解决。
    12. Remove Duplicate Scripts 删除重复脚本
    重复调用的代码浏览器并不会识别忽略,而是会再次运算一遍,这当然是大大的浪费。
    13. Configure ETags 配置ETags
    搞不清楚咋回事,总之我是在. htaccess里把它删除了。
    14. Make Ajax Cacheable 缓存Ajax
    Ajax是实时响应的,在浏览器接收到新的数据前,旧的数据被缓存,这样能够更好的提高效率。
    15. Flush the Buffer Early 尽早的释放缓冲
    当用户进行页面请求时,服务器端需要花费200到500毫秒时间来拼合HTML,将写在head与body之间,释放缓冲,这样可以将文件头先发送出去,然后再发送文件内容,提高效率。
    16. Use GET for AJAX Requests 用GET方式进行AJAX请求
    Get 方法和服务器只有一次交互(发送数据),而 Post 要两次(发送头部再发送数据)。
    17. Post-load Components 延迟加载组件
    最先加载必须的组件进行页面初始化,然后再加载其他,YUI Image Loader 是很好的例子。
    18. Preload components 预加载组件
    提前加载以后可能用到的东西,和延迟加载并不冲突,它的目的是为后续请求提供更快的响应,参见Google首页上的CSS sprites应用。
    19. Reduce the Number of DOM Elements 减少DOM元素数量
    复杂的页面结构意味着更长的下载及响应时间,更合理更高效的使用标签来架构页面,是好的前端的必备条件。
    20. Split Components Across Domains 跨域分离组件
    页面组件多个来源可以增大你的平行下载量,但注意不要过多,超过2-4个域名会引起上面说到的DNS查找浪费。
    21. Minimize the Number of iframes 减少iframe数量
    需要更有效的利用 ifames。
    iframe 优点:有利于下载缓慢的广告等第三方内容,安全沙箱,并行下载脚本
    iframe 缺点:即使为空也会有较大资源消耗,会阻止页面的onload,非语义
    22. No 404s 不要出现404页面
    站点本身里(非搜索结果)出现404页面,无意义的404页面会影响用户体验并且会消耗服务器资源。
    23. Reduce Cookie Size 减小Cookie
    Cookie在服务器及浏览器之间的通过文件头进行交换,尽可能减小Cookie体积,设置合理的过期时间,能够很好的提高效率。
    24. Use Cookie-free Domains for Components 对组件使用无Cookie的域名
    对静态组件的Cookie读取是一种浪费,使用另一个无Cookie的域名来存放你的静态组件式一个好方法,或者也可以在Cookie中只存放带www的域名。
    25. Minimize DOM Access 减少DOM的访问次数
    JS访问DOM是很慢的,尽量不要用JS来设置页面布局。
    26. Develop Smart Event Handlers 开发灵活的事件处理句柄
    DOM树上过多的元素被加入事件句柄的话,反应效率肯定会低,YUI事件工具有一个 onAvailable 方法可以帮助你灵活的设置DOM事件句柄
    27. Choose < link >over @import 使用< link >而非 @import
    在IE中使用@import就和在页面底部用< link >一样,我们前面说要把< link >放顶部的。
    28. Avoid Filters 避免过滤器的使用
    如果需要Alpha透明,不要使用AlphaImageLoader,它效率低下而且只对IE6及以下的版本适用,用PNG8图片。如果你非要使用,加上_filter以免影响IE7+用户。
    29. Optimize Images 优化图片
    将你的GIF转为PNG8会是个减小体积的好办法,另外有很多方法处理你的JPG及PNG图片以达到优化效果。
    30. Optimize CSS Sprites 优化CSS Sprites
    在CSS Sprites中竖直并尽量紧凑的排列图片,尽量将颜色相似的图片排在一起,会减小图片本身的大小及提高页面图片显示速度。
    31. Don’t Scale Images in HTML 不要在HTML中缩放图片
    图片要用多大的就用多大的,1000X1000的图片被width=”100″ height=”100″以后,本身的KB数是不会减少的。
    32. Make favicon. ico Small and Cacheable 缩小favicon. ico的大小并缓存它
    站点的浏览器ICO应该不是经常换吧,那就长时间的缓存它,并且最好控制在1K以下。
    33. Keep Components under 25K 保证组件在25K以下
    iPhone不能缓存25K以上的组件,并且这还是要在被压缩前。
    34. Pack Components into a Multipart Document 将组件打包进一个多部分的文档中
    就好像在邮件中加入附件一样,一个HTTP请求就够了,但是这一技术需要确保你的代理支持,iPhone就不支持。
    
    再加一点个人丛代码上的考虑
    
    1:尽量少用全局变量,js作用域链查询机制
    2:缓存DOM访问节点
    
    

     

  3. 丛输入网址到显示的过程是怎样,详细见附件。

    先睡觉啦。。。。
分享到:
评论

相关推荐

    最新的web前端学习线路图(知识点+配套视频教程)

    分享最新的web前端学习线路图里面包含了全部的知识点,另外还有配套视频教程,希望大家能学好web前端。

    前端基础知识分享案例代码

    在IT行业中,前端开发是构建互联网应用不可...通过学习和分析这些案例,你可以更好地理解上述知识点,并逐步提升自己的前端开发技能。记住,理论结合实践是学习前端开发的关键,动手编写代码和调试问题能加速你的成长。

    考试类精品--前端增长,知识图谱课件,没事盘他。从面试考察的知识点入手,梳理前端知识点脉络,精讲各个点的长问问题和设.zip

    本课程“考试类精品--前端增长,知识图谱课件,没事盘他”就是针对这一需求,从面试常考知识点出发,系统地梳理前端知识体系,并深入讲解每个关键点的常见问题与设计思路。 课程内容涵盖以下几个核心领域: 1. ...

    前端笔试题分享 前端面试pdf.pdf

    本资源为前端笔试题分享,涵盖了JavaScript基础、前端web前端相关知识点,以下是从给定的文件中生成的相关知识点: 一、JavaScript基础 1. 手写Object.create思路:将传入的对象作为原型,通过创建一个新的构造...

    面经2022-23年收集前端知识点面试题目含各大厂面经和收集的原题

    面经2022-23年收集前端知识点面试题目含各大厂面经和收集的原题提取方式是百度网盘分享地址

    ava开发者文档,分享日常学习的一些小知识点 前端,后端,测试,运维等.zip

    一、前端知识点 前端开发主要关注用户交互和界面设计。Java在前端的应用虽然不如JavaScript常见,但仍然有如GWT(Google Web Toolkit)这样的框架,允许开发者用Java编写前端代码。学习内容可能包括HTML、CSS、...

    Java开发者文档,分享日常学习的一些小知识点 前端,后端,测试,运维等

    Java开发者文档,分享日常学习的一些小知识点。 前端,后端,测试,运维等。

    前端面试题实用知识库分享知识分享

    这里我们深入探讨一些常见的前端面试知识点。 **HTML5相关面试题**: 1. **H5新特性**:HTML5引入了许多新特性,包括拖放功能、语义化标签(如, , 等)、离线存储(Application Cache)、媒体元素(, )、画布...

    自己写的前端小知识分享文案

    七、其他知识点 * 生命周期和钩子函数:在 Vue.js 中,每个组件都有其生命周期钩子函数,例如 mounted()、beforeDestroy() 等,可以在特定的时刻执行特定的任务。 * 插件的引入和使用:在 Vue.js 中,可以使用插件...

    前端笔记全套分享一学期

    在本套"前端笔记全套分享一学期"中,我们涵盖了前端开发领域的众多核心知识点,旨在帮助学习者系统地掌握前端开发的基本技能,并逐步提升至专业水平。以下是对这些笔记内容的详细解读: 1. **HTML基础**:HTML...

    前端资料分享,欢迎下载。

    以下是对这份资料可能包含的一些核心知识点的详细说明: 1. HTML(HyperText Markup Language):HTML是构成网页的基础语言,用于定义页面结构和内容。学习HTML将涉及基本标签、语义化元素、表格、图像、链接等知识...

    大厂前端高频面试题分享

    ## 前端技术知识点 ### HTML相关知识点 - HTML5新增的内容:包括新增的语义化标签(例如`&lt;section&gt;`、`&lt;article&gt;`、`&lt;nav&gt;`等),以及与多媒体、绘图相关的标签和API(例如`&lt;video&gt;`、`&lt;audio&gt;`、Canvas API)。 -...

    前端知识图谱+B站资源整合 V1.0版本

    下面我们将深入探讨其中涉及的前端知识点和B站资源整合的价值。 首先,知识图谱是这个项目的核心部分,它以图形化的方式展示了前端开发领域的各个知识点和它们之间的关系。这样的图谱通常包含HTML、CSS、JavaScript...

    基于Javascript和前端知识的日语就业信息库探索.pdf

    基于 Javascript 和前端知识的日语就业...本文探索了基于 Javascript 和前端知识的日语就业信息库的设计和实现,并讨论了信息库的搜索和检索、就业相关内容的规划、数据库的设计和实现、SQL 注入的防止等方面的知识点。

    WEB前端工程师Web前端性能优化经验分享

    综合以上四点,Web前端工程师在进行性能优化时,不仅需要理解这些知识点,而且要在实际工作中灵活运用。例如,在设计Web页面时,应考虑到HTTP请求的数量,在资源加载时尽可能合并文件,并使用懒加载技术来优化图片的...

    Web前端PPT课件.pptx

    Web 前端 PPT 课件知识点总结 本资源摘要信息涵盖了 Web 前端 PPT 课件的主要知识点,包括 CSS 的基础知识、选择器、继承特性、层叠特性、页面基本设置、样式表、网页风格设计等。 1. CSS 的基础知识 CSS 是一种...

    VUE3前端开发技术分享

    VUE3 前端开发技术分享 VUE3 是一种流行的前端开发框架,具有强大的响应式系统、灵活的组件式编程、优秀的性能和小巧的打包大小等特点。下面是 VUE3 的一些关键知识点: 前端发展历程 在前端发展的早期,网站的...

Global site tag (gtag.js) - Google Analytics