Я использую сочетание red5 и flex для потоковой передачи микрофона. Сценарий отправляет поток микрофона веб-клиента на сервер и воспроизводит поток на стороне сервера. Аналогичным образом выполняется обратное, то есть отправка потока микрофона с сервера клиенту и воспроизведение потока на стороне клиента.red5: как я могу сделать потоковое вещание на стороне сервера?
Я отправил аналогичный запрос по переполнению стека ссылку ниже:
red5: how can i send microphone stream?
Я получил код на стороне клиента, и я думаю, что она также доступна на различных блогах. Но моя проблема в том, что я пишу код на стороне сервера red5. Я установил сервер red5 на свою машину, а также запустил API red5. Но оттуда не ясно, как я занимаюсь потоком в прямом эфире на стороне сервера.
Я также сделал код образца красного5.
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?