Как сделать исходящие звонки в AsteriskNow, используя Asterisk AMI с Java

Я хотел бы инициировать вызов с добавочного номера на другой в сети LAN. Я сделал эту задачу через графический интерфейс FreePBX. Сейчас я пытаюсь выполнить эту задачу, используя Asterisk AMI с кодом Java. Ниже код Java показывает некоторые исключения во время отладки.

import java.io.IOException; 
import org.asteriskjava.manager.AuthenticationFailedException; 
import org.asteriskjava.manager.ManagerConnection; 
import org.asteriskjava.manager.ManagerConnectionFactory; 
import org.asteriskjava.manager.TimeoutException; 
import org.asteriskjava.manager.action.OriginateAction; 
import org.asteriskjava.manager.response.ManagerResponse; 

public class HelloManager 
{ 
private ManagerConnection managerConnection; 

public HelloManager() throws IOException 
{ 
ManagerConnectionFactory factory = new ManagerConnectionFactory( 
"192.168.68.173", "admin", "admin"); 

this.managerConnection = factory.createManagerConnection(); 
} 

public void run() throws IOException, AuthenticationFailedException, 
TimeoutException 
{ 
OriginateAction originateAction; 
ManagerResponse originateResponse; 

originateAction = new OriginateAction(); 
originateAction.setChannel("SIP/1010"); 
originateAction.setContext("default"); 
originateAction.setExten("2020"); 
originateAction.setPriority(new Integer(1)); 
originateAction.setTimeout(new Integer(30000)); 
// connect to Asterisk and log in 

managerConnection.login(); 

// send the originate action and wait for a maximum of 30 seconds for Asterisk 
// to send a reply 
originateResponse = managerConnection.sendAction(originateAction, 30000); 

// print out whether the originate succeeded or not 
System.out.println("Enter Response="+originateResponse.getResponse()); 

// and finally log off and disconnect 
managerConnection.logoff(); 
} 

public static void main(String[] args) throws Exception 
{ 
HelloManager helloManager; 

helloManager = new HelloManager(); 
helloManager.run(); 
} 
} 

Исключение:

run: 
Feb 06, 2014 4:04:16 PM org.asteriskjava.manager.internal.ManagerConnectionImpl connect 
INFO: Connecting to 192.168.68.173:5038 
Feb 06, 2014 4:04:17 PM org.asteriskjava.manager.internal.ManagerConnectionImpl setProtocolIdentifier 
INFO: Connected via Asterisk Call Manager/1.3 
Feb 06, 2014 4:04:17 PM org.asteriskjava.manager.internal.ManagerConnectionImpl setProtocolIdentifier 
WARNING: Unsupported protocol version 'Asterisk Call Manager/1.3'. Use at your own risk. 
Feb 06, 2014 4:04:18 PM org.asteriskjava.manager.internal.ManagerConnectionImpl disconnect 
INFO: Closing socket. 
Feb 06, 2014 4:04:18 PM org.asteriskjava.manager.internal.ManagerReaderImpl run 
INFO: Terminating reader thread: No more lines available: null 
Exception in thread "main" org.asteriskjava.manager.AuthenticationFailedException: Authentication failed 
at org.asteriskjava.manager.internal.ManagerConnectionImpl.doLogin(ManagerConnectionImpl.java:578) 
at org.asteriskjava.manager.internal.ManagerConnectionImpl.login(ManagerConnectionImpl.java:438)
at org.asteriskjava.manager.internal.ManagerConnectionImpl.login(ManagerConnectionImpl.java:423)
at org.asteriskjava.manager.DefaultManagerConnection.login(DefaultManagerConnection.java:294)
at asteriskjtapi.HelloManager.run(HelloManager.java:49) 
at asteriskjtapi.HelloManager.main(HelloManager.java:67) 

Примечание: здесь я использую учетные данные в FreePBX. Это право доступа ConnectionManager?

2 ответа

Решение

Пожалуйста, вставьте ваш журнал звездочки во время выполнения Java-программы

Для получения журнала звездочки

 tail -f /var/log/asterisk/full

Для проверки того же из командной строки попробуйте это

 telnet 192.168.68.173  5038
 Action: Login
 Username: admin
 Secret: admin

если логин успешен

 Action: Originate
 Channel: SIP/1010
 Exten: 2020
 Context: default
 Priority: 1
 Callerid: 1010
 Async: yes

Попробуйте это и дайте мне знать ваши выводы

  1. Прежде всего, вы должны попытаться соединиться со звездочкой через telnet.
  2. Если вы получили сообщение "Войти успешно", вы можете продолжить программирование. В противном случае, если вы получаете сообщение "Ошибка аутентификации", добавьте свой ip в permit установка в manager.conf, Затем сохраните изменения.

    permit:[your static ip]

  3. Попробуйте еще раз с Telnet

Другие вопросы по тегам