代码拉取完成,页面将自动刷新
开源流媒体服务框架 ZLMediaKit C Api 的 Java 实现
感谢 @夏楚 提供了这么好的开源流媒体服务框架ZLMediaKit
本项目是对 ZLMediaKit 提供的 C Api 的 Java Api 封装(部分封装)。采用 JNA 对 ZLMediaKit C Api 进行解析,并进行微调和修改,基于 ZLMediaKit 项目的调用原始风格,各位网友可以参照 ZLMediaKit 原始项目文档编写应用程序。
使用此项目可以实现现有项目快速集成流媒体服务功能,无需部署额外的流媒体服务器,利用原始流事件回调更加方便的操作流(推拉流鉴权、按需拉流、自动关流、转协议、截图、录制、国标GB推流)
具体如何集成到项目可以参考JMediaServer
public class Test {
//动态链接库放在/resource/win32-x86-64&/resource/linux-x86-64下JNA会自动查找目录
//public static ZLMApi ZLM_API = Native.load("mk_api", ZLMApi.class);
//Windows环境测试 自定义动态链接库目录
public static ZLMApi ZLM_API = Native.load("D:\\ZLMediaKit\\source\\release\\windows\\Debug\\mk_api.dll", ZLMApi.class);
//Linux环境测试 自定义动态链接库目录
//public static ZLMApi ZLM_API = Native.load("/opt/media/libmk_api.so", ZLMApi.class);
public static void main(String[] args) throws InterruptedException {
//初始化环境配置
MK_INI mkIni = ZLM_API.mk_ini_default();
//配置参数 打开自动关流 对应conf.ini中配置[protocol] auto_close
ZLM_API.mk_ini_set_option_int(mkIni, "protocol.auto_close", 1);
ZLM_API.mk_ini_set_option_int(mkIni,"protocol.enable_fmp4",0);
ZLM_API.mk_ini_set_option_int(mkIni,"protocol.enable_hls",0);
ZLM_API.mk_ini_set_option_int(mkIni,"protocol.enable_ts",0);
//全局回调
MK_EVENTS mkEvents = new MK_EVENTS();
mkEvents.on_mk_media_changed= (regist, sender) -> {
System.out.println("这里是流改变回调通知:"+regist);
};
mkEvents.on_mk_media_no_reader= sender -> {
System.out.println("这里是无人观看回调通知");
ZLM_API.mk_media_source_close(sender,1);
};
mkEvents.on_mk_media_publish= (url_info, invoker, sender) -> {
ZLM_API.mk_publish_auth_invoker_do(invoker,"0",0,0);
};
//添加全局回调
ZLM_API.mk_events_listen(mkEvents);
//Pointer iniPointer = ZLM_API.mk_ini_dump_string(mkIni);
//初始化zmk服务器
ZLM_API.mk_env_init1(1, 1, 1, null, 0, 0, null, 0, null, null);
//创建http服务器 0:失败,非0:端口号
short http_server_port = ZLM_API.mk_http_server_start((short) 7788, 0);
//创建rtsp服务器 0:失败,非0:端口号
short rtsp_server_port = ZLM_API.mk_rtsp_server_start((short) 7554, 0);
//创建rtmp服务器 0:失败,非0:端口号
short rtmp_server_port = ZLM_API.mk_rtmp_server_start((short) 7935, 0);
//创建拉流代理
MK_PROXY_PLAYER mk_proxy = ZLM_API.mk_proxy_player_create("__defaultVhost__", "live", "test", 0, 0);
//回调关闭时间
IMKProxyPlayCloseCallBack imkProxyPlayCloseCallBack = new IMKProxyPlayCloseCallBack() {
@Override
public void invoke(Pointer pUser, int err, String what, int sys_err) {
//这里Pointer是ZLM维护的不需要我们释放 遵循谁申请谁释放原则
ZLM_API.mk_proxy_player_release(new MK_PROXY_PLAYER(pUser));
}
};
//开始播放
ZLM_API.mk_proxy_player_play(mk_proxy, "rtsp://admin:telit123@172.16.6.236/h264/ch1/main/av_stream");
//添加代理关闭回调 并把代理客户端传过去释放
ZLM_API.mk_proxy_player_set_on_close(mk_proxy, imkProxyPlayCloseCallBack, mk_proxy.getPointer());
//阻塞60s
Thread.sleep(60000L);
//停止所有服务器
ZLM_API.mk_stop_all_server();
}
}
可直接复制代码到自己的项目中,方便修改参数
由于此项目暂未发布到中央仓库,可以下载此项目然后打包到本地仓库(mvn install)然后项目引入
<dependency>
<groupId>com.ldf</groupId>
<artifactId>j-zlm-sdk</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
wx:L746101210
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。