Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

作者有增加画中画播放的打算吗? #3

Open
wants to merge 329 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 72 commits
Commits
Show all changes
329 commits
Select commit Hold shift + click to select a range
a736309
Add files via upload
Roinlong Sep 19, 2022
0c9005c
Add files via upload
Roinlong Sep 19, 2022
377e292
添加由于网路原因没能成功上传的文件
Roinlong Sep 19, 2022
5f785e0
Update LivePlayActivity.java
Roinlong Sep 19, 2022
ce88774
Add files via upload
Roinlong Sep 19, 2022
44aca0a
添加EPG自定义设置接口
Roinlong Sep 19, 2022
5aee5f2
添加EPG自定义设置接口
Roinlong Sep 19, 2022
2169aa3
Revert "添加EPG自定义设置接口"
Roinlong Sep 19, 2022
b267210
Merge remote-tracking branch 'origin/main'
Roinlong Sep 19, 2022
aa75a6c
Revert "添加EPG自定义设置接口"
Roinlong Sep 19, 2022
5aee58b
修改自定义格式,自定义EPG可以不用加 ?ch=
Roinlong Sep 19, 2022
506d85e
Update ApiDialog.java
Roinlong Sep 20, 2022
2f6f26e
- 字幕大小自适应
Sep 20, 2022
215dd80
- 增加字幕记忆
Sep 21, 2022
08e9051
- ijk支持切换音轨
Sep 22, 2022
96da84e
历史记录可查看上次看到哪一集 长按选择播放器 长按关闭外挂字幕
q215613905 Sep 22, 2022
f3c3bc8
- 字幕解析bug修复
Sep 23, 2022
1593fb8
- ijk支持内置字幕
Sep 23, 2022
43bedf5
- 字幕加载逻辑优化
Sep 24, 2022
794602e
热搜词改回腾讯热搜 …
q215613905 Sep 24, 2022
38b7df4
- 内置字幕默认选择中文
Sep 25, 2022
0d949e3
热搜词修正 优化聚搜逻辑 …
q215613905 Sep 26, 2022
557171f
- 搜索页支持指定搜索源
Sep 27, 2022
660a2ae
优化底部EPG信息栏显示逻辑
Roinlong Sep 27, 2022
6deb12f
- 搜索页指定搜索源优化
Sep 27, 2022
4947aa4
- 搜索页指定搜索源bug修复
Sep 27, 2022
434ff05
嗅探优化;播放字号统一;其他小调整
q215613905 Sep 27, 2022
3903689
Update HomeActivity.java
Roinlong Sep 27, 2022
668c9d9
嗅探再次优化 解决倒叙后相同位置集数播放…
q215613905 Sep 27, 2022
0d91913
Merge remote-tracking branch 'origin/main'
q215613905 Sep 27, 2022
b20462e
?
q215613905 Sep 27, 2022
4d5740e
Add files via upload
llb0 Sep 28, 2022
d882828
Add files via upload
llb0 Sep 28, 2022
4c2ab5a
Add files via upload
llb0 Sep 28, 2022
9cab75b
- 搜索页指定搜索源TV端bug修复
Sep 28, 2022
8f6e2bc
Add files via upload
llb0 Sep 28, 2022
b2d3231
- 搜索页指定搜索源TV端bug修复
Sep 28, 2022
f372376
Merge pull request #56 from llb0/main
q215613905 Sep 28, 2022
a680c46
播放列表循环播放
q215613905 Sep 28, 2022
65a11d0
解决小窗模式下短视频竖屏闪退;聚合搜索数量显示真实计数;嗅探调整;
q215613905 Sep 28, 2022
6f261c5
Add quickjs support.
Sep 29, 2022
2afab8b
Merge pull request #57 from ShadowDemon1997/dev
okcaptain Sep 29, 2022
e9a1125
- 去掉EPG本地存储权限相关
Sep 29, 2022
146944f
- live播放出现点击没反应bug修复
Sep 29, 2022
259a56e
再次优化嗅探 解决收藏夹闪退
q215613905 Sep 29, 2022
8973279
- live播放出现点击没反应bug修复
Sep 30, 2022
7fc45ff
解决阿里系未开小窗播放闪退问题
q215613905 Sep 30, 2022
8fa716f
add dr support step 0.1
Sep 30, 2022
052a918
add dr support step 0.1
Sep 30, 2022
97d29e8
- 嗅探优化
Sep 30, 2022
e81e06c
- parse优化
Sep 30, 2022
b5ed2bb
- 预览窗口播放竖屏返回的bug修复
Sep 30, 2022
5643842
Add js local.delete
Sep 30, 2022
b836832
Merge branch 'q215613905:main' into main
ShadowDemon1997 Sep 30, 2022
3419a6a
Merge pull request #58 from ShadowDemon1997/main
q215613905 Oct 1, 2022
e9fc43e
- 搜索页指定搜索源全局
Oct 1, 2022
675e81f
- 首页热点推荐不出现的bug修复
Oct 1, 2022
1469c78
- 一些优化
Oct 3, 2022
3386a1e
- bug fix
Oct 3, 2022
0d8abea
- 推送剪切板已支持各类短视频和直播分享链接
Oct 4, 2022
b85f62e
- 推送视频
Oct 4, 2022
9f64453
- 直播相关bug修复
Oct 5, 2022
032a299
- 一些优化
Oct 5, 2022
9b0ff83
- 嗅探规则配置相关
Oct 5, 2022
a3f0f35
解决部分在线配置加载失败;解决播放记录未同步问题;恢复嗅探默认正则正则未包含到的视频请自行配置rules;其他小调整
q215613905 Oct 7, 2022
854b7d6
drpy 本地js 支持.
Oct 8, 2022
13f4b2c
drpy 本地js 支持.
Oct 8, 2022
834517d
Merge pull request #61 from ShadowDemon1997/main
q215613905 Oct 8, 2022
64b8c46
- 修复更换配置引起指定搜索源bug修复 (by okjack)
Oct 9, 2022
8a1727a
web嗅探支持ext里的UA传递;支持点击播放的站点嗅探;热词联想小调整;rules规则小调整
q215613905 Oct 10, 2022
bcf7bef
小窗模式下取消循环播放;点击播放嗅探配置兼容不带域名的方式;修正非小窗模式不支持click
q215613905 Oct 10, 2022
4c3f550
参考使用
Tangsan99999 Oct 11, 2022
9ab506e
参考使用
Tangsan99999 Oct 11, 2022
8f5b582
Merge remote-tracking branch 'origin/main'
Tangsan99999 Oct 11, 2022
62cfd26
Merge pull request #63 from Tangsan99999/main
q215613905 Oct 11, 2022
ec04fe6
修正图床bug;修正嗅探偶发报错;
q215613905 Oct 11, 2022
e5cdb49
修正pk加密方式不能解析
q215613905 Oct 12, 2022
dc61861
图床bugFixed
q215613905 Oct 12, 2022
9abe4af
1兼容道长本地js(drpy);2首页UI调整;3热搜词联想切换为爱奇艺;4 js引擎-req方法识别Content-Type;5嗅探带上…
q215613905 Oct 15, 2022
7b51216
紧急修复图床
q215613905 Oct 15, 2022
caad279
1兼容道长本地js(drpy);js引擎-req方法识别Content-Type(完善);
q215613905 Oct 18, 2022
4bab3fc
增加首页推荐多行显示开关; 更完善的兼容道长drpy; 搜索软键盘bug修正; 播放地址随播放切换; 全局旋转
q215613905 Oct 21, 2022
c1c358c
直播支持回看 回看增加滑动进度条
Roinlong Oct 23, 2022
05012f0
修复直播bug
Roinlong Oct 23, 2022
f2cfb95
- 嗅探相关(by okjack)
Oct 24, 2022
dff7367
-
Oct 24, 2022
dd110cc
- 字幕黑边 (by okjack)
Oct 24, 2022
29fd780
- 字幕黑边bug (by okjack)
Oct 25, 2022
4d62279
- 指定搜索源弹窗卡顿bug修复 (by okjack)
Oct 26, 2022
f7fb0d4
- 为jar使用webview提供支持 (by okjack)
Oct 26, 2022
5fc541f
首页小调整;嗅探可携带cookie播放
q215613905 Oct 27, 2022
151624d
修正系统自带view携带cookie不生效的问题
q215613905 Oct 27, 2022
eb4bc85
修复直播换源闪退
Roinlong Oct 28, 2022
db05837
- 设置新增搜索附近TVBox(beta版)(by okjack)
Oct 28, 2022
ff1fa0e
- 搜索附近TVBox的bug修复(by okjack)
Oct 28, 2022
6bc35ce
- 优化搜索局域网TVBox速度(by okjack)
Oct 29, 2022
9ccbeb9
片头片尾逻辑更新(借鉴fongmi);首页小调整;修正嗅探rule换源时无限叠加的bug;m3u8播放失败重试时添加外部代理(临时逻辑)
q215613905 Oct 30, 2022
57a5a67
- 设置页面UI对齐(by okjack)
Oct 31, 2022
a2737b3
- 去除推送剪切板url正则(by okjack)
Oct 31, 2022
db36609
引入长按倍速播放(借鉴taka);图床增加更多图片格式的支持;播放进度常驻
q215613905 Nov 3, 2022
e631bcf
去除右上角播放进度;配置加载优化(已内置ijk解码和ads);竖屏按钮播放短视频时才显示
q215613905 Nov 4, 2022
282b123
直播无需jar代理;兼容蜂蜜在线配置;竖屏按钮显示时机修正
q215613905 Nov 5, 2022
4ba1c6b
- 显示底部菜单时,下一集按钮获得焦点(by okjack)
Nov 5, 2022
9519049
修正图床加载bug;修正多直播源不识别
q215613905 Nov 5, 2022
3c86242
修正图床加载bug;修正多直播源不识别
q215613905 Nov 5, 2022
3ac5bde
Merge remote-tracking branch 'origin/main'
q215613905 Nov 5, 2022
c85f0a8
嗅探调整
q215613905 Nov 7, 2022
ab7429c
安卓P以上版本的刘海屏适配; 搜索界…
q215613905 Nov 9, 2022
f3e8d3a
播放控制器延长为10秒后消失
q215613905 Nov 9, 2022
71edbbb
修复解析url
power721 Nov 11, 2022
579a61d
Merge pull request #69 from power721/bug/encode-url
q215613905 Nov 11, 2022
2cfb82f
集数动态分组; …
q215613905 Nov 11, 2022
9818a20
补充提交
q215613905 Nov 11, 2022
19e8d20
恢复内置ijk配置(优先调用用户自己的配置);修正一处集数分组bug
q215613905 Nov 11, 2022
85a77cd
修正部分电视盒子选集焦点丢失问题
q215613905 Nov 12, 2022
78a641e
解决搜索播放返回焦点丢失问题; epg配置…
q215613905 Nov 12, 2022
4f64937
快速搜索:加强分词
power721 Nov 12, 2022
f4c7156
解决移动网络下ijkplayer播放视频手动快进时出现的卡顿问题
linhua55 Nov 13, 2022
a7ce520
- 预览窗口可选中(by okjack)
Nov 13, 2022
5935c02
Merge remote-tracking branch 'origin/main'
Nov 13, 2022
f45d0b2
Merge pull request #72 from linhua55/main
Roinlong Nov 13, 2022
9ca35bf
Merge pull request #70 from power721/feature/split-words
Roinlong Nov 13, 2022
6e57c88
预览窗口自动适应字幕大小
power721 Nov 13, 2022
ecb3f6d
Merge pull request #71 from power721/feature/subtitle-text-size
Roinlong Nov 13, 2022
3da3ebe
修正集数分组倒叙问题;修正集数分组偶发性滚动不到位的问题
q215613905 Nov 14, 2022
b002eda
选中filter后图标变色
power721 Nov 14, 2022
5bec478
修复预览窗口字幕大小
power721 Nov 14, 2022
746d2a6
Merge pull request #73 from power721/feature/filter-icon-color
Roinlong Nov 14, 2022
e550335
支持jar图床(img+开头)
q215613905 Nov 15, 2022
75b664b
修复filter闪退
power721 Nov 15, 2022
c0e6c8f
修复filter key错误
power721 Nov 16, 2022
a95dc90
API传递filter参数
power721 Nov 17, 2022
029d786
修复filter图标显示
power721 Nov 17, 2022
2d5b4c8
Merge pull request #75 from power721/feature/filter-unselect
Roinlong Nov 17, 2022
e729d14
直播微调;嗅探词微调;下拉选择框微调
q215613905 Nov 19, 2022
afc80be
详情样式修正
q215613905 Nov 19, 2022
0eb8e57
- 引入quickjs-android (by okjack)
Nov 28, 2022
31f9405
- js相关bug修复 (by okjack)
Nov 28, 2022
b5e1daf
- js相关bug修复 (by okjack)
Nov 28, 2022
2cd49d9
- drpy搜索bug修复 (by okjack)
Nov 28, 2022
62a3f12
- drpy2支持完善 (by okjack)
Nov 28, 2022
3739c3b
- drpy搜索结果点击闪退bug修复 (by okjack)
Nov 29, 2022
710b84e
- 直播网速显示问题修复,默认网速显示关闭 (by okjack)
Nov 29, 2022
5d2eb67
- drpy请求默认超时时间5s (by okjack)
Nov 29, 2022
de1f2d7
- drpy2完善 (by okjack)
Nov 30, 2022
9efbe2d
- IJK播放器,mp3,mkv,avi等边缓存边播放(公测功能,有bug请反馈) (by okjack)
Dec 2, 2022
b54626d
- IJK缓存相关
Dec 2, 2022
f3b8e3e
- 限制IJK单个播放文件缓存最大容量 (by okjack)
Dec 2, 2022
daebf40
- App启动时清空播放产生的缓存 (by okjack)
Dec 2, 2022
837de7c
- 修复TV清空缓存闪退bug (by okjack)
Dec 3, 2022
c777f89
- 设置新增IJK缓存播放开关,默认关闭 (by okjack)
Dec 3, 2022
2a34859
- 修复开启IJK缓存后播放一段时间自动下一集的bug (by okjack)
Dec 3, 2022
74ef785
- 首页历史记录、站点推荐选中时最左侧样式遮挡问题修复 (by okjack)
Dec 18, 2022
5d14a13
解决部分bug;改善用户体验
q215613905 Mar 1, 2023
3988b4e
修bug;
q215613905 Mar 2, 2023
e64962d
修复重播:重置进度条
power721 Nov 29, 2022
505aa3b
修复外挂字幕闪退
power721 Nov 29, 2022
6525b18
支持VLC播放器
power721 Jan 18, 2023
984ad7c
自动关闭远程搜索对话框
power721 May 21, 2023
c9b1364
支持影视接口规则
power721 May 27, 2023
42dbef5
支持影视接口规则
power721 May 27, 2023
a5208f9
Merge pull request #85 from power721/dev
q215613905 Jun 1, 2023
dbc413b
更新ijk解码库;还原集数分组;缩短直播无响应时自动换源时间
q215613905 Jun 1, 2023
7a0cfd6
修bug
q215613905 Jul 12, 2023
73f8328
配置加载优化;直播右上角bug修正;去掉始终m3u8优先排序;修正部分源filters筛选加载bug
q215613905 Jul 15, 2023
5775c0e
图片加载支持@Headers
q215613905 Jul 16, 2023
4f919c5
支持荐片播放;支持普通ftp视频播放;支持电驴ed2k播放;修正退出播放时未停止磁力下载的bug
q215613905 Jul 20, 2023
7197760
修荐片播放bug;ijk配置优化
q215613905 Jul 21, 2023
fdc44e2
直播列表加载rtp协议;修正一处T4 bug;分类列表可从文件夹和封面形式自由切换
q215613905 Jul 25, 2023
3e6c422
修正部分图片不显示的问题;
q215613905 Aug 1, 2023
2f044d8
修闪退bug;修磁力bug;修图片bug
q215613905 Aug 5, 2023
f0d155e
更新影魔ff4;完善一次提交
q215613905 Aug 5, 2023
d97ed6f
修分类封面/文件夹切换bug;修主页配置加载时间过长不能操作的bug;添加dns;修磁力推送解析bug
q215613905 Aug 11, 2023
289e960
T4支持ext配置;当没有站点推荐时默认加载豆瓣热播推荐;
q215613905 Aug 14, 2023
bcc47f1
get-push
watson1982 Aug 14, 2023
39293e0
DetailActivity.java+push
watson1982 Aug 17, 2023
c2561a1
SourceViewModel.java+push
watson1982 Aug 17, 2023
eaa3ddc
DetailActivity.java+history
watson1982 Aug 17, 2023
2b5166d
SourceViewModel.java+secondary page push
watson1982 Aug 17, 2023
41d59c3
Merge pull request #100 from watson1982/main
q215613905 Aug 18, 2023
a17b24c
再次修正部分图片不加载问题;兼容msg(toast消息);兼容subs字幕(只取第1个);
q215613905 Aug 18, 2023
ab7d7d4
;
q215613905 Aug 18, 2023
0702c11
修复ed2k 和 magnet 磁力链接剧集反复切换可能会引起 playUrl 为null的异常
zhixc Aug 18, 2023
d2972fc
修复历史记录页面删除记录速度过快出现的索引越界异常
zhixc Aug 18, 2023
dd2db1b
修复部分在线字幕加载闪退的bug
zhixc Aug 19, 2023
a2ec375
exo+netspeed
watson1982 Aug 21, 2023
b0482f8
define netspeed
watson1982 Aug 21, 2023
452457f
AndroidMediaPlayer+netspeed
watson1982 Aug 21, 2023
59f6785
VodController+lock
watson1982 Aug 21, 2023
589c651
icon_lock.xml
watson1982 Aug 21, 2023
2381fa0
Update player_vod_control_view.xml
watson1982 Aug 21, 2023
f8d07a9
T4 ext兼容本地json文件; 修正蜂蜜bili闪…
q215613905 Aug 21, 2023
a131e7a
RoomDataManger.java+del all
watson1982 Aug 21, 2023
59ded04
VodCollectDao.java+del all
watson1982 Aug 21, 2023
ac67c21
Update VodRecordDao.java+del all
watson1982 Aug 21, 2023
b2a10d8
CollectActivity+del all
watson1982 Aug 21, 2023
203e9c1
HistoryActivity+del all
watson1982 Aug 21, 2023
6c06a4d
ConfirmClearDialog.java
watson1982 Aug 21, 2023
8ff3d96
Update HawkConfig.java
watson1982 Aug 21, 2023
cd089bf
button_dialog_vod.xml
watson1982 Aug 21, 2023
6496025
icon_clear.xml
watson1982 Aug 21, 2023
1604ccb
Update activity_collect.xml
watson1982 Aug 21, 2023
e611418
Update activity_history.xml
watson1982 Aug 21, 2023
31d46f5
dialog_confirm.xml
watson1982 Aug 21, 2023
691f178
Update colors.xml
watson1982 Aug 21, 2023
722bad7
dialog_confirm.xml
watson1982 Aug 21, 2023
d09e459
HistoryAdapter
watson1982 Aug 21, 2023
4b5c5dd
HomeHotVodAdapter
watson1982 Aug 21, 2023
acc4b8e
item_grid.xml
watson1982 Aug 21, 2023
11203b0
item_user_hot_vod
watson1982 Aug 21, 2023
eb910de
shape_user_delete.xml
watson1982 Aug 21, 2023
835b682
Update colors.xml
watson1982 Aug 21, 2023
4bcd1b2
HomeActivity+del mode
watson1982 Aug 21, 2023
e379fda
Merge branch 'q215613905:main' into main
watson1982 Aug 21, 2023
6b9f0be
紧急修正部分dash视频闪退
q215613905 Aug 21, 2023
5e62124
UserFragment+check del mode
watson1982 Aug 21, 2023
231af14
UserFragment.java
watson1982 Aug 21, 2023
61c486c
Merge branch 'q215613905:main' into main
watson1982 Aug 21, 2023
d4e034f
Update button_dialog_vod.xml
watson1982 Aug 21, 2023
c6c1499
Update dialog_confirm.xml
watson1982 Aug 21, 2023
5b7e302
Update colors.xml
watson1982 Aug 21, 2023
0b1acc6
UserFragment.java
watson1982 Aug 21, 2023
0027338
VodController.java
watson1982 Aug 21, 2023
c5fd9ce
ScreenUtils.java
watson1982 Aug 21, 2023
a7a5c46
HomeActivity.java
watson1982 Aug 21, 2023
0189e8e
Update HomeActivity.java
watson1982 Aug 21, 2023
583678b
VodController.java
watson1982 Aug 21, 2023
617a822
UserFragment.java
watson1982 Aug 21, 2023
746864c
icon_lock.xml
watson1982 Aug 21, 2023
6750427
icon_unlock.xml
watson1982 Aug 21, 2023
9000c5f
Merge pull request #101 from zhixc/dev
q215613905 Aug 22, 2023
7eebb87
Merge pull request #102 from watson1982/main
q215613905 Aug 22, 2023
94fdb84
Update PlayActivity.java
670637080 Aug 23, 2023
6687096
Update PlayFragment.java
670637080 Aug 23, 2023
428a196
补充修复json聚合并发轮询引起的闪退bug
zhixc Aug 23, 2023
4d21342
Merge pull request #105 from 670637080/main-3
q215613905 Aug 23, 2023
6b6d288
Merge pull request #106 from 670637080/main-2
q215613905 Aug 23, 2023
c0ef8aa
Merge pull request #107 from zhixc/dev
q215613905 Aug 23, 2023
20481a3
解决合并打包异常
q215613905 Aug 23, 2023
16a3217
ijk内置字幕有中文取中文没中文取第一个;解决内置字幕不消失的问题;修磁力不完全解析的问题
q215613905 Aug 23, 2023
86893e4
Js (#1)
watson1982 Aug 29, 2023
2ac9563
Update build.gradle
watson1982 Aug 29, 2023
6cbf876
Merge pull request #111 from watson1982/main
q215613905 Aug 30, 2023
14fab9c
Revert "Update build.gradle"
q215613905 Sep 1, 2023
2c7ca19
Revert "Js (#1)"
q215613905 Sep 1, 2023
8b63bf8
修正一些bug;优化图片加载;(可能是最后一版对4.4以下的支持)
q215613905 Sep 1, 2023
a2bb307
修正
q215613905 Sep 24, 2024
1a94c84
补充提交
q215613905 Sep 25, 2024
95293b0
支持cronet
q215613905 Sep 26, 2024
ff3a4a9
本地代理支持转发header
q215613905 Oct 29, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 36 additions & 0 deletions .idea/inspectionProfiles/Project_Default.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 5 additions & 0 deletions .idea/jarRepositories.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

41 changes: 37 additions & 4 deletions .idea/misc.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 7 additions & 4 deletions app/src/main/AndroidManifest.xml
Original file line number Diff line number Diff line change
Expand Up @@ -38,19 +38,22 @@

<activity
android:name=".ui.activity.LivePlayActivity"
android:screenOrientation="landscape" />
android:screenOrientation="sensorLandscape" />
<activity
android:name=".ui.activity.DetailActivity"
android:screenOrientation="landscape" />
android:screenOrientation="sensorLandscape" />
<activity
android:name=".ui.activity.PlayActivity"
android:screenOrientation="landscape" />
android:screenOrientation="sensorLandscape" />
<activity
android:name=".ui.activity.PushActivity"
android:screenOrientation="landscape" />
<activity
android:name=".ui.activity.SearchActivity"
android:screenOrientation="landscape" />
<activity
android:name=".ui.activity.FastSearchActivity"
android:screenOrientation="landscape" />
<activity
android:name=".ui.activity.SettingActivity"
android:screenOrientation="landscape" />
Expand Down Expand Up @@ -97,4 +100,4 @@
android:value="disable" />
</application>

</manifest>
</manifest>
89 changes: 83 additions & 6 deletions app/src/main/java/com/github/catvod/crawler/JarLoader.java
Original file line number Diff line number Diff line change
Expand Up @@ -3,22 +3,29 @@
import android.content.Context;

import com.github.tvbox.osc.base.App;
import com.github.tvbox.osc.util.MD5;
import com.lzy.okgo.OkGo;

import org.json.JSONObject;

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

import dalvik.system.DexClassLoader;
import okhttp3.Response;

public class JarLoader {
private DexClassLoader classLoader = null;
private ConcurrentHashMap<String, DexClassLoader> classLoaders = new ConcurrentHashMap<>();
private ConcurrentHashMap<String, Method> proxyMethods = new ConcurrentHashMap<>();
private ConcurrentHashMap<String, Spider> spiders = new ConcurrentHashMap<>();
private Method proxyFun = null;
private volatile String recentJarKey = "";

/**
* 不要在主线程调用我
Expand All @@ -27,13 +34,19 @@ public class JarLoader {
*/
public boolean load(String cache) {
spiders.clear();
proxyFun = null;
recentJarKey = "main";
proxyMethods.clear();
classLoaders.clear();
return loadClassLoader(cache, "main");
}

private boolean loadClassLoader(String jar, String key) {
boolean success = false;
try {
File cacheDir = new File(App.getInstance().getCacheDir().getAbsolutePath() + "/catvod_csp");
if (!cacheDir.exists())
cacheDir.mkdirs();
classLoader = new DexClassLoader(cache, cacheDir.getAbsolutePath(), null, App.getInstance().getClassLoader());
DexClassLoader classLoader = new DexClassLoader(jar, cacheDir.getAbsolutePath(), null, App.getInstance().getClassLoader());
// make force wait here, some device async dex load
int count = 0;
do {
Expand All @@ -47,7 +60,7 @@ public boolean load(String cache) {
try {
Class proxy = classLoader.loadClass("com.github.catvod.spider.Proxy");
Method mth = proxy.getMethod("proxy", Map.class);
proxyFun = mth;
proxyMethods.put(key, mth);
} catch (Throwable th) {

}
Expand All @@ -59,21 +72,82 @@ public boolean load(String cache) {
}
count++;
} while (count < 5);

if (success) {
classLoaders.put(key, classLoader);
}
} catch (Throwable th) {
th.printStackTrace();
}
return success;
}

public Spider getSpider(String key, String cls, String ext) {
private DexClassLoader loadJarInternal(String jar, String md5, String key) {
if (classLoaders.contains(key))
return classLoaders.get(key);
File cache = new File(App.getInstance().getFilesDir().getAbsolutePath() + "/" + key + ".jar");
if (!md5.isEmpty()) {
if (cache.exists() && MD5.getFileMd5(cache).equalsIgnoreCase(md5)) {
loadClassLoader(cache.getAbsolutePath(), key);
return classLoaders.get(key);
}
}
try {
Response response = OkGo.<File>get(jar).execute();
InputStream is = response.body().byteStream();
OutputStream os = new FileOutputStream(cache);
try {
byte[] buffer = new byte[2048];
int length;
while ((length = is.read(buffer)) > 0) {
os.write(buffer, 0, length);
}
} finally {
try {
is.close();
os.close();
} catch (Exception e) {
e.printStackTrace();
}
}
loadClassLoader(cache.getAbsolutePath(), key);
return classLoaders.get(key);
} catch (Throwable e) {
e.printStackTrace();
}
return null;
}

public Spider getSpider(String key, String cls, String ext, String jar) {
String clsKey = cls.replace("csp_", "");
String jarUrl = "";
String jarMd5 = "";
String jarKey = "";
if (jar.isEmpty()) {
jarKey = "main";
} else {
String[] urls = jar.split(";md5;");
jarUrl = urls[0];
jarKey = MD5.string2MD5(jarUrl);
jarMd5 = urls.length > 1 ? urls[1].trim() : "";
}
recentJarKey = jarKey;
if (spiders.containsKey(key))
return spiders.get(key);
DexClassLoader classLoader = null;
if (jarKey.equals("main"))
classLoader = classLoaders.get("main");
else {
classLoader = loadJarInternal(jarUrl, jarMd5, jarKey);
}
if (classLoader == null)
return new SpiderNull();
try {
Spider sp = (Spider) classLoader.loadClass("com.github.catvod.spider." + clsKey).newInstance();
sp.init(App.getInstance(), ext);
if (!jar.isEmpty()) {
sp.homeContent(false); // 增加此行 应该可以解决部分写的有问题源的历史记录问题 但会增加这个源的首次加载时间 不需要可以已删掉
}
spiders.put(key, sp);
return sp;
} catch (Throwable th) {
Expand All @@ -84,6 +158,7 @@ public Spider getSpider(String key, String cls, String ext) {

public JSONObject jsonExt(String key, LinkedHashMap<String, String> jxs, String url) {
try {
DexClassLoader classLoader = classLoaders.get("main");
String clsKey = "Json" + key;
String hotClass = "com.github.catvod.parser." + clsKey;
Class jsonParserCls = classLoader.loadClass(hotClass);
Expand All @@ -97,6 +172,7 @@ public JSONObject jsonExt(String key, LinkedHashMap<String, String> jxs, String

public JSONObject jsonExtMix(String flag, String key, String name, LinkedHashMap<String, HashMap<String, String>> jxs, String url) {
try {
DexClassLoader classLoader = classLoaders.get("main");
String clsKey = "Mix" + key;
String hotClass = "com.github.catvod.parser." + clsKey;
Class jsonParserCls = classLoader.loadClass(hotClass);
Expand All @@ -110,6 +186,7 @@ public JSONObject jsonExtMix(String flag, String key, String name, LinkedHashMap

public Object[] proxyInvoke(Map params) {
try {
Method proxyFun = proxyMethods.get(recentJarKey);
if (proxyFun != null) {
return (Object[]) proxyFun.invoke(null, params);
}
Expand Down
33 changes: 29 additions & 4 deletions app/src/main/java/com/github/tvbox/osc/api/ApiConfig.java
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,8 @@ public void loadConfig(boolean useCache, LoadConfigCallback callback, Activity a
String apiFix = apiUrl;
if (apiUrl.startsWith("clan://")) {
apiFix = clanToAddress(apiUrl);
}else if(!apiUrl.startsWith("http")){
apiFix = "http://" + apiFix;
}
OkGo.<String>get(apiFix)
.execute(new AbsCallback<String>() {
Expand Down Expand Up @@ -151,6 +153,8 @@ public String convertResponse(okhttp3.Response response) throws Throwable {
if (apiUrl.startsWith("clan")) {
result = clanContentFix(clanToAddress(apiUrl), result);
}
//假相對路徑
result = fixContentPath(apiUrl,result);
return result;
}
});
Expand Down Expand Up @@ -244,6 +248,8 @@ private void parseJson(String apiUrl, String jsonStr) {
sb.setFilterable(DefaultConfig.safeJsonInt(obj, "filterable", 1));
sb.setPlayerUrl(DefaultConfig.safeJsonString(obj, "playUrl", ""));
sb.setExt(DefaultConfig.safeJsonString(obj, "ext", ""));
sb.setJar(DefaultConfig.safeJsonString(obj, "jar", ""));
sb.setPlayerType(DefaultConfig.safeJsonInt(obj, "playerType", -1));
sb.setCategories(DefaultConfig.safeJsonStringList(obj, "categories"));
if (firstSite == null)
firstSite = sb;
Expand All @@ -260,6 +266,7 @@ private void parseJson(String apiUrl, String jsonStr) {
// 需要使用vip解析的flag
vipParseFlags = DefaultConfig.safeJsonStringList(infoJson, "flags");
// 解析地址
parseBeanList.clear();
for (JsonElement opt : infoJson.get("parses").getAsJsonArray()) {
JsonObject obj = (JsonObject) opt;
ParseBean pb = new ParseBean();
Expand Down Expand Up @@ -294,13 +301,20 @@ private void parseJson(String apiUrl, String jsonStr) {
//clan
String extUrl = Uri.parse(url).getQueryParameter("ext");
if (extUrl != null && !extUrl.isEmpty()) {
String extUrlFix = new String(Base64.decode(extUrl, Base64.DEFAULT | Base64.URL_SAFE | Base64.NO_WRAP), "UTF-8");
String extUrlFix;
if(extUrl.startsWith("http") || extUrl.startsWith("clan://")){
extUrlFix = extUrl;
}else {
extUrlFix = new String(Base64.decode(extUrl, Base64.DEFAULT | Base64.URL_SAFE | Base64.NO_WRAP), "UTF-8");
}
// System.out.println("extUrlFix :"+extUrlFix);
if (extUrlFix.startsWith("clan://")) {
extUrlFix = clanContentFix(clanToAddress(apiUrl), extUrlFix);
extUrlFix = Base64.encodeToString(extUrlFix.getBytes("UTF-8"), Base64.DEFAULT | Base64.URL_SAFE | Base64.NO_WRAP);
url = url.replace(extUrl, extUrlFix);
}
extUrlFix = Base64.encodeToString(extUrlFix.getBytes("UTF-8"), Base64.DEFAULT | Base64.URL_SAFE | Base64.NO_WRAP);
url = url.replace(extUrl, extUrlFix);
}
// System.out.println("url :"+url);
LiveChannelGroup liveChannelGroup = new LiveChannelGroup();
liveChannelGroup.setGroupName(url);
liveChannelGroupList.add(liveChannelGroup);
Expand Down Expand Up @@ -394,7 +408,7 @@ public String getSpider() {
}

public Spider getCSP(SourceBean sourceBean) {
return jarLoader.getSpider(sourceBean.getKey(), sourceBean.getApi(), sourceBean.getExt());
return jarLoader.getSpider(sourceBean.getKey(), sourceBean.getApi(), sourceBean.getExt(), sourceBean.getJar());
}

public Object[] proxyLocal(Map param) {
Expand Down Expand Up @@ -497,4 +511,15 @@ String clanContentFix(String lanLink, String content) {
String fix = lanLink.substring(0, lanLink.indexOf("/file/") + 6);
return content.replace("clan://", fix);
}

String fixContentPath(String url, String content) {
if (content.contains("\"./")) {
if(!url.startsWith("http") && !url.startsWith("clan://")){
url = "http://" + url;
}
if(url.startsWith("clan://"))url=clanToAddress(url);
content = content.replace("./", url.substring(0,url.lastIndexOf("/") + 1));
}
return content;
}
}
Loading