一个标准的web应用目录结构如下:
静态web资源和jsp可以放到web应用的根目录下,web应用根目录下的资源,浏览器可以直接访问到。
存放web应用程序需要用到的jar文件,一般工程所需的其他包都放在lib下。
整个web应用的核心配置文件,用来供web容器部署和执行web应用。
web.xml不是必须的,一个web工程可以没有web.xml文件。
脚本语言是一种介乎于HTML和JAVA等编程语言只爱你的一种特殊语言。常见的脚本语言可分为静态脚本语言和动态脚本语言:
静态脚本语言:html
动态脚本语言:asp(逐步在淘汰,常见于小站点)、aspx、php(目前比较流行)、jsp
ASP全名ActiveServerPages,是MicroSoft公司开发的服务器端脚本环境,是一个WEB服务器端的开发环境,利用它可以产生和执行动态的、互动的、高性能的WEB服务应用程序。
1)IIS(internet information server)是支持ASP运行的平台。
2)ASP采用脚本语言VBScript(Javascript)作为自己的开发语言。
3)ASP文件与HTML文件类似,包含文本、HTML、脚本。
4)ASP文件中的脚本可在服务器上执行,ASP文件后缀名是 .asp。
ASP与HTML的区别:
- 当浏览器请求某个HTML文件时,服务器就会访问这个文件;
- 当浏览器请求某个ASP文件时,IIS会将这个请求传递给ASP引擎。ASP引擎会逐行读取这个ASP文件,并执行文件中的脚本。最后,ASP文件将以纯HTML的形式返回浏览器。
当浏览器请求 ASP.NET 文件时,ASP.NET 引擎读取文件,编译和执行脚本文件,并将结果以普通的 HTML 页面返回给浏览器。
根据数据包中传递的cookie值,比如PHP使用的会话ID是PHPSESSID,JSP使用的会话ID是JSESSION。下面网站使用的脚本语言为JSP。
有时候网站的响应包会携带Server信息,Server表示Web服务器的版本。
另外需要注意以下字段:
- X-Powered-By:Web应用框架信息。
- IIS6.0,一般是ASP,少部分是ASP.NET,也有少部分是php;
- IIS7.0,一般是ASP.NET,少部分是ASP;
- Nginx,一般为php,也有可能是python;
- Apache,一般都是php;
- Tomat、Resin、JBoss一般是JAVA;
- inurl:返回url中含有关键词的网页。例如:inurl:xxx 将返回url中含有XXX的网页。
- site:指定访问的站点。例如 site:xxx.com inurl:AAA 将只在xxx.com中查找url中含有AAA的网页。
1)构造畸形请求,让网站报错;
2)通过识别目录、指纹等信息,来识别CMS框架(框架知道了,所用的脚本语言也就知道了);
3)分析某些html中的链接,以及ajax技术中会请求的地址;
4)在网站后面加特殊域名,网站能正常打开,说明网站就是用该语言写的(也有特殊情况)
特殊域名:
index.php、idnex.asp、index.jsp、index.aspx、defualt.php、defualt.asp、default.jsp、default.aspx
4)用正则去匹配HTML代码,找出其中的copyright(版权信息)、powered by(技术支持),进而得知使用的语言。
目前流行Web应用程序架构有两种:C/S、B/S.
1)C/S:Client/Server,服务器通常采用高性能的PC、工作站或小型机,客户端需要安装专用的客户端软件。
2)B/S:Brower/Server,客户端只要安装一个浏览器,通过浏览器与Web服务器进行数据交互。
Web开发技术大体上可以分为客户端技术和服务端技术两大类。
1)客户端技术:Html、JavaScript、JQuery、CSS。
2)服务器端技术:CGI、ASP和ASP.NET、PHD、Servlet、JSP。