短視頻(douyin)去水印工具的實(shí)現(xiàn)代碼
現(xiàn)在視頻號(hào)非?;馃?,之前在做抖音和快手的人就直接把之前的視頻直接搬運(yùn)過來了。但是從抖音app下載的視頻都是帶官方水印的?這個(gè)是怎么去掉的?哦,不對(duì),他們應(yīng)該都有保留原視頻的吧。但是還有很多人是直接搬運(yùn)別人的視頻的,那他們是怎么去水印的呢?
其實(shí)早就有很多現(xiàn)成的工具,如小程序、去水印app都能直接去水印,甚至還有收費(fèi)的。
趕緊研究研究,說不準(zhǔn)咱也能搞一個(gè)比他們更好的工具出來。
一頓操作猛如虎,各種抓包看數(shù)據(jù),結(jié)果簡(jiǎn)單的不得了,分分鐘內(nèi)就能給一坨視頻去水印。
其實(shí)這些去水印的工具都太夸張(忽悠)了,完全不是真的去水印,小白都以為是對(duì)視頻做了什么牛的后處理,把水印干掉了。
其實(shí)是直接下載的無水印的視頻而已。因?yàn)槟阍诙兑艉涂焓值萢pp上,看到的視頻都是不帶官方水印,所以這個(gè)無水印視頻肯定是存在的。
下面就把本人破解的過程一一說下(以douyin為例)。
1.先拿到第一個(gè)鏈接

2.嗯,在瀏覽器打開這個(gè)鏈接
然后打開剛才復(fù)制過來的地址,https://v.douyin.com/e1MMESR/ 。
3. 打開地址發(fā)現(xiàn)有302跳轉(zhuǎn)

4.然后播放左側(cè)的視頻,竟然變成了帶水印的視頻。
我們?cè)赼pp里播放的看不到水印的,但是在瀏覽器打開就是有水印的。

5.在控制臺(tái)發(fā)現(xiàn)有ajax請(qǐng)求,返回了該視頻的全部信息,當(dāng)然也包括視頻地址

6.找到視頻播放地址video.play_addr.url_list[0]
上面這個(gè)地址和我們?cè)诳刂婆_(tái)審查元素看到的video播放的是一個(gè)地址,但是都是帶水印的地址。

起碼是一個(gè)信息,先把這個(gè)地址記錄下來。
7.另尋他路,從個(gè)人中心的視頻列表入手
拿到個(gè)人的視頻列表地址(進(jìn)入個(gè)人中心點(diǎn)擊分享,有復(fù)制鏈接)https://v.douyin.com/e1MCMaT/。
8.瀏覽器打開,從控制臺(tái)分析接口數(shù)據(jù)
這個(gè)就是接口返回的視頻列表數(shù)據(jù),不過也就是前幾條,暫時(shí)還沒看怎么拿到全部。

9.列表數(shù)據(jù)分析,發(fā)現(xiàn)新大陸
上面接口返回了視頻列表數(shù)據(jù),這里每條數(shù)據(jù)的信息更豐富,而且發(fā)現(xiàn)了無水印地址。
每一個(gè)視頻都有4個(gè)播放地址,估計(jì)是cdn,用來分流的,其實(shí)這就是無水印的播放地址。

10.停止搜索,終點(diǎn)已到
上面的地址看上去內(nèi)容差別挺大,依次打開后發(fā)現(xiàn)前兩個(gè)都直接播放,后兩個(gè)都有302跳轉(zhuǎn)后播放。
再看下第三條地址,好像有點(diǎn)面熟
//第三條地址 https://aweme.snssdk.com/aweme/v1/play/?video_id=v0300f760000c0fq7t5t1gvidv0rdtag&line=0&ratio=720p&media_type=4&vr_type=0&improve_bitrate=0&is_play_url=1&source=PackSourceEnum_DOUYIN_REFLOW //上面保存的 https://aweme.snssdk.com/aweme/v1/playwm/?video_id=v0300f760000c0fq7t5t1gvidv0rdtag&ratio=720p&line=0
很明顯,地址一樣幾乎一模一樣,只是參數(shù)不同。
參數(shù)可以忽略,就看地址差別在于/playwm/和/play/,差了個(gè)wm。
到這里,咱們算是大功告成了,去掉wm的就是無水印播放地址。wm是個(gè)啥?就是水印的英文簡(jiǎn)寫watermark。
11.下載就完了
直接打開播放,在播放的視頻上右鍵保存,完事兒。

本人后面也做很多測(cè)試,以上路子ok。
12.快手的怎么搞?
快手的就更簡(jiǎn)單了,完全沒有隱藏,直接瀏覽器打開就是無水印的視頻。明顯抖音多做了一些。
搞個(gè)下載工具?
現(xiàn)在我們兩步就可以下載到無水印視頻了,但都是手動(dòng)下載。所以我們要做成工具,直接輸入視頻地址就可以一鍵下載。
如何實(shí)現(xiàn)?手動(dòng)下載很容易,但如果搞成自動(dòng)的,就沒那么順利,因?yàn)槠脚_(tái)早就意識(shí)到這個(gè)問題,也是做了防御的了。
下面有兩個(gè)方案,最終的目標(biāo)都是拿到視頻的播放地址,然后下載視頻。
實(shí)現(xiàn)方案A
走平臺(tái)的api接口,拿到播放地址。不過很可能會(huì)遇到坑,平臺(tái)應(yīng)該早就對(duì)這種操作有方案,會(huì)被拒。
方案B
這個(gè)應(yīng)該更簡(jiǎn)單,更有效,使用無頭瀏覽器來拿到視頻的地址,接口請(qǐng)求省了。
部分代碼
代碼還么有寫完整,只寫了一個(gè)下視頻和拿到api請(qǐng)求地址。
//下載視頻
const path = require('path')
const fs = require('fs')
const request = require('request')
/**
* 下載視頻
*/
function downVideo(url) {
var fileName = `${+new Date()}.mp4`
var fullPath = path.resolve('./videos/' + fileName);
console.log('開始下載視頻:', fileName);
request(encodeURI(url)).on('error', function (err) {
console.log(error)
}).pipe(fs.createWriteStream(fullPath)).on('finish', () => {
console.log('視頻下載成功');
})
}
const url = 'http://v6-z.douyinvod.com/719423c89357069fffd503a6698436f9/60342b2c/video/tos/cn/tos-cn-ve-15/56505c3774bd46de98d6a49e2315e292/?a=1128&br=4996&bt=1249&cd=0%7C0%7C0&ch=0&cr=0&cs=0&cv=1&dr=0&ds=3&er=&l=2021022300074001020410813542130635&lr=&mime_type=video_mp4&pl=0&qs=0&rc=and1eWxqd3d0MzMzOWkzM0ApZTw2NWhoZGRpNzs7ZTc4OWcpaGRqbGRoaGRmXmEtYXMuMjRjYC0tNC0wc3MzLjY1XzMxNjE2Ly4xMDFhOmNwb2wrbStqdDo%3D&vl=&vr='
downVideo(url)
//獲取api地址
function getApiUrl(url){
//前端傳過來的地址 進(jìn)行重定向拿到 item_ids 并且返回
return new Promise(resolve => {
request(url, (error, response) => {
if (!error && response.statusCode == 200) {
let href = response.request.href;
let id = '';
id = href.match(/video\/(\S*)\/\?region/)[1];
resolve(`https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids=${id}`);
} else {
resolve(false)
}
})
});
}
getApiUrl('xxx').then(api=>{
//xxx
})后面會(huì)把代碼補(bǔ)全,寫一個(gè)完整的"去水印"工具,掛到我自己的站上。
最后
整個(gè)過程沒什么難度,不過挺好玩。而且發(fā)現(xiàn)了很多有意思的東西,就上面那個(gè)視頻列表內(nèi)的信息很多很多,還可以挖掘一下。
到此這篇關(guān)于市面上短視頻(douyin)"去水印"的工具原來是這樣實(shí)現(xiàn)的的文章就介紹到這了,更多相關(guān)短視頻去水印工具內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript中find()和?filter()方法的區(qū)別小結(jié)
js中find和filter方法大家在工作中會(huì)經(jīng)常遇到,那么他們有什么區(qū)別呢?這篇文章主要給大家介紹了關(guān)于JavaScript中find()和?filter()方法區(qū)別的相關(guān)資料,需要的朋友可以參考下2021-12-12
使用TypeScript實(shí)現(xiàn)楊輝三角的代碼示例
楊輝三角,又稱帕斯卡三角,是一個(gè)數(shù)學(xué)上非常有趣和重要的概念,它是一種數(shù)學(xué)結(jié)構(gòu),它不僅可以用于組合數(shù)學(xué),還可以應(yīng)用于代數(shù)、概率和許多其他領(lǐng)域,在本文中,我們將通過使用?TypeScript?來編寫楊輝三角的程序,同時(shí)深入探討?TypeScript?的類型系統(tǒng)2023-09-09
JS/HTML5游戲常用算法之碰撞檢測(cè) 包圍盒檢測(cè)算法詳解【凹多邊形的分離軸檢測(cè)算法】
這篇文章主要介紹了JS/HTML5游戲常用算法之碰撞檢測(cè) 包圍盒檢測(cè)算法,結(jié)合實(shí)例形式詳細(xì)分析了javascript針對(duì)凹多邊形的分離軸檢測(cè)算法相關(guān)概念、原理、實(shí)現(xiàn)技巧與操作注意事項(xiàng),需要的朋友可以參考下2018-12-12
javascript實(shí)現(xiàn)仿騰訊游戲選擇
這篇文章主要介紹了javascript實(shí)現(xiàn)仿騰訊游戲選擇,簡(jiǎn)單實(shí)現(xiàn)的下拉菜單二級(jí)聯(lián)動(dòng)效果,十分不錯(cuò),有需要的小伙伴可以參考下。2015-05-05
JavaScript立即執(zhí)行函數(shù)IIFE的用法詳解
在JavaScript開發(fā)中,立即執(zhí)行函數(shù)(Immediately Invoked Function Expression,簡(jiǎn)稱IIFE)是一種非常實(shí)用的設(shè)計(jì)模式,本文將深入探討IIFE的基本概念、作用以及實(shí)際應(yīng)用場(chǎng)景,并通過多個(gè)示例幫助開發(fā)者更好地掌握這一技術(shù),需要的朋友可以參考下2025-02-02
HTML+CSS+JS實(shí)現(xiàn)完美兼容各大瀏覽器的TABLE固定列
本文給大家分享的是使用HTML+CSS+JS實(shí)現(xiàn)完美兼容各大瀏覽器的TABLE固定列的方法和示例,非常的實(shí)用,特別是在BS架構(gòu)的企業(yè)級(jí)應(yīng)用,有需要的小伙伴可以參考下。2015-04-04

