mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-22 19:00:01 +08:00
不支持的协议直接抛异常, 防止非法推拉流:#1725
This commit is contained in:
parent
54f400a6e9
commit
24db0454a8
@ -56,10 +56,9 @@ PlayerBase::Ptr PlayerBase::createPlayer(const EventPoller::Ptr &poller, const s
|
|||||||
} else if (end_with(url, ".ts") || end_with(url_in, ".ts")) {
|
} else if (end_with(url, ".ts") || end_with(url_in, ".ts")) {
|
||||||
return PlayerBase::Ptr(new TsPlayerImp(poller), releasePlayer);
|
return PlayerBase::Ptr(new TsPlayerImp(poller), releasePlayer);
|
||||||
}
|
}
|
||||||
return PlayerBase::Ptr(new TsPlayerImp(poller), releasePlayer);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return PlayerBase::Ptr(new RtspPlayerImp(poller), releasePlayer);
|
throw std::invalid_argument("not supported play schema:" + url_in);
|
||||||
}
|
}
|
||||||
|
|
||||||
PlayerBase::PlayerBase() {
|
PlayerBase::PlayerBase() {
|
||||||
|
@ -19,14 +19,14 @@ namespace mediakit {
|
|||||||
|
|
||||||
PusherBase::Ptr PusherBase::createPusher(const EventPoller::Ptr &poller,
|
PusherBase::Ptr PusherBase::createPusher(const EventPoller::Ptr &poller,
|
||||||
const MediaSource::Ptr &src,
|
const MediaSource::Ptr &src,
|
||||||
const std::string & strUrl) {
|
const std::string & url) {
|
||||||
static auto releasePusher = [](PusherBase *ptr){
|
static auto releasePusher = [](PusherBase *ptr){
|
||||||
onceToken token(nullptr,[&](){
|
onceToken token(nullptr,[&](){
|
||||||
delete ptr;
|
delete ptr;
|
||||||
});
|
});
|
||||||
ptr->teardown();
|
ptr->teardown();
|
||||||
};
|
};
|
||||||
std::string prefix = FindField(strUrl.data(), NULL, "://");
|
std::string prefix = FindField(url.data(), NULL, "://");
|
||||||
|
|
||||||
if (strcasecmp("rtsps",prefix.data()) == 0) {
|
if (strcasecmp("rtsps",prefix.data()) == 0) {
|
||||||
return PusherBase::Ptr(new TcpClientWithSSL<RtspPusherImp>(poller, std::dynamic_pointer_cast<RtspMediaSource>(src)), releasePusher);
|
return PusherBase::Ptr(new TcpClientWithSSL<RtspPusherImp>(poller, std::dynamic_pointer_cast<RtspMediaSource>(src)), releasePusher);
|
||||||
@ -44,7 +44,7 @@ PusherBase::Ptr PusherBase::createPusher(const EventPoller::Ptr &poller,
|
|||||||
return PusherBase::Ptr(new RtmpPusherImp(poller, std::dynamic_pointer_cast<RtmpMediaSource>(src)), releasePusher);
|
return PusherBase::Ptr(new RtmpPusherImp(poller, std::dynamic_pointer_cast<RtmpMediaSource>(src)), releasePusher);
|
||||||
}
|
}
|
||||||
|
|
||||||
return PusherBase::Ptr(new RtspPusherImp(poller, std::dynamic_pointer_cast<RtspMediaSource>(src)), releasePusher);
|
throw std::invalid_argument("not supported push schema:" + url);
|
||||||
}
|
}
|
||||||
|
|
||||||
PusherBase::PusherBase() {
|
PusherBase::PusherBase() {
|
||||||
|
Loading…
Reference in New Issue
Block a user