README.md 3.8 KB
Newer Older
W
wizardforcel 已提交
1
<h1 align="center">BiliDriveEx</h1>
H
Hsury 已提交
2

W
wizardforcel 已提交
3
<h4 align="center">☁️ 废墟之上,重建辉煌! ☁️</h4>
W
slogan  
wizardforcel 已提交
4
<h4 align="center">☁️ 支持任意文件的全速上传与下载 ☁️</h4>
W
wizardforcel 已提交
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21

## 特色

- 轻量:无复杂依赖,资源占用少
- 自由:无文件格式与大小限制,无容量限制
- 安全:上传的文件需要通过生成的 META URL 才能访问,他人无法随意查看
- 稳定:带有分块校验与超时重试机制,在较差的网络环境中依然能确保文件的完整性
- 快速:支持多线程传输与断点续传,同时借助 B 站的 CDN 资源,能最大化地利用网络环境进行上传与下载

## 使用指南

### 安装

通过`pip`(推荐):

```
pip install BiliDriveEx
W
typo  
wizardforcel 已提交
22
```
W
wizardforcel 已提交
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140

从源码安装:

```
git clone https://github.com/apachecn/BiliDriveEx
cd BiliDriveEx
python setup.py install
```

### 登录

```
bdex login [-h] username password

username: Bilibili 用户名
password: Bilibili 密码
```

### 上传

```
bdex upload [-h] [-b BLOCK_SIZE] [-t THREAD] file

file: 待上传的文件路径

-b BLOCK_SIZE: 分块大小(MB), 默认值为4
-t THREAD: 上传线程数, 默认值为4
```

上传完毕后,终端会打印一串 META URL(通常以`bdex://`开头)用于下载或分享,请妥善保管

### 下载

```
bdex download [-h] [-f] [-t THREAD] meta [file]

meta: META URL (通常以 bdex:// 开头)
file: 另存为新的文件名, 不指定则保存为上传时的文件名

-f: 覆盖已有文件
-t THREAD: 下载线程数, 默认值为8
```

下载完毕后会自动进行文件完整性校验,对于大文件该过程可能需要较长时间,若不愿等待可直接退出

### 查看文件元数据

```
bdex info [-h] meta

meta: META URL (通常以 bdex:// 或 bdrive:// 开头)
```

### 查看历史记录

```
bdex history [-h]
```

### 交互模式

不传入任何命令行参数,直接运行程序即可进入交互模式

该模式下,程序会打印命令提示符`BiliDriveEx > `,并等待用户输入命令

## 技术实现

将任意文件分块编码为图片后上传至 B 站,对该操作逆序即可下载并还原文件

## 性能指标

### 测试文件

文件名:[Vmoe]Hatsune Miku「Magical Mirai 2017」[BDrip][1920x1080p][HEVC_YUV420p10_60fps_2FLAC_5.1ch&2.0ch_Chapter][Effect Subtitles].mkv

大小:14.5 GB (14918.37 MB)

分块:10 MB * 1492

META URL:`bdrive://d28784bff1086450a6c331fb322accccd382228e`

### 上传

地理位置:四川成都

运营商:教育网

上行速率:20 Mbps

用时:02:16:39

平均速度:1.82 MB/s

### 下载

### 测试点1

地理位置:福建福州

运营商:中国电信

下行速率:100 Mbps

用时:00:18:15

平均速度:13.62 MB/s

### 测试点2

地理位置:上海

运营商:中国电信

下行速率:1 Gbps

用时:00:02:22

平均速度:104.97 MB/s
W
wizardforcel 已提交
141 142 143 144

## 历史记录

[见这里](history.md)
W
wizardforcel 已提交
145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163

## 免责声明

+   请自行对重要文件做好本地备份。
+   请不要上传含有个人隐私的文件,因为无法删除。
+   请勿使用本项目上传不符合社会主义核心价值观的文件。
+   请合理使用本项目,避免对哔哩哔哩的存储与带宽资源造成无意义的浪费。
+   该项目仅用于学习和技术交流,开发者不承担任何由使用者的行为带来的法律责任。

## 协议

本项目基于 SATA 协议发布。

您有义务为此开源项目点赞,并考虑额外给予作者适当的奖励。

## 致谢

本项目基于 [Hsury](https://github.com/Hsury)[BiliDrive](https://github.com/Hsury/BiliDrive),在此表示感谢。

W
wizardforcel 已提交
164 165
同时感谢 [goocarder](https://v2ex.com/t/618064) 提供的思路。

W
wizardforcel 已提交
166 167 168 169 170 171 172 173 174
## 赞助我们

![](https://home.apachecn.org/img/about/donate.jpg)

## 另见

+   [ApacheCN 学习资源](https://docs.apachecn.org/)
+   [计算机电子书](http://it-ebooks.flygon.net)
+   [布客新知](http://flygon.net/ixinzhi/)