Я использую комбинацию red5 и flex для прямой трансляции с микрофона. Сценарий отправляет поток микрофона веб-клиента на сервер и воспроизводит поток на стороне сервера. Аналогично, выполняется обратное, то есть отправка потока микрофона с сервера на клиент и воспроизведение потока на стороне клиента.
Я отправил аналогичный запрос по переполнению стека, ссылка ниже:
red5: как отправить поток с микрофона?
У меня есть код на стороне клиента, и я думаю, что он также доступен в разных блогах. Но моя проблема в том, как я пишу код на стороне сервера Red5. Я установил на своем компьютере сервер red5, а также зачитал API red5. Но оттуда не ясно, как я решу живой поток на стороне сервера.
Я также сделал пример кода red5.
Application.java
public class Application extends ApplicationAdapter {
@Override
public boolean appConnect(IConnection arg0, Object[] arg1) {
out.println("appConnect");
return super.appConnect(arg0, arg1);
}
@Override
public void appDisconnect(IConnection arg0) {
out.println("appConnect");
super.appDisconnect(arg0);
}
}
StreamManager.java
public class StreamManager {
private static final Log log = LogFactory.getLog(StreamManager.class);
private Application app;
/**
* Start recording the publishing stream for the specified IConnection.
*
* @param conn
*/
private ClientBroadcastStream stream;
public void recordShow(IConnection conn) {
try {
log.debug("Recording show for: " + conn.getScope().getContextPath());
String streamName = String.valueOf(System.currentTimeMillis());
log.debug("Stream Name : " + streamName);
// Get a reference to the current broadcast stream.
stream = (ClientBroadcastStream) app.getBroadcastStream(conn.getScope(), "hostStream");
// Save the stream to disk.
stream.saveAs(streamName, false);
} catch (Exception e) {
log.error(e.getMessage(), e);
}
}
public void setApplication(Application app) {
this.app = app;
}
}
samplescope-context.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:lang="http://www.springframework.org/schema/lang"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-2.0.xsd">
<bean id="samplescope.context" class="org.red5.server.Context" autowire="byType" />
<bean id="samplescope.scope" class="org.red5.server.WebScope"
init-method="register">
<property name="server" ref="red5.server" />
<property name="parent" ref="global.scope" />
<property name="context" ref="samplescope.context" />
<property name="handler" ref="samplescope.handler" />
<property name="contextPath" value="/samplescope" />
<property name="virtualHosts"
value="*,localhost, localhost:5080, 127.0.0.1:5080" />
</bean>
<bean id="samplescope.handler" class="my.first.Application" />
<bean id="streamManager.service" class="my.first.StreamManager">
<property name="application" ref="samplescope.handler"/>
</bean>
</beans>
Приведенный выше код сохраняет поток в FLV-файле на стороне сервера, но я хочу, чтобы вместо сохранения потока на сервере я мог получать поток необработанных данных и легко кодировать поток. Аналогично перед отправкой потока на сервер декодируется поток. Как я могу сделать это в red5?