2017-10-06 11 views
1

RestComm SipServlet을 사용하여 IMS 응용 프로그램 서버를 개발하려고합니다. 처음에는 특별한 목적을 수행하지 않고 호출 흐름에 AS를 삽입하기 만하면됩니다. enter image description hereRestComm SIpServlet - IMS 네트워크에서 응용 프로그램 서버로 Servlet 채우기

응용 프로그램 서버에는 doStuff 및 전달 초기 초대가 있습니다. 문제는 RestComm의 SIP 스택이 Invite add it from route 헤더를 경로 헤더에 제거하지 않기 때문에 초대장이 AS로 다시 라우팅되어 루프를 생성한다는 것입니다. SipRequest에서 Route Header를 삭제하려고 할 때 시스템 헤더를 수정할 수 없다는 이유로 AS 응답이 500으로 수정되었습니다. 여기

내가 미친거야 코드

@Override 
protected final void doInvite(SipServletRequest request) 
     throws ServletException, IOException { 

    //DO STUFF 
    System.out.println("RECEIVED AN INVITE"); 

    //  These lines generate a 500 
    //  request.removeHeader("route"); 
    //  request.removeHeader("route"); 

    ProxyImpl p = (ProxyImpl) request.getProxy(true); 
    p.setRecordRoute(false); 
    p.setSupervised(true); 
    p.setParallel(true); 
    p.proxyTo(request.getRequestURI()); 
    p.startProxy(); 

}

의 조각 :/ 희망 누군가가 나에게 몇 가지 제안을 줄 수 ...

답변

0

또한 모금 새로운 오전 서블릿하지만 내가이 정보에서 만난 문서를 읽었을 때 :

"다음 중 하나의 문자열로 구성된 경로 수정 자 : ROUTE, ROUTE_ BACK 또는 NO_ROUTE. 경로 수정을 요청 외부 경로에 대한 경로 정보를 표시합니다. "mobicents-dar.properties에 관련된과 함께 사용된다.

어쩌면 그것은 도움이됩니다.

+0

댓글이 너무 깁니다. 나는 또 다른 대답을했다. –

0

난 아직도 원래의 문제를 고민하고 말도. 내가 가진 Bartek이 나에게 주었던 힌트를 조사했습니다. 불행히도 문서가 매우 열악하고 아마도 완전히 이해하지 못했을 것입니다. 어쨌든 dar 속성 파일을 조작하여 내 결과를 공유합니다. 정의는 SipServlet 사양 v1.1에서 가져 왔습니다.

ROUTE 변경자는 tha t SipApplicationRouterInfo.getRoutes()는 유효한 경로를 반환합니다. 컨테이너가 외부에 있는지 또는 내부 경로가 반환되었는지를 결정하는 것은 컨테이너의 책임입니다. 반환 된 모든 경로는 반드시 동일한 유형이어야하므로 컨테이너는 첫 번째 경로 만 검사하여 결정을 내릴 수 있습니다.

2017-10-10 15:55:01,372 ERROR [SipApplicationDispatcherImpl] (pool-AffinityJAIN-thread-1) Unexpected exception while processing request 
    INVITE sip:[email protected] SIP/2.0 
    Via: SIP/2.0/TCP 10.39.117.121:50302;rport=50302;branch=z9hG4bKPj921L-Q-IghWuH.rSX.uNoNMh9T7gZilB;received=10.39.117.121 
    Via: SIP/2.0/TCP 10.39.117.93:6560;received=10.39.117.93;branch=z9hG4bK+aa78dad05a4a559d9e4635f37906172a1+sip+5+a64ded2b 
    Route: <sip:[email protected];lr> 
    Route: <sip:[email protected]:5054;lr;orig> 
    Record-Route: <sip:sprout.dev.mydomain.sys:5054;transport=TCP;lr;service=scscf;billing-role=charge-orig> 
    Record-Route: <sip:10.39.117.93:6560;lr> 
    From: "itsme" <sip:[email protected]>;tag=10.39.117.93+5+2cdeefc2+8fc7709c 
    To: <sip:[email protected]> 
    CSeq: 1 INVITE 
    Expires: 180 
    Call-Info: <sip:10.39.117.93:6560>;method="NOTIFY;Event=telephone-event;Duration=2000" 
    P-Charging-Function-Addresses: ccf=pri_ccf_address 
    Supported: outbound,path,replaces 
    P-Charging-Vector: icid-value="0be3bd9333dd5089baf80bf17225e3d6";orig-ioi=mydomain.net 
    Contact: <sip:[email protected]:46973;transport=tcp;rinstance=e637627c20b12d87;ob>;+sip.instance="<urn:uuid:968fdfa1-95d3-59cb-acb3-403d721daeee>" 
    P-Asserted-Identity: <sip:[email protected]> 
    Max-Forwards: 68 
    Call-ID: 0gQAAC8WAAACBAAALxYAAOYHyDdZmVO7ntMtj/[email protected] 
    Allow: SUBSCRIBE,NOTIFY,INVITE,ACK,CANCEL,BYE,REFER,INFO,OPTIONS 
    User-Agent: X-Lite release 5.0.1 stamp 86895 
    P-Visited-Network-ID: perim.dev.ims.ext1.net 
    Accept: application/sdp,application/dtmf-relay 
    Session-Expires: 600 
    P-Served-User: <sip:[email protected]>;regstate=reg;sescase=orig 
    Content-Type: application/sdp 
    Content-Length: 281 

    v=0 
    o=- 14048926850737 14048926850737 IN IP4 10.39.117.93 
    s=- 
    c=IN IP4 10.39.117.93 
    t=0 0 
    m=audio 45234 RTP/AVP 120 0 101 
    a=sendrecv 
    a=rtpmap:120 opus/48000/2 
    a=rtpmap:101 telephone-event/8000 
    a=fmtp:120 useinbandfec=1; usedtx=1; maxaveragebitrate=64000 
    a=fmtp:101 0-15 

    org.mobicents.servlet.sip.core.DispatcherException: Impossible to parse the route returned by the application router into a compliant address 
      at org.mobicents.servlet.sip.core.dispatchers.InitialRequestDispatcher.checkRouteModifier(InitialRequestDispatcher.java:575) 
      at org.mobicents.servlet.sip.core.dispatchers.InitialRequestDispatcher.dispatchMessage(InitialRequestDispatcher.java:299) 
      at org.mobicents.servlet.sip.core.SipApplicationDispatcherImpl.processRequest(SipApplicationDispatcherImpl.java:927) 
      at gov.nist.javax.sip.EventScanner.deliverRequestEvent(EventScanner.java:250) 
      at gov.nist.javax.sip.EventScanner.deliverEvent(EventScanner.java:146) 
      at gov.nist.javax.sip.SipProviderImpl.handleEvent(SipProviderImpl.java:185) 
      at gov.nist.javax.sip.DialogFilter.processRequest(DialogFilter.java:1328) 
      at gov.nist.javax.sip.stack.SIPServerTransactionImpl.processRequest(SIPServerTransactionImpl.java:851) 
      at gov.nist.javax.sip.stack.ConnectionOrientedMessageChannel.processMessage(ConnectionOrientedMessageChannel.java:473) 
      at gov.nist.javax.sip.parser.NioPipelineParser$Dispatch.run(NioPipelineParser.java:132) 
      at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 
      at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
      at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) 
      at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) 
      at gov.nist.javax.sip.MDCScheduledTHExecutor$MDCFuture.run(MDCScheduledTHExecutor.java:57) 
      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 
      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 
      at java.lang.Thread.run(Thread.java:748) 
    Caused by: java.text.ParseException: :Bad address spec 
      at gov.nist.javax.sip.parser.Parser.createParseException(Parser.java:45) 
      at gov.nist.javax.sip.parser.AddressParser.address(AddressParser.java:120) 
      at gov.nist.javax.sip.parser.StringMsgParser.parseAddress(StringMsgParser.java:328) 
      at gov.nist.javax.sip.address.AddressFactoryImpl.createAddress(AddressFactoryImpl.java:124) 
      at org.mobicents.servlet.sip.core.dispatchers.InitialRequestDispatcher.checkRouteModifier(InitialRequestDispatcher.java:537) 
    ... 17 more 

또한 SIP 메시지를 전달하기 위해 IMS 노드를 가리 키도록 경로 필드를 사용했습니다. 그것은 작동하지만이 방법으로 AS가 Record-Route 헤더에 추가되지 않고 루프가 발생한다고 생각합니다.

ROUTE_BACK은 SipApplicationRouterInfo.getRoutes()에서 얻은 외부 경로를 푸시하기 전에 컨테이너가 자체 경로를 푸시하도록 지시합니다. 애플리케이션 라우터 I가 다음 오류 및 500

2017-10-10 15:52:57,276 ERROR [SipApplicationDispatcherImpl] (pool-AffinityJAIN-thread-14) Unexpected exception while processing request 
    INVITE sip:[email protected] SIP/2.0 
    Via: SIP/2.0/TCP 10.39.117.121:43312;rport=43312;branch=z9hG4bKPj5IBDrImFUbO1J.J1LrwUcUQ-rsT28TRh;received=10.39.117.121 
    Via: SIP/2.0/TCP 10.39.117.93:6560;received=10.39.117.93;branch=z9hG4bK+84bf75e3c2c4ccae314be5e5849bd4961+sip+3+a64ded21 
    Route: <sip:[email protected];lr> 
    Route: <sip:odi_kMFF/[email protected]:5054;lr;orig> 
    Record-Route: <sip:sprout.dev.mydomain.sys:5054;transport=TCP;lr;service=scscf;billing-role=charge-orig> 
    Record-Route: <sip:10.39.117.93:6560;lr> 
    From: "Gennaro" <sip:[email protected]>;tag=10.39.117.93+3+7334eef2+84ee6a06 
    To: <sip:[email protected]> 
    CSeq: 1 INVITE 
    Expires: 180 
    Call-Info: <sip:10.39.117.93:6560>;method="NOTIFY;Event=telephone-event;Duration=2000" 
    P-Charging-Function-Addresses: ccf=pri_ccf_address 
    Supported: outbound,path,replaces 
    P-Charging-Vector: icid-value="4167d34dd3fb232bb1f5fcf458dc1a9e";orig-ioi=mydomain.net 
    Contact: <sip:[email protected]:46973;transport=tcp;rinstance=e637627c20b12d87;ob>;+sip.instance="<urn:uuid:968fdfa1-95d3-59cb-acb3-403d721daeee>" 
    P-Asserted-Identity: <sip:[email protected]> 
    Max-Forwards: 68 
    Call-ID: 0gQAAC8WAAACBAAALxYAAK2OW7qCKhw2LAbw9q+UyCfK2Js5PtCkUUpQsljED2+H/[email protected] 
    Allow: SUBSCRIBE,NOTIFY,INVITE,ACK,CANCEL,BYE,REFER,INFO,OPTIONS 
    User-Agent: X-Lite release 5.0.1 stamp 86895 
    P-Visited-Network-ID: perim.dev.ims.ext1.net 
    Accept: application/sdp,application/dtmf-relay 
    Session-Expires: 600 
    P-Served-User: <sip:[email protected]>;regstate=reg;sescase=orig 
    Content-Type: application/sdp 
    Content-Length: 281 

    v=0 
    o=- 76884298267467 76884298267467 IN IP4 10.39.117.93 
    s=- 
    c=IN IP4 10.39.117.93 
    t=0 0 
    m=audio 45230 RTP/AVP 120 0 101 
    a=sendrecv 
    a=rtpmap:120 opus/48000/2 
    a=rtpmap:101 telephone-event/8000 
    a=fmtp:120 useinbandfec=1; usedtx=1; maxaveragebitrate=64000 
    a=fmtp:101 0-15 

    java.lang.IllegalArgumentException: not allowed to set parameter, the URI is not modifiable 
      at org.mobicents.servlet.sip.address.SipURIImpl.setParameter(SipURIImpl.java:401) 
      at org.mobicents.servlet.sip.core.dispatchers.InitialRequestDispatcher.checkRouteModifier(InitialRequestDispatcher.java:591) 
      at org.mobicents.servlet.sip.core.dispatchers.InitialRequestDispatcher.dispatchMessage(InitialRequestDispatcher.java:299) 
      at org.mobicents.servlet.sip.core.SipApplicationDispatcherImpl.processRequest(SipApplicationDispatcherImpl.java:927) 
      at gov.nist.javax.sip.EventScanner.deliverRequestEvent(EventScanner.java:250) 
      at gov.nist.javax.sip.EventScanner.deliverEvent(EventScanner.java:146) 
      at gov.nist.javax.sip.SipProviderImpl.handleEvent(SipProviderImpl.java:185) 
      at gov.nist.javax.sip.DialogFilter.processRequest(DialogFilter.java:1328) 
      at gov.nist.javax.sip.stack.SIPServerTransactionImpl.processRequest(SIPServerTransactionImpl.java:851) 
      at gov.nist.javax.sip.stack.ConnectionOrientedMessageChannel.processMessage(ConnectionOrientedMessageChannel.java:473) 
      at gov.nist.javax.sip.parser.NioPipelineParser$Dispatch.run(NioPipelineParser.java:132) 
      at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 
      at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
      at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) 
      at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) 
      at gov.nist.javax.sip.MDCScheduledTHExecutor$MDCFuture.run(MDCScheduledTHExecutor.java:57) 
      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) 
      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) 
      at java.lang.Thread.run(Thread.java:748) 

NO_ROUTE와 AS 응답이이 경우에 동작

)은 (애플리케이션 라우터가 어떤 경로 및 SipApplicationRouterInfo.getRoutes 반환되지 않은 것을 나타낸다 가치가있는 경우이를 무시해야합니다.

이 경우 요청은 IMS 노드로 요청을 전달할 방법이없는 AS에 갇혀있는 것 같습니다.

희망이 상황을 설명합니다. 감사합니다.