轩辕镜像 官方专业版
轩辕镜像
专业版
轩辕镜像 官方专业版
轩辕镜像
专业版
首页个人中心搜索镜像
交易
充值流量¥7起我的订单
文档
工具
提交工单页面收录
cups-web

hanxi/cups-web

hanxi

CUPS Web是一个功能完善的网页版打印机管理工具,支持远程打印、多用户管理和打印记录追踪,轻松实现家庭或小型办公室的打印管理需求。

1 次收藏下载次数: 0状态:社区镜像维护者:hanxi仓库类型:镜像最近更新:14 天前
让 AI 帮你使用轩辕镜像? · 展开查看说明 · 点击收起说明

如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。

只需在 AI 对话中先发送下面这句话即可:

请先完整阅读并严格遵守以下文档中的全部规则与要求:

https://xuanyuan.cloud/agents.md

在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。

查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。

DockerHub 官方简介
轩辕镜像中文简介
下载命令
镜像标签列表与下载命令
轩辕镜像,加速的不只是镜像。
点击查看

🖨️ CUPS Web - 网页打印机

https://img.shields.io/docker/pulls/hanxi/cups-web?style=flat-square&logo=docker](https://hub.docker.com/r/hanxi/cups-web) https://img.shields.io/github/stars/hanxi/cups-web?style=flat-square&logo=github](https://github.com/hanxi/cups-web) https://img.shields.io/github/license/hanxi/cups-web?style=flat-square](LICENSE)

这是一个功能完善的网页版打印机管理工具。它允许你通过浏览器远程控制打印机,支持多用户管理、打印记录追踪等功能,轻松实现家庭或小型办公室的打印管理需求。

📸 界面预览


文件上传

打印机

预览

管理后台

✨ 功能特点

核心功能

  • 远程打印:随时随地通过网页上传文件进行打印
  • 多格式支持:
    • PDF 文档
    • 图片文件(JPG、PNG、GIF)
    • Office 文档(docx、xlsx、pptx 等)自动转换为 PDF(基于 LibreOffice)
    • 文本文件(txt)自动转换为 PDF

用户管理

  • 多用户系统:支持管理员和普通用户两种角色
  • 打印记录:完整的打印历史记录

管理后台

  • 用户管理:创建、编辑、删除用户账号
  • 打印记录查询:按用户、时间范围查询打印记录
  • 系统设置:配置数据保留天数等

安全特性

  • Session 认证:安全的会话管理机制
  • CSRF 保护:防止跨站请求伪造***
  • 密码加密:使用 bcrypt 加密存储用户密码

部署优势

  • 多种部署方式:支持 Docker 一键部署或二进制文件直接运行
  • 数据持久化:数据库和上传文件独立存储
  • 易于维护:简洁的配置和管理界面
  • 跨平台支持:提供 Linux、macOS、Windows 多平台二进制文件

🛠️ 技术栈

  • 打印服务: https://github.com/OpenPrinting/cups
  • 后端: Go
  • 前端: Vue.js 3 + Vite + Tailwind CSS + Nuxt UI

🚀 快速开始

你可以选择以下两种方式部署:

  • Docker 部署(推荐,简单易用)
  • 二进制部署(适用于已有 CUPS 服务的场景)

Docker 部署

前置要求

  • Docker
  • Docker Compose
  • USB 打印机(如果使用本地打印机)

1. 创建项目目录

bash
mkdir cups-web
cd cups-web

2. 创建 docker-compose.yml

创建 docker-compose.yml 文件,内容如下:

yaml
services:
  cups:
    image: docker.xuanyuan.run/hanxi/cups:latest
    user: root
    environment:
      - CUPSADMIN=${CUPSADMIN}
      - CUPSPASSWORD=${CUPSPASSWORD}
    ports:
      - "631:631"
    devices:
      - /dev/bus/usb:/dev/bus/usb
    volumes:
      - ./.etc:/etc/cups
    restart: unless-stopped

  web:
    image: docker.xuanyuan.run/hanxi/cups-web:latest
    user: root
    environment:
      - CUPS_HOST=cups:631
    volumes:
      - ./.data:/data
      - ./.uploads:/uploads
    ports:
      - "1180:8080"
    depends_on:
      - cups
    restart: unless-stopped

或者直接下载:

bash
wget https://raw.githubusercontent.com/hanxi/cups-web/main/docker-compose.yml

3. 配置环境变量

创建 .env 文件并配置以下环境变量:

bash
# CUPS 管理员账号(用于管理打印机)
CUPSADMIN=admin
CUPSPASSWORD=your_cups_password

4. 启动服务

bash
docker-compose up -d

5. 配置打印机

访问 CUPS 管理界面配置打印机:

http://localhost:631

使用 .env 中配置的 CUPSADMIN 和 CUPSPASSWORD 登录,然后添加你的打印机。

提示:建议根据打印机型号安装合适的驱动程序。

6. 访问 Web 界面

打开浏览器访问:

http://localhost:1180

默认管理员账号:

  • 用户名:admin
  • 密码:admin

⚠️ 重要:首次登录后请立即修改默认密码!

7. 开始使用

  1. 使用管理员账号登录
  2. 在管理后台创建普通用户账号
  3. 用户即可登录并开始打印

二进制部署

如果你已经有 CUPS 服务运行,可以直接下载二进制文件运行 Web 服务。

前置要求

  • 已安装并运行 CUPS 服务
  • 可选:USB 打印机(如果使用本地打印机)

1. 下载二进制文件

从 https://github.com/hanxi/cups-web/releases 下载适合你平台的二进制文件:

平台架构文件名
Linuxamd64cups-web-linux-amd64
Linuxarm64cups-web-linux-arm64
macOSamd64cups-web-darwin-amd64
macOSarm64cups-web-darwin-arm64
Windowsamd64cups-web-windows-amd64.exe
bash
# 示例:下载 Linux amd64 版本
wget https://github.com/hanxi/cups-web/releases/download/master/cups-web-linux-amd64
chmod +x cups-web-linux-amd64

2. 配置环境变量

二进制文件不会自动加载 .env 文件,你需要手动设置环境变量:

bash
# CUPS 服务地址(必填)
export CUPS_HOST=localhost:631

# 数据目录(可选,默认当前目录)
export DB_PATH=./data/cups-web.db
export UPLOAD_DIR=./uploads

# 监听地址(可选,默认 :8080)
export LISTEN_ADDR=:8080

或者使用 env 命令临时设置:

bash
CUPS_HOST=localhost:631 DB_PATH=./data/cups-web.db ./cups-web-linux-amd64

3. 运行服务

bash
./cups-web-linux-amd64

4. 访问 Web 界面

打开浏览器访问:

http://localhost:8080

默认管理员账号:

  • 用户名:admin
  • 密码:admin

⚠️ 重要:首次登录后请立即修改默认密码!


📖 详细使用指南

用户角色说明

管理员(Admin)

  • 管理所有用户账号
  • 查看所有打印记录
  • 配置系统设置(数据保留等)
  • 访问管理后台

普通用户(User)

  • 上传并打印文件
  • 查看个人打印历史

打印功能

支持的文件格式

格式类型支持的扩展名说明
PDF.pdf直接打印
图片.jpg, .jpeg, .png, .gif自动转换为 PDF
Office.docx, .xlsx, .pptx, .doc, .xls, .ppt通过 LibreOffice 转换为 PDF
文本.txt自动转换为 PDF

打印流程

  1. 选择打印机:从列表中选择可用的打印机
  2. 上传文件:点击选择文件按钮上传要打印的文件
  3. 预览和转换:
    • PDF 和图片可直接预览
    • Office 文档可点击"转换"按钮预览转换后的 PDF
  4. 查看页数估算:系统自动显示预估页数
  5. 确认打印:点击"打印"按钮提交打印任务

打印记录

用户可以查看自己的打印历史,包括:

  • 打印时间
  • 文件名
  • 页数
  • 打印状态

管理后台使用

用户管理

创建用户:

  1. 进入管理后台
  2. 点击"创建用户"
  3. 填写用户信息:
    • 用户名(必填)
    • 密码(必填)
    • 角色(管理员/普通用户)
    • 联系信息(可选)

编辑用户:

  • 可修改用户的所有信息(除用户名外)

删除用户:

  • 可删除普通用户
  • 默认管理员账号(admin)受保护,无法删除

打印记录查询

管理员可以:

  • 查看所有用户的打印记录
  • 按用户名筛选
  • 按时间范围筛选
  • 导出打印记录(查看详细信息)

系统设置

数据保留天数:

  • 设置打印记录和上传文件的保留时间
  • 超过保留期的数据会被自动清理

⚙️ 配置说明

环境变量详解

Web 服务配置

变量名说明默认值必填
LISTEN_ADDRWeb 服务监听地址:8080否
DB_PATHSQLite 数据库文件路径/data/cups-web.db否
UPLOAD_DIR上传文件存储目录/uploads否
CUPS_HOSTCUPS 服务地址localhost否

CUPS 服务配置

变量名说明默认值必填
CUPSADMINCUPS 管理员用户名-是
CUPSPASSWORDCUPS 管理员密码-是

Docker Compose 配置

默认的 docker-compose.yml 配置:

  • CUPS 服务端口:631(用于管理打印机)
  • Web 服务端口:1180(用于访问 Web 界面)
  • 数据持久化:
    • ./.data:数据库文件
    • ./.uploads:上传的文件
    • ./.etc:CUPS 配置文件

修改端口

如需修改端口,编辑 docker-compose.yml:

yaml
services:
  web:
    ports:
      - "你的端口:8080"  # 修改左侧端口号

🔧 高级配置

使用 HTTPS

配置反向代理(如 Nginx)处理 HTTPS:

nginx
server {
    listen 443 ssl;
    server_name your-domain.com;

    ssl_certificate /path/to/cert.pem;
    ssl_certificate_key /path/to/key.pem;

    location / {
        proxy_pass http://localhost:1180;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }
}

数据备份

定期备份以下目录:

bash
# 备份数据库
cp ./.data/cups-web.db /backup/location/

# 备份上传文件
tar -czf uploads-backup.tar.gz ./.uploads/

# 备份 CUPS 配置
tar -czf cups-config-backup.tar.gz ./.etc/

性能优化

对于大量用户场景,建议:

  1. 增加 Docker 容器资源限制
  2. 定期清理过期的打印记录和文件
  3. 使用 SSD 存储数据库文件

⚠️ 注意事项

安全建议

  1. 修改默认密码:首次部署后立即修改 admin 账号密码
  2. 定期备份:定期备份数据库和上传文件
  3. 限制访问:使用防火墙限制只有授权 IP 可以访问

打印机驱动

  • CUPS 容器中可能没有预装所有打印机驱动
  • 建议根据打印机型号手动安装对应驱动
  • 可以通过 docker exec 进入 CUPS 容器安装驱动

LibreOffice 转换

  • Web 镜像已预装 LibreOffice 和常用字体
  • 支持中文字体(Noto CJK、文泉驿等)
  • 转换超时时间为 60 秒
  • 复杂文档可能需要较长转换时间

数据清理

  • 系统会根据"数据保留天数"设置自动清理过期数据
  • 清理包括:打印记录和对应的上传文件
  • 建议根据存储空间合理设置保留天数

❓ 常见问题

如何重置管理员密码?

如果忘记管理员密码,可以通过以下方式重置:

bash
# 停止服务
docker-compose down

# 删除数据库(会清空所有数据)
rm ./.data/cups-web.db

# 重新启动服务(会创建新的 admin/admin 账号)
docker-compose up -d

打印机无法识别怎么办?

  1. 确认打印机已正确连接到服务器
  2. 访问 CUPS 管理界面(http://localhost:631%EF%BC%89%E6%A3%80%E6%9F%A5%E6%89%93%E5%8D%B0%E6%9C%BA%E7%8A%B6%E6%80%81
  3. 尝试重启 CUPS 服务:docker-compose restart cups
  4. 检查打印机驱动是否正确安装

Office 文档转换失败?

可能的原因:

  1. 文档格式损坏或不支持
  2. 文档过大或过于复杂
  3. LibreOffice 转换超时

解决方法:

  1. 尝试在本地用 Office 或 LibreOffice 打开并另存为
  2. 将文档手动转换为 PDF 后再上传
  3. 简化文档内容

如何查看服务日志?

bash
# 查看 Web 服务日志
docker-compose logs -f web

# 查看 CUPS 服务日志
docker-compose logs -f cups

如何更换打印机?

  1. 访问 CUPS 管理界面(http://localhost:631%EF%BC%89
  2. 删除旧打印机
  3. 添加新打印机
  4. 在 Web 界面刷新打印机列表

📝 更新日志

查看 https://github.com/hanxi/cups-web/releases 了解版本更新历史。

🤝 贡献

欢迎提交 Issue 和 Pull Request!

📄 许可证

本项目采用 MIT 许可证。详见 LICENSE 文件。

镜像拉取方式

您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。

轩辕镜像加速拉取命令点我查看更多 cups-web 镜像标签

docker pull docker.xuanyuan.run/hanxi/cups-web:<标签>

使用方法:

  • 登录认证方式
  • 免认证方式

DockerHub 原生拉取命令

docker pull hanxi/cups-web:<标签>

轩辕镜像配置手册

按平台快速找到配置文档

一键安装

一键安装 Docker

Linux Docker 一键安装

AI

用 AI 使用轩辕镜像

agents.md · AI 对话 · 提示词

Docker

登录仓库拉取

登录认证 · 私有仓库

专属域名拉取

免登录 · 高速拉取

Linux

Docker 镜像配置

Windows / Mac

Docker Desktop 配置

MacOS OrbStack

OrbStack 容器

Apple Container

macOS 原生容器

Docker Compose

Compose 项目配置

NAS

群晖

Synology 配置

飞牛

fnOS 镜像配置

绿联

绿联 NAS

威联通

QNAP 配置

极空间

极空间 NAS

Unraid

Unraid NAS

企业仓库

其他仓库

ghcr · Quay · nvcr

Harbor 镜像源

Proxy Repository 对接

Portainer 镜像源

Registries 配置

Nexus 镜像源

Docker Proxy 缓存

开发工具

Dev Containers

VS Code 开发容器

Podman

Podman 配置指南

Singularity / Apptainer

HPC 科学计算容器

Kubernetes

K8s Containerd

Kubernetes · Containerd

K3s

轻量级集群

面板 / 网络

爱快路由

iKuai 镜像加速

宝塔面板

一键配置镜像源

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

功能

版本功能对比

功能对比 · 版本选择

支持的镜像仓库

Docker Hub · GCR · GHCR

新手拉取配置

登录 · 专属域名 · 配置

docker search 限制

专属域名 · Hub 搜索

不支持 push

仅支持 pull · 不支持

拉取速度原因

带宽 · 缓存 · 冷热镜像

错误码

402 与流量用尽

402 · 流量包 · 充值

401 认证失败

401 · docker login

manifest unknown

标签错误 · 镜像不存在

410 Gone 排查

410 · Docker 升级

429 限流

免费版 · 专业版 · 企业版 · 请求频率

其他报错

DNS 超时

DNS 解析 · 网络超时

TLS 证书失败

no matching manifest(架构)

账号

失败是否计费

manifest · blob · 计费

申请开发票(企业 / 个人)

企业 · 个人 · 工单

修改登录密码

网站 · 仓库 · 重置

注销账户

工单 · 数据 · 注销

原理

mirrors 不生效

daemon.json · 重启

去掉域名前缀

docker tag · 重命名

指定架构拉取

ARM64 · AMD64 · 多架构

latest 与「最新」

digest · 版本号 · 标签

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
hanxi/cups-web
教程轩辕镜像功能与使用教程
定价查看流量套餐与价格
热门查看热门 Docker 镜像推荐
博客Docker 镜像公告与技术博客
专业版 · 高速稳定拉取镜像
高速镜像下载·在线技术支持·99.95% SLA 保障·付费会员免广告
50GB 仅 ¥7/年
专业版 · 高速稳定拉取镜像
50GB 仅 ¥7/年
高速镜像下载·在线技术支持·99.95% SLA 保障·付费会员免广告
用户协议·隐私政策·增值电信业务经营许可证:浙B2-20261007·©2024-2026 源码跳动©2024-2026 杭州源码跳动科技有限公司·商务合作:点击复制邮箱

更多 cups-web 镜像推荐

robocupssl/ssl-game-controller logo

robocupssl/ssl-game-controller

robocupssl
ssl-game-controller是RoboCup SSL比赛的裁判控制器,替代ssl-refbox,用于管理比赛流程、接收视觉数据和机器人跟踪信息,提供Web界面、多客户端支持及灵活的集成模式,适用于比赛控制与模拟测试。
1万+ 次下载
29 天前更新
robocupssl/ssl-status-board logo

robocupssl/ssl-status-board

robocupssl
RoboCup Small Size League(SSL)的状态板工具,优化用于在大屏幕上实时显示当前比赛状态,支持Docker部署,无需额外依赖,可通过配置文件自定义。
1万+ 次下载
1 个月前更新
robocupssl/ssl-vision-client logo

robocupssl/ssl-vision-client

robocupssl
ssl-vision-client是ssl-vision的图形化客户端,用于接收多播数据包并通过Web界面展示,支持便捷的可视化监控与数据查看。
1万+ 次下载
28 天前更新
robocupssl/ssl-quality-inspector logo

robocupssl/ssl-quality-inspector

robocupssl
暂无描述
1万+ 次下载
2 个月前更新
robocupssl/ssl-auto-recorder logo

robocupssl/ssl-auto-recorder

robocupssl
RoboCup SSL联赛的工具集合,提供消息读写、发送、接收、解析及日志记录、转换、统计等功能,适用于机器人足球比赛数据处理与分析。
1万+ 次下载
29 天前更新
robocupssl/ssl-ref-client logo

robocupssl/ssl-ref-client

robocupssl
暂无描述
6.6千+ 次下载
29 天前更新

查看更多 cups-web 相关镜像