--- title: Web-based protocol handlers slug: Web/API/Navigator/registerProtocolHandler/Web-based_protocol_handlers translation_of: Web/API/Navigator/registerProtocolHandler/Web-based_protocol_handlers ---
利用非http协议,从网页链接到一些别的资源,这种做法是相当普遍的。比如 mailto:
协议:
当Web页面作者想直接从网页上,为用户提供一个方便的方式发送一个电子邮件,时可以使用mailto:链接。激活链接时,浏览器应该启动默认的桌面应用程序来处理电子邮件。你可以认为这是一个基于桌面的协议处理器。
基于网络的协议处理程序也允许基于web的应用程序参与这一过程。随着越来越多的类型的应用程序迁移到web,这变得越来越重要。事实上,有许多基于web的电子邮件处理的应用程序可以处理一个mailto链接。
设置一个web应用程序作为一个协议处理器不是一个很麻烦的过程。web应用程序可以使用registerProtocolHandler()注册到浏览器上,从而对于一个给定的协议来讲,作为一个潜在的处理程序。例如:
navigator.registerProtocolHandler("mailto", "https://www.example.com/?uri=%s", "Example Mail");
参数为:
href
属性,之后通过这个url来发起一个GET请求.当一个浏览器执行这段代码时,它应该向用户显示一个请求,让用户许可为处理这个协议而注册一个web应用程序的请求。Firefox在通知栏区域显示一个提示:
http://example.com/handle_mailto/%s
注册一个协议处理程序, 但http://example.org/handle_mailto/%s不可以
.
多次注册相同的协议处理程序会弹出不同的通知,表明协议处理器已经注册。因此,发起一个注册协议处理程序的请求,之后检查是否注册是一个很好的方法。比如下面的例子。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"> <html lang="en"> <head> <title>Web Protocol Handler Sample - Register</title> <script type="text/javascript"> var url = "http://starkravingfinkle.org/projects/wph/handler.php?value=%s"; if (!navigator.isProtocolHandlerRegistered("fake", url)) { navigator.registerProtocolHandler("fake", url, "Fake Protocol"); } </script> </head> <body> <h1>Web Protocol Handler Sample</h1> <p>This web page will install a web protocol handler for the <code>fake:</code> protocol.</p> </body> </html>
现在,只要用户点击链接,使用注册协议,浏览器将跳转到web应用程序注册时提供的URL。Firefox在默认情况下,跳转前会提示用户操作。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"> <html lang="en"> <head> <title>Web Protocol Handler Sample - Test</title> </head> <body> <p>Hey have you seen <a href="fake:this%20is%20fake">this</a> before?</p> </body> </html>
下一步是处理这个动作。浏览器在激活的链接中提取出href属性,之后与注册时提供的URL模板进行拼装,之后经由拼装好的URL发起一个HTTP GET请求.因此下面的例子中,浏览器会基于此URL发起一个GET请求:
http://starkravingfinkle.org/projects/wph/handler.php?value=fake:this%20is%20fake
服务端代码可以提取查询字符串的参数,执行所需的操作。
<?php $value = ""; if ( isset ( $_GET["value"] ) ) { $value = $_GET["value"]; } ?> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"> <html lang="en"> <head> <title>Web Protocol Handler Sample</title> </head> <body> <h1>Web Protocol Handler Sample - Handler</h1> <p>This web page is called when handling a <code>fake:</code> protocol action. The data sent:</p> <textarea> <?php echo(htmlspecialchars($value, ENT_QUOTES, 'UTF-8')); ?> </textarea> </body> </html>