不信人间有白头

分类: android

曲淡歌
曲淡歌@qudange

2024 年 7 月 13 日

安卓端用tasker实现ai总结b站 

前言

本文的实现方式受到chrome拓展ChatGPTBox的启发,原理是通过b站的api和cookie获得自动ai字幕,然后用大语言模型(LLM)来总结字幕,从而获得视频的总结。

此工具的功能是帮助用户快速总结视频内容,以提高信息获取的速度。诚然,b站自己也推出了ai总结功能,但是那个功能很不稳定,有时候对一个视频有详细而结构化的总结,有时却只能得到一句话的概括,即便LLM已经火了两三年了,b站仍没有在这块投入过多,因此只能自己动手,丰衣足食。

本工具的缺点:
1. 无法总结没有字幕的视频(但是像bibigpt和b站官方的ai总结有时候能总结没有字幕的视频,我怀疑是有其他途径获取字幕)
2. 对视频内容和音频内容非强相关的视频无效(例如一个ASMR催眠视频,如果只用声音来判断,可能整个视频都是没有意义的。我们期待在未来多模态的ai能解决这个问题)
3. 需要使用b站的cookie才能获取视频字幕,而cookie是动态变化的,因此需要cookie刷新机制,我的处理办法是使用cookiecloud(需要自己的服务器/托管在别人的服务器上)

安卓端利用tasker实现ai总结b站

工作原理

  1. 如果视频是手机分享的短链接形式(https://b23.tv/xxxxx ),则通过域名重定向获取bid(BVxxxxxx)
  2. 已知bid后,获取cid https://api.bilibili.com/x/web-interface/view?bvid=%bid
  3. 已知bid和cid后,获取包含字幕链接subtitle_url的信息https://api.bilibili.com/x/player/v2?cid=%cid&bvid=%bid
  4. 将字幕发送通过api发送给ai,让ai总结

案例:

以视频【游戏试玩】杀戮尖塔+娃娃机=抓抓地牢?游戏实况 为例,如果采用安卓端国内版bilibili应用分享链接,得到的链接为【【游戏试玩】杀戮尖塔+娃娃机=抓抓地牢?-哔哩哔哩】 https://b23.tv/jpcq7rz

(隐藏的第一步为获取最新的cookie,因为实现方法不唯一,在下一章节介绍)

因此第一步是要从文字中提取出链接,一般采用正则

(https?|ftp|file)://[-A-Za-z0-9+&@#/%?=~_|!:,.;]+[-A-Za-z0-9+&@#/%=~_|]

得到结果为https://b23.tv/jpcq7rz,然后我们需要将短链接转为长链接,最简单的办法就是使用浏览器的重定向功能,最终将得到https://www.bilibili.com/video/BV1DC411J7Wy/

然后使用正则提取出bid,正则如下:

BV([^/?]+)

即得到BV1DC411J7Wy

然后执行http get https://api.bilibili.com/x/web-interface/view?bvid=BV1DC411J7Wy 可以获取一个json文件,需要从中提取cid,因此执行两次正则

正则1(先匹配cid):

"cid":(\d+)

得到:"cid":1524209082

正则2(提取cid的值):

(\d+)

得到1524209082

然后获取字幕url,执行http get https://api.bilibili.com/x/player/v2?cid=1524209082&bvid=BV1DC411J7Wy
注意,header中需要加入cookie,如

User-Agent:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36
Cookie:%cookieString

然后会获得一个包含键为subtitle_url的json文件(前提是视频有字幕),因此这里为了避免不存在字幕产生的误会,需要做一个有无的判断

用正则进行匹配

//[-A-Za-z0-9+&@#/%?=~_|!:,.;]+[-A-Za-z0-9+&@#/%=~_|]

如果不匹配,则提示此视频无字幕,若满足则进行下一步

subtitle_url执行http get,获得json,提取键content

然后把content的内容http post给LLM

headers:

Authorization: Bearer %api_key

body:

{
    "model": "%llm_model",
    "messages": [
        {
            "role": "user",
            "content": "用尽量简练的语言,采用markdown语法书写(不要用代码块包裹),联系视频标题,对视频进行内容摘要,同时仍要保留重要细节和标题信息,视频标题为:%bili_name,字幕内容为:%subtitle"
        }
    ],
    "use_search": true,
    "stream": false
}

然后就能获得ai总结的内容了

同步cookie

我选择使用开源项目CookieCloud实现cookie的同步

变量解释:
%cookiecloud_urlcookiecloud服务器域名,例如:https://cookiecloud.25wz.cn/,注意,结尾没有/
%cookiecloud_uuid:见cookiecloud插件文档
%cookiecloud_key:见cookiecloud插件文档

步骤详解:

执行http get %cookiecloud_url/get/%cookiecloud_uuid
请求的body如下:

password%cookiecloud_key

这一步会获得解码后的json,包括cookie和localdata

然后通过JavaScriptlet来格式化cookie

var jsonData = JSON.parse(local('%http_data'));
var cookies = jsonData.cookie_data[".bilibili.com"];
var result = [];

for (var i = 0; i < cookies.length; i++) {
    var name = cookies[i].name;
    var value = cookies[i].value;
    result.push(name + "=" + value);
}

// 将结果存储在Tasker的全局变量中
setGlobal('cookieString', result.join(';'));

注:其实这一步理论上只需要SESSDATA,我为了省事这么写了。
格式化得到a=1,b=2,c=3格式的cookie信息,然后参见上一章完成目标即可。

本文永久更新地址:

https://blogs.qudange.top/p/2024-07-13-android_tasker_ai_summary/

#Ai #[5] #[17] #gpt #LLM
2024 年 7 月 13 日 202 64

回复

曲淡歌
曲淡歌@qudange

2024 年 4 月 1 日

三星浏览器调教记录 

切换搜索引擎为bing

应用商店自带的国行三星浏览器只能用百度,360和神马搜索,下面给出解决办法:
1. google play下载三星浏览器beta
2. 在beta版中输入网址:internet://debug/
3. 保持这个网页,打开浏览器设置页面,最下方会出现【Debug settings】
4. 选择【Feature variation test】
5. 修改【Sales code】为【ACG】(其实不是中国的就行)
6. 修改【Country code】为【USA】
7. 修改【Country iso code】为【US】
8. 前往设置中修改搜索引擎,此时应该有google bing等选项

启用三星浏览器的广告拦截

国行商店下架了拦截插件,需要去google play手动下载

Magisk模块ChromeXt给浏览器提供脚本和控制台支持

我是一个重度沉浸式翻译使用者,最近因为三星浏览器更新了AI总结功能,为了吃上AI换用了三星浏览器。但是三星浏览器原生是不支持油猴脚本的,因此我们需要用到一个面具模块——chromext

chromext项目地址:https://github.com/JingMatrix/ChromeXt

使用方法:刷入模块后可打开这个网址来检测是否正常工作:https://jingmatrix.github.io/ChromeXt/

注意事项:在类似kiwi这种魔改较少的浏览器中,可以直接打开js文件来安装脚本,而三星浏览器不能打开js文件,所以需要先随便找个网页单击长按,然后选中【Eruda console】,进入【info】栏,在【UserScripts】中点击加号,手动选择js文件

如何调用第三方下载器?

本文永久更新地址:

https://blogs.qudange.top/p/2024-04-01-samsung/

#[5] #[17] #[4]
2024 年 4 月 1 日 370
曲淡歌
曲淡歌@qudange

2023 年 7 月 7 日

安卓使用 Thanox 实现安装新应用自动加入 Magisk 的 Denylist(Shamiko 实现) 

如果你想在安卓设备上得到最佳体验的话,Root 是必须的,而在现在 Magisk 仍然是最优的 Root 选择,但是目前很多 app 都会对 Root 进行检测,尤其是不少应用在第一次检测到设备上有 Root 的痕迹后便会把设备列入一个名单,因此在安装应用后的第一时间就做好反检测措施是很有必要的。

下面我介绍如何便捷的实现安装新应用后,自动把新应用加入 Magisk 的 Denylist中(Shamiko 实现)。

使用 Thanox 的情景模式,添加如下代码:

[
{
"name": "AutoMagiskHide",
"description": "新应用安装时,自动MagiskHide(shamiko)",
"priority": 2,
"condition": "pkgAdded == true",
"actions": [
"ui.showShortToast(\"已添加新应用:\"+pkgName+\",已加入Magisk Denylist:\" + su.exe(\"magisk --denylist add \"+pkgName));"
]
}
]

如果是使用的早期的 Magisk,那就是 Magiskhide,原理类似。
贴一下新老两个版本的 Magisk 文档,tools 那节就有具体的用法。

Magisk Denylist:Magisk Tools | Magisk (topjohnwu.github.io)
Magiskhide: Magisk Tools — Magisk documentation

本文永久更新地址:

https://blogs.qudange.top/p/2023-07-07-magisk/

#[5] #[17] #[4] #root #搞机
2023 年 7 月 7 日 587

Loading...
载入中

已到底部

没有可加载的页面

C
写微博
S
搜索
J
下一篇微博/评论
K
上一篇微博/评论
R
回复
E
编辑
O
显示隐藏评论
T
回顶部
L
登录
H
显示隐藏帮助
Ctrl+Enter
提交发布
ESC
取消并清除内容