浏览器内核

-

要搞清楚浏览器内核是什么,首先应该先搞清楚浏览器的构成。简单来说浏览器可以分为两部分,shell+内核。其中shell的种类相对比较多,内核则比较少。Shell是指浏览器的外壳:例如菜单,工具栏等。主要是提供给用户界面操作,参数设置等等。它是调用内核来实现各种功能的。内核才是浏览器的核心。内核是基于标记语言显示内容的程序或模块。也有一些浏览器并不区分外壳和内核。从Mozilla将Gecko独立出来后,才有了外壳和内核的明确划分。目前主流的浏览器有IE6、IE8、Mozilla、FireFox、Opera、Safari、Chrome、Netscape等。

什么是浏览器内核

浏览器内核又可以分成两部分:渲染引擎(layout engineer或者Rendering Engine)和JS引擎。它负责取得网页的内容(HTML、XML、图像等等)、整理讯息(例如加入CSS等),以及计算网页的显示方式,然后会输出至显示器或打印机。浏览器的内核的不同对于网页的语法解释会有不同,所以渲染的效果也不相同。所有网页浏览器、电子邮件客户端以及其它需要编辑、显示网络内容的应用程序都需要内核。(参见维基百科)JS引擎则是解析Javascript语言,执行javascript语言来实现网页的动态效果。最开始渲染引擎和JS引擎并没有区分的很明确,后来JS引擎越来越独立,内核就倾向于只指渲染引擎。有一个网页标准计划小组制作了一个ACID来测试引擎的兼容性和性能。内核的种类很多,如加上没什么人使用的非商业的免费内核,可能会有10多种,但是常见的浏览器内核可以分这四种:Trident、Gecko、Presto、Webkit。

Trident又称MSHTML,是微软开发的渲染引擎(包含了Javascript引擎JScript),他已经深入了Windows操作系统的骨髓,例如Windows Media Play,Windows Explorer,Outlook Express等都使用了。目前很多浏览器都使用这个引擎,例如IE,Maxthon(最新版已经不使用)等。

Gecko是C++开发的,Open Source的渲染引擎,包括了SpiderMonkey(Rhino)。主要的使用者有Firefox。

Webkit是苹果公司基于KHTML开发的。他包括Webcore和JavaScriptCore(SquirrelFish,V8)两个引擎。主要的使用者有Safari,Chrome。

Presto由Opera Software公司开始的,用于Opera的渲染引擎。Macromedia Dreamweaver (MX版本及以上)和Adobe Creative Suite 2也使用了Presto的内核。

主流浏览器所使用的内核分类

Trident内核:IE,MaxThon,TT,The World,360,搜狗浏览器等
Gecko内核:Netscape6及以上版本,FF,MozillaSuite/SeaMonkey等
Presto内核:Opera7及以上
Webkit内核:Safari,Chrome等

Engine

Creator

Software license

Leading application

Gecko

Netscape/Mozilla Foundation

MPL/GNU GPL/GNU LGPL tri-license

Mozilla Firefox

KHTML

KDE

GNU LGPL

Konqueror

Presto

Opera Software

Proprietary

Opera

Tasman

Microsoft

Proprietary

Microsoft Entourage

Trident

Microsoft

Proprietary

Internet Explorer

WebKit (Based on KHTML)

WebKit Foundation

GNU LGPL, BSD-style

Safari, Google Chrome

JS引擎

JavaScript最初由网景公司的Brendan Eich设计,是一种动态、弱类型、基于原型的语言,内置支持类。以它为基础,制定了ECMAScript标准。他的起源并不是如《Javascript高级程序设计》书中所述,是Brendan Eich自主发明的。(参考aimingoo的考证文章)JavaScript在浏览器的实现中还必须含有DOM和BOM。Web浏览器一般使用公共API来创建主机对象来负责将DOM对象反射进JavaScript。

 

Trident

Gecko

WebKit

KHTML

Presto

Name of ECMAScript Engine

JScript

Spidermonkey

JavaScriptCore

KJS

linear b/futhark

ECMAScript Version

Edition 3

Yes

0.6

Yes

Yes

7.0

JavaScript 1.5 extensions

No

0.6

Yes

Yes

7.0

JavaScript 1.7 extensions

No

1.8.1

No

No

No

JavaScript 1.8 extensions

No

1.9

No

No

No

浏览器内核实现原理

渲染流程如下所示:

渲染引擎运作流程

Mozilla架构设计:界面和实现分离。采用标记语言,JavaScript,C++来开发。JSEngine就是指SpideMonkey,Layout就是指Gecko。Mozilla的一个关键部分是XPCOM和NSPR。

Mozilla架构设计

Webkit的处理流程:

Webkit的处理流程
浏览器内核的优缺点

Trident:这种浏览器内核是IE浏览器用的内核,因为在早期IE占有大量的市场份额,所以这种内核比较流行,以前有很多网页也是根据这个内核的标准来编写的,但是实际上这个内核对真正的网页标准支持不是很好,甚至在2005年,与网页标准制定组织(W3C理事会)所制定的标准发生了脱节,同时 Trident 内核本身的BUG比较多,对一些符合W3C标准的网页代码支持不是很好,这在早期的IE版本中比较明显,比如IE5.5以前(包括IE5.5),其实IE6对W3C标准的支持也不是很好,而我们现在很多人都在使用IE6,事实上它也属于一个比较早的版本。

但是由于IE的高市场占有率,微软也很长时间没有更新Trident内核,这导致了二个结果
1,Trident内核和W3C标准脱节。
2,Trident内核的大量Bug等安全问题没有得到解决,加上一些专家学者公开自己认为IE浏览器不安全的观点,使很多用户开始转向其他浏览器,FF,Opera就是这时期兴起的。
Gecko:这是Firefox 和 Flock 所采用内核,这个内核的优点就是功能强大、丰富,可以支持很多复杂网页效果和浏览器扩展接口,但是代价是也显而易见就是要消耗很多的资源,比如内存。
Presto:Opera 采用的是 Presto内核,Presto内核被称为公认的浏览网页速度最快的内核,这得益于它在开发时的天生优势,在处理JS脚本等脚本语言时,会比其他的内核快3倍左右,缺点就是为了达到很快的速度而丢掉了一部分网页兼容性。

Webkit:Webkit 是 Safari 采用的内核,不过 Safari 是苹果系统下的浏览器(虽然也有windows版,但是比较少),所以只简单介绍一下这个内核的优点和缺点,优点就是网页浏览速度较快,虽然不及 Presto 但是也胜于 Gecko 和 Trident,缺点是对于网页代码的容错性不高,也就是说对网页代码的兼容性较低,会使一些编写不标准的网页无法正确显示。

总结:就浏览器来说,互联网经历了十年的高速发展期,近几年市场上也推出了很多新的浏览器,但是他们并非是采用自主开发的内核,所以浏览器内核本身实际没有实质突破。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Java中获取浏览器内核可以通过以下方式实现: 1. 使用User-Agent:可以通过获取客户端的User-Agent信息,从中提取浏览器名称和版本号来判断浏览器内核。通常,在User-Agent字符串中会包含浏览器的标识符和内核的版本信息。 2. 使用第三方库:可以使用第三方库来获取浏览器内核的相关信息。例如,可以使用库如"BrowserDetector"或"BrowserLauncher2"来获取浏览器的相关信息,包括内核信息。 3. 解析HTTP请求头:可以通过解析HTTP请求头中的"User-Agent"字段来获取浏览器内核的相关信息。使用Java的HTTP请求库,可以获取请求头的所有字段值,然后从中提取出浏览器内核的信息。 需要注意的是,以上方法都是基于浏览器发送的HTTP请求头中的User-Agent字段来判断浏览器内核,但是由于User-Agent可以被客户端篡改,所以无法保证100%准确性。此外,不同浏览器会使用不同的内核,因此在判断浏览器内核时应考虑到各种可能性。 ### 回答2: 要获取浏览器内核,可以使用Java中的User-Agent属性。User-Agent是浏览器发送给服务器的一个HTTP头部字段,用来标识浏览器和操作系统的信息。通过解析User-Agent,我们可以获取浏览器内核信息。 在Java中,可以使用HttpServletRequest对象来获取User-Agent属性。首先,需要通过请求对象获取User-Agent属性的值,代码如下: ``` String userAgent = request.getHeader("User-Agent"); ``` 然后,我们可以通过正则表达式或其他方法来解析User-Agent,获取浏览器内核的信息。以下是一些常见浏览器内核的识别方法: 1. Trident内核(IE):匹配字符串"Trident"或"MSIE" 2. Gecko内核(Firefox):匹配字符串"Gecko"和"Firefox" 3. Webkit内核(Chrome、Safari):匹配字符串"Webkit"和"Chrome"或"Safari" 4. Presto内核(Opera):匹配字符串"Presto"或"Opera" 根据不同的内核,我们可以采取不同的处理逻辑。例如,根据内核选择使用特定的CSS样式或JavaScript代码。 综上所述,通过解析User-Agent属性,我们可以获取浏览器内核信息,并根据不同的内核进行相应的处理。 ### 回答3: 要获取浏览器内核,我们可以使用Java编写一个简单的程序。首先,我们需要通过Java的网络编程功能,连接到目标网站,并获取目标网站的响应。 我们可以使用Java的URL类来创建一个URL对象,然后使用URLConnection类的openConnection()方法来打开与目标网站的连接。接下来,我们可以使用URLConnection对象的getInputStream()方法获取与目标网站的输入流。 要获取浏览器内核,我们可以检查目标网站的响应中的“User-Agent”标头。因为浏览器在发送HTTP请求时通常会在“User-Agent”标头中包含浏览器内核的信息。 可以通过URLConnection对象的getHeaderField()或getHeaderFieldKey()方法来获取“User-Agent”标头的值。我们可以通过判断此值是否包含特定的浏览器内核来确定浏览器内核。 例如,如果目标网站的响应中的“User-Agent”标头包含“WebKit”字符串,则可以判断该浏览器内核Webkit内核。同样地,如果包含“Trident”字符串,则判断为Trident内核;如果包含“Gecko”字符串,则判断为Gecko内核。 最后,我们可以通过打印相应的信息来展示浏览器内核。 总之,使用Java编写的程序可以通过获取目标网站的响应,并检查其中的“User-Agent”标头信息,以获取浏览器内核的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值