SIP Servlets同样基于Java Servlet架构, 其API归属于javax.servlet.sip包, 和javax.servlet.http同样扩展自javax.servlet. 不同的是, HTTP Servlets通过Servlet架构实现了HTTP协议, 而SIP Servlet实现了SIP协议.
通过SIP Servlets, 开发人员可以非常简单的开发出复杂的SIP应用程序, 就像HTTP servlets在WEB应用开发中起到的作用一样.
一组SIP Servlets连同资源和部署描述文件打包后部署并运行在一个容器或SIP应用服务器上的. 容器提供了例如会话状态管理, 事务管理, 重发, 网络连接, 消息调度, 线程管理, 资源管理, 应用程序管理等服务. 应用程序中只需包含高级的消息处理和业务逻辑, 开发人员不再需要在协议本身上投入过多精力, 这使SIP服务的开发成为一件轻而易举的事情.
下面对HTTP serlvet和SIP servlet做了一点比较:
|
HTTP |
SIP |
Servlet class |
HttpServlet |
SipServlet |
Session |
HttpSession |
SipSession |
Application package |
war |
sar |
Deployment Descriptor |
web.xml |
sip.xml |
SIP serlvets继承自javax.servlet.sip.SipServlet, 这个类同HttpServlet一样, 继承自javax.servlet.GenericServlet. SipServlet通过重写的service(ServletRequest request,
ServletResponse response)方法来处理不同的SIP消息.
由于SIP协议是异步的, 所以service方法每次调用时, 其两个参数中只有一个是有效的, 而另一个是null, 例如, 如果收到的SIP消息是一个request, 那么第一个request参数有效, 而response参数为null, 反之亦然.
SipSerlvet中service方法的默认实现是把SIP消息交给不同的子方法处理. 对请求来说, 是doXXX()方法, 对响应来说是doXXXResponse()方法. 例如, doInvite(SipServletRequest request)方法处理INVITE请求, doSuccessResponse(SipServletResponse response) 处理所有的2XX响应. 通常, 通过重写SipSerlvet类的这些doXXX(), doXXXResponse()方法, 来实现SIP应用的业务逻辑.
创建响应:
在doXXX(SipServletRequest request)中, 可以通过调用javax.servlet.sip.SipServletRequest类的createResponse()方法来创建一个响应, 随后, 调用这个响应的send()方法,将其发送出去.
创建请求:
在一个SIP Servlet中创建一个请求有两种方式, SipSession类的createRequest()方法用于在已经建立的一个会话中创建请求, 创建的请求属于这个已经存在的SipSession. 另一种方法是
javax.servlet.sip.SipFactory类的createRequest()方法. SipFactory是SIP Servlet API中提供的一个工厂接口, 用于创建Request, Address, URI, Applicaiton session对象, 它的具体实现是由容器提供的, 在SIP Servlet中, 只需要通过ServletContext类的getAttribute("javax.servlet.sip.SipFactory”) 就可以获得一个SipFactory实例。
下面是一个具体的例子:
这个例子是一简单的"Echo"应用, 它接收Windows Messenger发送的Instant Message消息, 再将收到的消息发送回Windows Messenger。
package blog.sample.sipservlet;
import java.io.IOException;
import java.util.HashMap;
import javax.servlet.*;
import javax.servlet.sip.*;
/**
* EchoServlet provides a simple example of a SIP servlet.
* EchoServlet echoes instant messages sent by Windows Messenger.
*/
public class EchoServlet extends SipServlet {
/**
* _address keeps the mapping between sign-in name and actual contact address.
*/
protected HashMap _addresses = new HashMap();
/**
* Invoked for SIP INVITE requests, which are sent by Windows Messenger
* toestablish a chat session.
*/
protected void doInvite(SipServletRequest req)
throws IOException, ServletException {
// we accept invitation for a new session by returning 200 OK response
req.createResponse(SipServletResponse.SC_OK).send();
}
/**
* Invoked for SIP REGISTER requests, which are sent by Windows Messenger
* for sign-inand sign-off.
*/
protected void doRegister(SipServletRequest req)
throws IOException, ServletException {
String aor = req.getFrom().getURI().toString().toLowerCase();
synchronized (_addresses) {
// the non-zero value of Expires header indicates a sign-in.
if (req.getExpires() != 0) {
// keep the name/address mapping
_addresses.put(aor, req.getAddressHeader("Contact").getURI());
}
// the zero value of Expires header indicates a sign-off.
else {
// remove the name/address mapping
_addresses.remove(aor);
}
}
// we accept the sign-in or sign-off by returning 200 OK response
req.createResponse(SipServletResponse.SC_OK).send();
}
/**
* Invoked for SIP MESSAGE requests, which are sent by Windows Messenger
* for instant messages.
*/
protected void doMessage(SipServletRequest req)
throws IOException, ServletException {
SipURI uri = null;
synchronized (_addresses) {
// get the previous registered address for the sender
uri = (SipURI) _addresses.get(req.getFrom().getURI().toString().toLowerCase());
}
if (uri == null) {
// reject the message if it is not from a registered user
req.createResponse(SipServletResponse.SC_FORBIDDEN).send();
return;
}
// we accept the instant message by returning 200 OK response.
req.createResponse(SipServletResponse.SC_OK).send();
// create an echo SIP MESSAGE request with the same content
SipServletRequest echo = req.getSession().createRequest("MESSAGE");
String charset = req.getCharacterEncoding();
if (charset != null) {
echo.setCharacterEncoding(charset);
}
echo.setRequestURI(uri);
echo.setContent(req.getContent(), req.getContentType());
// send the echo MESSAGE request back to Windows Messenger
echo.send();
}
/**
* Invoked for SIP 2xx class responses.
*/
protected void doSuccessResponse(SipServletResponse resp)
throws IOException, ServletException {
// print out when the echo message was accepted.
if (resp.getMethod().equalsIgnoreCase("MESSAGE")) {
System.out.println("\"" + resp.getRequest().getContent()
+ "\" was accepted: " +resp.getStatus());
}
}
/**
* Invoked for SIP 4xx-6xx class responses
*/
protected void doErrorResponse(SipServletResponse resp)
throws IOException, ServletException {
// print out when the echo message was rejected/
if (resp.getMethod().equalsIgnoreCase("MESSAGE")) {
System.out.println("\"" + resp.getRequest().getContent()
+ "\" was rejected: " + resp.getStatus());
}
}
/**
* Invoked for SIP BYE requests, which are sent by Windows Messenger
* to terminate a chat session/
*/
protected void doBye(SipServletRequest req)
throws IOException, ServletException {
// accept session termination by returning 200 OK response.
req.createResponse(SipServletResponse.SC_OK).send();
}
}
EchoServlet的呼叫流程如图:
编译EchoServlet需要servlet.jar和sipservlet.jar这两个jar文件在classpath中. sipservlet.jar可以在JSR116的发布包中找到.
和HTTP Servlet应用一样, SIP Servlet应用同样需要一个部署描述文件-sip.xml. 下面是一个sip.xml的例子:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sip-app
PUBLIC "-//Java Community Process//DTD SIP Application 1.0//EN"
"http://www.jcp.org/dtd/sip-app_1_0.dtd">
<sip-app>
<display-name>SIP Servlet Sample</display-name>
<servlet>
<servlet-name>echo</servlet-name>
<servlet-class>com.micromethod.sample.EchoServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>echo</servlet-name>
<pattern>
<or>
<equal><var>request.method</var><value>REGISTER</value></equal>
<equal><var>request.method</var><value>INVITE</value></equal>
</or>
</pattern>
</servlet-mapping>
</sip-app>
明显和web.xml不同的就是用and, or, not, equal, exists, contains, subdomain-of这一系列标签代替了url-pattern. 通过这些标签的组合嵌套,形成了一个条件表达式,表明相应的servlet可以处理哪些SIP消息.
上面的sip.xml就表明了EchoServlet可以处理REGISTER和INVITE请求. 注意的是, 请求的类型指的是创建会话的请求, 会话后续请求不再做这种条件判断,例如INVITE创建会话后,会话内的ACK, CANCEL, MESSAGE, BYE等消息会直接被判定为由接收INVITE请求的servlet处理。
为了方便部署, 需要将EchoServlet和sip.xml放入一个部署包中. 和HTTP Servlet应用类似, SIP Servlet应用使用SIP application archive (SAR). SAR文件其实就是JAR文件, 它的内部目录结构和WAR文件相同:
.../WEB-INF
|-- classes
| |-- blog
||--sample
| |--sipservlet
| |-- EchoServlet.class
|-- sip.xml
在上级目录执行jar cv0f echo.sar创建sar文件.
最后需要做的就是部署echo.sar, 目前提供SIP应用服务器免费下载的的似乎只有BEA和Micromethod, BEA的Weblogic SIP Server是基于它的Web Server实现的, 和J2EE结合比较紧密, 但相应配置运行较为复杂, Micromethod的SIPMethod Application Server相比之下是一个轻量级的产品, 配置部署运行都比较简洁,同时还提供一个方便开发SIP应用的Application Creation Environment和一些基于SIP Servlet技术的完整SIP基础应用,如Proxy Server, Presence Server等, 因此, 比较适合学习和开发使用. 可以从
http://www.micromethod.com或
http://cn.micromethod.com下载.
本文中使用的就是Micromethod的SIPMethod Application Server, 下载安装后,将echo.sar拷贝到SIPMethod AS的sipapps目录, 最好把sipapps目录下其它的sar文件都删除,以免EchoServlet的servlet-mapping和其它应用中的servlet冲突. 接下来, 执行SIPMethod的bin目录下的startup.bat运行服务器, 在服务器启动过程中,echo.sar就会被解开.
通常情况下, 运行SIPMethod AS甚至不需要额外配置, 使用它的默认配置就可以运行, 高级的配置方式可以参考它的user-guide. 常见的问题是端口冲突, SIPMethod AS默认需要占用TCP5060, TCP8080, TCP47492, UDP5060这四个端口.
当SIPMethod Application Server启动完成后, 就可以用Windows Messenger看效果了.
Windows Messenger的需要5.0或更高, 低于这个版本的WM没有SIP功能.
运行Windows Messenger, 依照下面的步骤进行配置:
1. 打开"Options"对话框 Tools->Options;
2. 点击"Options"对话框中的"Account"标签;
3. 选中"My contacts include users of a SIP Communications Service"复选框;
4. 在"Sign-in name"编辑框中输入一个SIP URI, 例如 kyle@micromethod.com;
5. 点击"Advanced..."按钮打开"SIP Communications Service Connection Configuration"对话框;
6. 选中"Configure settings"单选按钮;
7. 在"Server name or IP address"编辑框中输入运行SIPMethod AS的机器IP地址, 例如192.168.0.101, 或192.168.0.101:5060, 5060是SIPMethod 默认的SIP监听端口;
8. 选择使用的传输协议, 通常是TCP或UDP, TLS需要服务器进行额外配置.
配置完成后, 就可以登陆Windows Messenger了, 使用的登陆名就是刚才输入的SIP URI, 例如kyle@micromethod.com.
确保SIPMethod Applicaiton Server是运行的.
接下来选择"Actions->Send an Instant Message…"菜单项, 打开"Send an Instant Message"对话框, 选中对话框的Other标签, 在编辑框中输入echo@micromethod.com, 点击OK. (实际上在这个输入echo或是其它任何字符都可以, 因为我们在servlet-mapping中并没有对request.to或request.uri进行任何限制).
在打开的Instant message窗口中, 就可以和EchoServlet对话了.
分享到:
相关推荐
《SIPServlet-1.0-FCS:探索SIP服务的深度解析》 SIP(Session Initiation Protocol)是一种用于控制多媒体通信会话(如语音和视频通话)的应用层协议,广泛应用于VoIP(Voice over Internet Protocol)系统。在...
SipServlet API是Java平台上的一个关键组件,用于构建基于SIP(Session Initiation Protocol)的应用程序。SIP是一种协议,常用于控制多媒体通信会话,如语音和视频通话、在线会议、即时消息等。SipServlet API为...
sipservlet 1.1 sip sipservlet 1.1 sipsipservlet 1.1 sip
【sipservlet_demo_chatroom】是一个基于SIP(Session Initiation Protocol)协议的聊天室示例项目,它展示了如何使用SIP Servlets来构建实时通信应用,如多人聊天室。SIP是一种IETF定义的开放标准协议,主要用于...
标题中的"SIPServlet0[1].5.rar"表明这是一个关于SIP Servlets的资源包,版本号为0.1.5。SIP(Session Initiation Protocol)是一种用于控制多媒体通信会话(如语音和视频通话)的应用层协议,广泛应用于VoIP系统。...
在使用sipservlet-1.0-fcs这个文件时,你需要将其部署到支持SIP的Java应用服务器中,如JBOSS或者GlassFish。然后,你可以编写遵循SIP Servlet API规范的Java代码,实现自己的SIP应用程序。在实际开发过程中,理解SIP...
### SIP Servlet 1.1 知识点解析 #### 一、SIP Servlet 概念与背景 **SIP Servlet** 是一种基于 Java 的技术,它允许开发人员使用 **Session Initiation Protocol (SIP)** 来创建通信应用程序。SIP 是一种用于控制...
支持sip协议的sipServlet的jar包。
### SIP Servlet 开发详解 #### 一、引言与背景 IP多媒体子系统(IMS,IP Multimedia Subsystem)是下一代网络的核心技术之一,它通过基于SIP(Session Initiation Protocol)协议的会话控制系统,为用户提供高...
【标题】"sip-servlet-jboss 1.2.0" 涉及的主要知识点是SIP Servlets在JBoss应用服务器上的实现和部署。SIP(Session Initiation Protocol)是一种用于控制多媒体通信会话(如语音和视频通话)的协议,而Servlets则...
英文版的sipservlet,对APi详解sipservlet undersatnd
《sip-api.jar:深入解析SipServlet与JAIN-SIP在通信中的应用》 在现代通信技术中,SIP(Session Initiation Protocol)扮演着重要的角色,尤其在VoIP(Voice over IP)和多媒体通信领域。SIP-api.jar是开发者进行...
本文将深入探讨SIP Servlet技术,并通过一个带注释的实例——ChatRoomServer,展示如何使用SIP Servlet API创建一个聊天室服务。这个服务允许SIP即时消息传递应用(messenger)之间进行交互,实现了消息广播和特定的...
总结来说,“sip-servlets”项目是Java开发者构建SIP应用的重要资源,结合JAIN SIP API和SIP Servlet容器,开发者可以轻松实现复杂、高效且可扩展的多媒体通信解决方案。这个项目的源代码和文档将帮助开发者深入理解...
手工开发Servlet涉及一系列步骤,以下将详细讲解这些步骤,并涵盖开发过程中需要注意的关键点。 **步骤一:创建Servlet类** 首先,我们需要创建一个继承自`javax.servlet.Servlet`或`javax.servlet....
Java SIP API,全称为Java Session Initiation Protocol (SIP) API,是由Sun Microsystems开发的一组接口和类,用于在Java应用程序中实现SIP协议。SIP是一种应用层控制(信令)协议,常用于建立、修改和终止多媒体...
javax.servlet的jar包,javax.servlet找不到。The SIP Servlet API defines a high-level extension API for SIP servers. It enables SIP applications to be deployed and managed based on the servlet