@jacktea/pdf-viewer-server 0.1.3 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +66 -0
- package/package.json +1 -1
package/README.md
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
# @jacktea/pdf-viewer-server
|
|
2
|
+
|
|
3
|
+
Jacktea PDF Viewer 的实时协作后端服务,基于 Socket.io 实现。
|
|
4
|
+
|
|
5
|
+
## 简介
|
|
6
|
+
|
|
7
|
+
如果你希望在你的 PDF 预览器中接入多人实时协作功能(如:实时看到别人的高亮、批注、评论拉取与同步),可以使用此 Node.js 服务。
|
|
8
|
+
|
|
9
|
+
服务端主要负责多端状态同步和协同数据的分发,目前作为本地运行或自行部署的独立微服务使用。
|
|
10
|
+
|
|
11
|
+
## 特性
|
|
12
|
+
|
|
13
|
+
- ⚡ **实时光标与轨迹**:可以看到其他协作者的鼠标滚动和选择轨迹。
|
|
14
|
+
- 🔄 **秒级同步更新**:文档中的任何批注添加与修改均会基于房间隔离实时广播。
|
|
15
|
+
- 🔒 **权限拦截机制**:内置房间与用户身份概念的验证能力。
|
|
16
|
+
|
|
17
|
+
## 安装
|
|
18
|
+
|
|
19
|
+
你可以全局安装作为 CLI 服务启动:
|
|
20
|
+
|
|
21
|
+
```bash
|
|
22
|
+
npm install -g @jacktea/pdf-viewer-server
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
或者在你的自有工程中配合脚本启动:
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
npm install @jacktea/pdf-viewer-server
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
## 启动服务
|
|
32
|
+
|
|
33
|
+
### 1. 全局 CLI 方式 (开发调试)
|
|
34
|
+
|
|
35
|
+
全局安装后,在终端任意目录直接执行:
|
|
36
|
+
|
|
37
|
+
```bash
|
|
38
|
+
pdf-viewer-server
|
|
39
|
+
```
|
|
40
|
+
*(默认监听 `3000` 端口)*
|
|
41
|
+
|
|
42
|
+
### 2. 作为 Node 包在你的项目中启动
|
|
43
|
+
|
|
44
|
+
你可以通过 npm scripts 启动:
|
|
45
|
+
|
|
46
|
+
```json
|
|
47
|
+
{
|
|
48
|
+
"scripts": {
|
|
49
|
+
"start:collab": "pdf-viewer-server"
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
### 3. Server 配置环境变量
|
|
55
|
+
|
|
56
|
+
服务支持通过配置环境变量来控制行为,例如:
|
|
57
|
+
|
|
58
|
+
```bash
|
|
59
|
+
PORT=8080 CORS_ORIGINS="https://app.example.com" pdf-viewer-server
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
主要参量:
|
|
63
|
+
- `PORT`: 启动端口 (默认 `3000`)
|
|
64
|
+
- `CORS_ORIGINS`: 允许跨域请求的域名白名单,逗号分隔
|
|
65
|
+
- `ALLOW_ALL_ORIGINS`: `true` (开启无限制 CORS,仅开发环境)
|
|
66
|
+
- `REQUIRE_AUTH`: `true` | `false` (是否必须校验认证 token)
|