每个程序员都应该了解的知识有哪些?

jopen 11年前

 英文链接:What should every programmer know about web development?

  以下内容来自于 Stack Overflow 的一个问答中,此问题的答案整理的非常的详细,且颇具启发性,整理出来和大家一起分享。由于英语不是很好,如果自身英语成绩比较好的,可以看原文。

  问题:那些技术细节是需要程序员把站点开发给公众之前考虑的?像 Jeff Atwood(Stack Overflow 创始人)这样的都可以忘了使用 HttpOnly cookies, sitemapscross-site request forgeries,还有哪些可能被遗忘的重要内容?

  答案:从一个 Web 开发者的角度来看,网站的可用性和内容相比平台的稳定性、性能、安全或者被搜索引擎收录更加重要,开发人员需要保证的是做出来的网站不要太烂。以下是一些应该注意的点。

  界面和用户体验

  1、注意浏览器的实现标准上的不一致,确信让你的网站能够适当地跨浏览器。至少,你的网站需要测试一下下面的浏览器:

  最后,你可以使用一下这个工具 来看看你的网页在不同的浏览器下是怎么被显示出来的(陈皓注:这个工具就是以前本站介绍过的在不同浏览器和平台上检查你的网站的兼容性

  2、除了浏览器,网站还有其他使用方式:手机、屏幕朗读器、搜索引擎等等。你应该知道在这些情况下,你的网站的运行状况。例如:一些 Accessibility 的东西: WAISection508。移动设备开发:MobiForge

  3、知道如何在基本不影响用户使用的情况下升级网站。通常来说,你必须有版本控制系统(CVS、Subversion、Git 等等)和数据备份机制(backup)。 Ed Lucas 的答案 可以让你了解一些(陈皓注:Ed 说了一些如版本控制,自动化 build (Ant, NAnt 等), ,备份,回滚等机制)

  4、千万不要直接给用户显示不友好的错误信息。

  5、千万不要把用户的邮件地址以明文显示出来,这样会被爬虫爬走并被让用户的邮箱被垃圾邮件搞死。

  6、为用户的链接加上 rel="nofollow" 的属性以 避免垃圾网站的干扰。(nofollow是 HTML 的一个属性,用于通知搜索引擎“这个链接所指向的网页非我所能控制,对其内容不予置评”,或者简单地说,该链接不是对目标网站或网页的“投票”,这样搜索引擎不会再访问这个链接。这个是用来减少一些特定垃圾页面对原网站的影响,从而可以改善搜索结果的质量,并且防止垃圾链接的蔓延。)

  7、为网站建立一些的限制 - 这个属于安全性的范畴。(比如你在 Google 注册邮箱时,你一口气注册超过两个以上的邮箱,gmail 要求给你发短信或是给你打电话认证,比如 Discuz 论坛的会限制你发贴或是搜索的间隔时间等等,更多的网站会用 CAPTCHA 来确认是人为的操作。 这些限制都是为了防止垃圾和恶意攻击)

  8、学习如何做 Progressive Enhancement. (Progressive Enhancement 是一个 Web Design 的理念,如:1)基础的内容和功能应该可以被所有的浏览器存取,2)页面布局的应该使用外部的 CSS 链接,3)Javascript 也应该是外部链接还应该是 unobtrusive 的,4)应该让用户可以设置他们的偏好)

  9、如果 POST 成功,要在 POST 方法后重定向网址,这样可以阻止用户通过刷新页面重复提交。

  10、严重关注 Accessibility。因为这是法律上的需求(Section 508 是美国的 508 法案,其是美国劳工复健法的改进,它是一部联邦法律,这个法律要求所有技术要考虑到残障人士的应用,如果某个大众信息传播网站,如果某些用户群体(如残疾人)浏览该网站获取信息时,如果他们无法正常获得所期望的信息(如无法正常浏览),那可以依据相关法规,可以对该网站依法起诉)。 WAI-ARIA 为这方面的事提供很不错的资源。

  安全

  1、在网上有很多关于安全的文章,但是 《OWASP 开发指南》 涵盖了几乎所有关于 Web 站点安全的东西。(OWASP (开放 Web 应用安全项目- Open Web Application Security Project)是一个开放的非营利性组织,目前全球有 130 个分会近万名会员,其主要目标是研议协助解决 Web 软体安全之标准、工具与技术文件,长期致力于协助政府或企业了解并改善网页应用程式与网页服务的安全性。OWASP 被视为 Web 应用安全领域的权威参考。2009 年下列发布的美国国家和国际立法、标准、准则、委员会和行业实务守则参考引用了 OWASP。美国联邦贸易委员会(FTC)强烈建议所有企业需遵循 OWASP 十大 WEB 弱点防护守则。

  2、了解什么是 SQL 注入攻击 并知道怎么阻止这种攻击。

  3、永远不要相信用户的输入(包括 Cookies,因为那也是用户的输入)

  4、对用户的口令进行 Hash,并使用 salt,以防止 Rainbow 攻击。使用慢一点的 Hash 算法来保存口令,如 bcrypt (被时间检证过了) 或是 scrypt (更强,但是也更新一些) (1, 2)。你可以阅读一下 How To Safely Store A Password。The NIST 建议使用 PBKDF2 to hash passwords, 并且 FIPS approved in .NET (具体什么意思我还是不太清楚,大家可以看这里的介绍 here)。避免直接使用 MD5 或 SHA。

  5、不要试图自己去发明或创造一个自己的 fancy 的认证系统,你可能会忽略到一些不容易让你查觉的东西而导致你的站点被 hack 了。(陈皓注:我在腾讯那坑爹的申诉系统中说过这个事了,我说过这句话——“真正的安全系统是协同整个社会的安全系统做出来的一道安全长城,而不是什么都要自己搞”,当然,很遗憾不是所有的人都能看懂这个事,包括一些资深的人)

  6、了解 处理信用卡的一些规则 . (这里也有一个问题你可以查看一下) (有两上 vendor 可以帮助你,一个是 Authorize.Net 另一个是 PayFlow Pro

  7、使用 SSL/HTTPS 来加密传输登录页面或是任可有敏感信息的页面,比如信用卡号等。

  8、知道如何对付 session 劫持。(请参看 wikipedia 的这 Session Hijacking,)

  9、避免 跨站脚本攻击(XSS)。

  10、避免 跨站伪造请求攻击 cross site request forgeries (XSRF).

  11、保持你的系统里的所有软件更新到最新的 patch。

  12、确保你的数据库连接是安全的。

  13、确保你能了解最新的攻击技术,以及你系统的脆弱处。

  14、阅读 Google 的《浏览器安全手册》(Browser Security Handbook)。

  15、阅读《网络软件的黑客手册》(The Web Application Hackers Handbook)。

  性能

  1、只要有机会,就使用缓存机制,了解并合理地使用 HTTP caching 以及 HTML5 Manifest

  2、优化图片使用 ,不要把一个 20KB 的图片文件,作为重复出现的网页背景图案。 不要使用 20KB 图片来平铺网页背景。

  3、学习如何用 gzip/deflate 压缩内容(deflate 方式更可取)。

  4、将多个样式表文件或脚本文件,合为一个文件,这样可以减少浏览器的 http 网络连接数,以及减小 gzip 压缩后的文件总体积。

  5、学习一下 Yahoo Exceptional Performance 这个网站上的东西,上面有很多非常不错的改善前端性能的指导,以及 YSlow 这个工具。 Google page speed 是另一个用来做性能采样的工具。这两个工具都需要安装 Firebug

  6、如果你的网页用到大量的小体积图片(比如工具栏),就应该使用 CSS Image Sprite,目的是减少 http 请求数。

  7、大流量的网站应该考虑将网页对象分散在多个域名。(比如有专门的图片服务器——图片相当耗带宽,或是专门的 Ajax 服务器)

  8、静态内容(比如图片、CSS、JavaScript、以及其他 cookie 无关的网页内容)都应该放在一个不需要使用 cookie 的独立域名之上。因为域名之下如果有 cookie,那么客户端向该域名发出的每次 http 请求,都会附上 cookie 内容。这里的一个好方法就是使用”内容分发网络”(Content Delivery Network,CDN)。

  9、使用单个页面的 HTTP 请求数最小化。

  10、使用 Google 的 Closure Compiler 压缩 JavaScript 文件,YUI Compressor 亦可。或是 其它压缩工具。(Google 的这个工具甚至还可以帮你优化你的代码)

  11、确保网站根目录下有 favicon.ico 文件,因为即使网页中根本不包括这个文件,浏览器也会自动发出对它的请求。所以如果这个文件不存在,就会产生大量的 404 错误,消耗光你的服务器的带宽。(服务器返回 404 页面会比这个 ico 文件可能还大)

  SEO(搜索引擎优化)

  1、使用 “搜索引擎喜欢的” URL,如:使用 example.com/pages/45-article-title 而不是 example.com/index.php?page=45

  2、如果你的动态页面要使用 # ,那么请把其改成 #! ,而在服务端,你需要处理$_REQUEST["_escaped_fragment_"] 这是 Google 搜索引擎需要的。换句话说,./#!page=1 会被 Google 搜索引擎转成 ./?_escaped_fragments_=page=1。 (陈皓注:通常来说 URL 中的#后的东西都不会被传到服务器上,所以,为了要让 Google 可以抓取 AJAX 的东西,你需要使用#!,而 Google 会把“#!”转成“_escaped_fragment_”来向服务器发请求,推ter 的大量的链接者是#!的,比如:https://推ter.com/#!/your_activity)。另外,用户也许会使用 Firefox 或 Chromium, history.pushState ({"foo":"bar"}, "About", "./?page=1"); 是一个很不错的命令。所以,就算是我们的地址栏上的地址改变了,页面也不会重新装载。这可以让你使用 ? 而不是 #! 也能无刷地保住当前的动态的页面,这可以让 AJAX 的请求被浏览器记住。

  3、不要使用”点击这里”之类的超级链接,因为这样等于浪费了一个 SEO 机会,而且降低了”屏幕朗读器”(screen reader)的使用效果。

  4、创建一个 XML sitemap 文件,它的缺省位置一般是/sitemap.xml(即放在网站根目录下)。(这个文件可以让搜索引擎了解你的网站地图)

  5、当你有多个 URL 指向同一个内容时,在网页代码中使用<link rel=”canonical” … />。可以使用 Google Webmaster Tools 来查看相关的问题。

  6、使用 Google 的 Webmaster Tools 和 Yahoo 的 Site Explorer

  7、从一开始就使用 Google Analytics(或者开源的访问量分析工具 Piwik)。

  8、了解 robots.txt 和搜索引擎爬虫是如何工作的。

  9、重定向请求 (使用 301 重定向网站) ,如果你要把 www.example.com 定向到 example.com(或是其它的变更) 这样可以防止 Google 的 rank 因为域名的变化发生改变。

  10、知道并不是所有的爬虫都是好的,有些爬虫的行为并不好。(比如向你的网站发大量的请求导致服务器性能低下)

  11、如果你的网站有非文本的内容(比如视频、音频等等),你应该参考 Google 的 sitemap 扩展协议Tim Farley 的答案,可以让你看到很多有价值的东西。

  技术

  1、理解 HTTP 协议,以及诸如 GET、POST、sessions、cookies 之类的概念,包括”无状态”(stateless)是什么意思。

  2、让你的 XHTML/HTMLCSS 符合 W3C 规范,使得它们能够通过检验。这可以使你的网页避免触发浏览器的古怪行为(quirks mode),并且可以让其更容易地能和非标准的浏览器工作,比如读屏器或移动设备。

  3、理解浏览器是怎么处理 JavaScript 的。

  4、理解网页上的 JavaScript 文件、样式表文件和其他资源是如何装载及运行的,考虑它们对页面性能有何影响。在某些情况下,可能应该将脚本文件放置在网页的尾部

  5、理解 JavaScript 沙箱(Javascript sandbox)的工作原理,尤其是如果你打算使用 iframe。

  6、请注意 JavaScript 可能会被禁止,这样会让你的 AJAX 失效。就算是大多数用户都开启了 Javascript 功能,但是也可能在一些情况下脚本是不被运行的,比如移动终端上,搜索引擎抓网页的时候也并不会执行你的脚本。

  7、了解 301 重定向和 302 重定向之间的区别(这也是一个 SEO 相关问题)。

  8、尽可能多地学习你的部署平台。(比如:操作系统,Web Server:Apache/Nginx,防火墙,数据库,等等)

  9、考虑使用样式表重置(Reset Style Sheet)。

  10、考虑使用 JavaScript 框架(比如 jQueryMooToolsPrototype),它们可以使你不用考虑浏览器之间的差异。

  11、把视觉效果和 JS 框架合在一起讨论,考虑使用一个 Service,如:Google Libraries API 来装载框架,这样可以让浏览器可能早就把这个 JS 框架已经 cache 了而不需要再从你的网站上下载了。

  12、不要重新发明轮子。在做任何事之前寻找一个现有组件或例子。你有 99% 的机会找到别人已经发布的开源版本。

  13、不要一开始就做非常多的功能和组件,特别是在客户端的 Web 上,你需要保持系统是轻量级,快速,灵活的。

  Bug 修复

  1、明白你会花 20% 的时间写代码,而 80% 的时候在维护,所以你要小心编码。

  2、建立一个有效的错误报告机制。

  3、建立某些途径或系统,让用户可以与你接触,向你提出建议和批评。

  4、为你开发的东西形成文档,解释清楚系统是怎么运行的,这样可以让后来的人容易维护你的软件和系统。

  5、频繁备份(也可确保你的这些备份功能正常) Ed Lucas 的回答 有一些忠告。你还需要有一个恢复策略,而不只是一个备份策略。

  6、使用一个版本控制系统来保存你的代码,如: SubversionGit.

  7、别忘了做 Acceptance Testing,使用 Selenium 能帮到你。

  8、确保你有足够的日志,你可以使用 log4j, log4net 或者 log4r.。如果出了问题,这是可以让你快速找到问题的方式。

  9、当你写日志的时候,确保你记录了你捕获了处理和未处理异常。报告和分析日志可以让你知道你网站的问题。

  这里有多的东西被省略了,并不是因为那些可能不是有帮助的答案,而是因为那些东西都太细节了,超出了这个问题的范围,因为这本来就是一个 Web 开发需要了解东西的 Overview。