Android实现抖音无水印视频

网络权限

二.实现思路以及核心代码

===========================================================================

1.最开始的思路


利用Jsoup框架爬取网页中的视频地址:

Document doc = Jsoup.connect(URL).get();

Elements elements = document.select(“video”).frist;

String videoUrl = element.attr(“src”);

到这发现有一层防爬措施,获取不到视频链接

2.另一种思路


为解决此问题,反编译拥有此功能的APP后,从smali文件中得到另一种思路

1.将网页保存至本地

mWebView = new WebView(this);

//允许执行javascript语句

mWebView.getSettings().setJavaScriptEnabled(true);

mWebView.addJavascriptInterface(new InJavaScriptLocalObj(), “local_obj”);

mWebView.loadUrl(Url);//从抖音复制的链接

mWebView.setWebViewClient(new WebViewClient() {

@Override

public void onPageStarted(WebView view, String url, Bitmap favicon) {

super.onPageStarted(view, url, favicon);

}

//当新的 url 即将被加载的时候---->用户点击了 Webview 内容里面的一个超链接的时候会触发该方法的调用

@Override

public boolean shouldOverrideUrlLoading(WebView view, String url) {

view.loadUrl(url);

return true;

}

//在页面加载结束时调用。

@Override

public void onPageFinished(WebView view, String url) {

super.onPageFinished(view, url);

view.loadUrl(“javascript:window.local_obj.showSource(‘’+” + “document.getElementsByTagName(‘html’)[0].innerHTML+‘’);”);

}

@Override

public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {

super.onReceivedError(view, errorCode, description, failingUrl);

}

});

final class InJavaScriptLocalObj {

@JavascriptInterface

public void showSource(final String html) {

//html为保存的网页代码

}

}

2.使用Jsoup解析本地网页(此操作写在子线程中)

Document doc = Jsoup.parse(html);

Element element = doc.select(“video”).first(); //搜索搜索节点的id 获得element

String videoUrl = element.attr(“src”);

这时发现有时element中会没有数据

将代码改写为

if (element != null) {

String videoUrl = element.attr(“src”);

}else{

//webview重新load网页操作

}

三.获取有水印的视频链接后,更改链接

=================================================================================

String aftervideoUrl=videoUrl.replace(“playwm”,“play”);

为了方便看效果,直接用VideoView播放(低版本的测试机器,未适配高版本机器)(主线程中进行)

videoview.setVideoPath(aftervideoUrl);

videoview.requestFocus();

videoview.start();

效果图


在这里插入图片描述

由此可见,可以获取到链接,拿到链接后就可以进行其他操作了,如视频下载等。

总结

=================================================================

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值