让开源浏览器Chromium正常显示中文

在这里插入图片描述

什么是 Chromium ?

Chromium 是一个开源浏览器项目,旨在为所有用户构建一种更安全、更快、更稳定的网络体验方式。

和老苏之前介绍的 Firefox 的作用是一样的

文章传送门:给群晖安装firefox浏览器

因为是基于 vnc 的应用,感觉资源占用比较高,虽然不是常态,但时不时的会飙升一下,所以不是太建议安装。或者等需要使用的时候再启动容器,用完后就停止,不需要一直开在那里

安装

在群晖上以 Docker 方式安装。

本文写作时, latest 版本对应为 4fed82c2-ls48

docker cli 安装

如果你熟悉命令行,可能用 docker cli 更快捷

# 新建文件夹 chromium 和 子目录
mkdir -p /volume1/docker/chromium/config# 进入 chromium 目录
cd /volume1/docker/chromium# 运行容器
docker run -d \--restart unless-stopped \--name chromium \--shm-size="1gb" \--security-opt seccomp=unconfined \-p 3020:3000 \-p 3021:3001 \-v $(pwd)/config:/config \-e PUID=1000 \-e PGID=1000 \-e TZ=Asia/Shanghai \-e CHROME_CLI=https://laosu.cf/ \linuxserver/chromium:latest

其中主要的参数的说明:

范围功能
-p 3000Chromium 桌面图形用户界面 http 访问端口。
-p 3001https 访问端口
-e PUID=1000UserID
-e PGID=1000GroupID
-e TZ=Asia/Shanghai指定要使用的时区。
-e CHROME_CLI=https://laosu.cf/指定一个或多个 Chromium CLI 标志,该字符串将完整传递给应用程序。
-v /config容器中的用户主目录,存储本地文件和设置。
--shm-size=用于指定共享内存的大小。在某些场景下提高容器的性能和可靠性,特别是当容器内的应用程序需要大量使用共享内存时。
--security-opt seccomp=unconfined仅对于 Docker 引擎,如果没有它,Chromium 将在无沙箱测试模式下运行。

docker-compose 安装

也可以用 docker-compose 安装,将下面的内容保存为 docker-compose.yml 文件

version: "2.1"services:chromium:image: linuxserver/chromium:latestcontainer_name: chromiumrestart: unless-stoppedports:- 3020:3000- 3021:3001volumes:- ./config:/configenvironment:- PUID=1000- PGID=1000- TZ=Asia/Shanghai- CHROME_CLI=https://laosu.cf/security_opt:- seccomp:unconfinedshm_size: "1gb"

然后执行下面的命令

# 新建文件夹 chromium 和 子目录
mkdir -p /volume1/docker/chromium/config# 进入 chromium 目录
cd /volume1/docker/chromium# 将 docker-compose.yml 放入当前目录# 一键启动
docker-compose up -d

运行

第一次初始化的时间会比较长,在浏览器中输入 http://群晖IP:3020,你可能会看到闪了一下 KasmVNC,然后就是黑乎乎的

启动正常后,就能看到主界面

这是基于 KasmVNC 的应用,左侧有隐藏的菜单

从界面看,显然容器内缺中文字体,所以汉字都显示成了方块

中文支持

先进入容器

# 以 root 身份进入容器
docker exec -it --user root chromium /bin/bash

然后在容器内,执行下面的命令来安装字体文件

  • fonts-wqy-zenhei:这是一款开源的中文字体,也称为文泉驿正黑字体。
  • fonts-arphic-ukai:这是一款由文鼎资讯公司提供的中文字体。
  • fonts-arphic-uming:同样由文鼎资讯公司提供的中文字体。
# 安装中文字体
apt-get update && \apt-get install -y \fonts-wqy-zenhei fonts-arphic-ukai fonts-arphic-uming \&& apt-get clean

接下来的操作,需要在 Chromium 浏览器中进行

在地址栏输入 chrome://flags,搜索 language,找到 Reduce Accept-Language request header

设置为 Enabled,然后 Relaunch 重启浏览器

现在汉字的显示就正常了

参考文档

linuxserver/docker-chromium: Web accessible Chromium inside an Alpine Container
地址:https://github.com/linuxserver/docker-chromium

chromium - LinuxServer.io
地址:https://docs.linuxserver.io/images/docker-chromium/

Add CJK (Chinese, Japanese, Korean) language support to the docker image · Issue #932 · garris/BackstopJS
地址:https://github.com/garris/BackstopJS/issues/932

Browser cannot displays my language · Issue #318 · SeleniumHQ/docker-selenium
地址:https://github.com/SeleniumHQ/docker-selenium/issues/318

Docker安装Chromium浏览器显示中文 - 800power记事本 - 备忘录
地址:https://www.800power.com/archives/22/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/525438.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL从入门到实战

MySQL从入门到实战 1.连接数据库 在操作数据库之前,需要连接它,输入命令:mysql -u用户名 -p密码。 2.创建数据库 创建完数据库之后我们可以通过show databases;命令查看MySQL中已存在的数据库。[请注意:数据库名区分大小写。] 3…

C++内存管理篇

文章目录 1. C/C内存分布2. C中的内存管理方式3. operator new和operator delete函数4. new和delete的实现原理5. 定位new表达式(placement-new) 1. C/C内存分布 C语言中,为了方便管理内存空间,将内存分成了不同的区域,每个区域管理不同的数据…

计算布尔二叉树的值

题目 题目链接 . - 力扣(LeetCode) 题目描述 代码实现 class Solution { public:bool evaluateTree(TreeNode* root) {if(root->left nullptr && root->right nullptr) return root->val;bool left evaluateTree(root->left)…

YOLOv8.1.0安装

【YOLO】YOLOv8训练环境配置 python 3.8.18 cuda 11.3.1 cudnn 8.2.1 pytorch 1.12.1-gpu版 - 知乎 (zhihu.com) 一、Anaconda 默认装好了可用的Anaconda,安装教程见Win10系统anaconda安装 - 知乎 (zhihu.com) 二、在虚拟环境下用conda安装 1.创建虚拟环境 …

STM32H750片外QSPI启动配置简要

STM32H750片外QSPI启动配置简要 📍参考信息源:《STM32H750片外Flash启动(W25Q64JVSIQ)》🔖本例程基于Keil MDk开发平台。🍁配置框架: ✨为什么使用要使用QSPI启动方式 不管对于STM32H7系列单片机,还是其他…

【Java】快速排序

文章目录 一、什么是快速排序二、基准元素的选择1、选择第一个元素2、随机选择 三、元素的交换1、双边循环法2、单边循环法 一、什么是快速排序 快速排序是由冒泡排序演变而来,比冒泡排序更快的排序算法。之所以快,是因为快速排序用了分治法。 相同的是…

探索手指套的多功能用途

什么是手指套? 手指套,戴在手指上的用品。作为一种小巧实用的用品,在我们的生活中扮演着多种角色。无论是在工业生产中的保护,医疗操作中的防护,还是日常生活中的装饰,甚至是性生活中的辅助,手…

数据结构从入门到精通——队列

队列 前言一、队列1.1队列的概念及结构1.2队列的实现1.3队列的实现1.4扩展 二、队列面试题三、队列的具体实现代码Queue.hQueue.ctest.c队列的初始化队列的销毁入队列出队列返回队头元素返回队尾元素检测队列是否为空检测元素个数 前言 队列是一种特殊的线性数据结构&#xff…

Rust教程:How to Rust-从开始之前到Hello World

本文为第0篇 专栏简介 本专栏是优质Rust技术专栏,推荐精通一门技术栈的蟹友,不建议基础的同学(无基础学Rust也是牛人[手动捂脸]) 感谢Rust圣经开源社区的同学,为后来者提供了非常优秀的Rust学习资源 本文使用&…

银河麒麟V10 安装部署大数据管理软件 DataSophon

一、概览 1、愿景 致力于快速实现部署、管理、监控以及自动化运维大数据云原生平台,帮助您快速构建起稳定、高效、可弹性伸缩的大数据云原生平台。 2、DataSophon是什么 《三体》,这部获世界科幻文学最高奖项雨果奖的作品以惊艳的"硬科幻"…

ARM/Linux嵌入式面经(二):芯片原厂

uart如何进行通信,模块发给uart数据信息后经历了什么 UART(Universal Asynchronous Receiver/Transmitter,通用异步收发传输器)是一种用于串行通信的协议,它使用一对传输线(TX和RX)进行双向通信…

结构体内存对齐详解

目录 结构体对齐: 为什么要进行内存对齐? 关于结构体的详解文章:C语言结构体详解_结构体变量和结构体类型举例-CSDN博客 结构体对齐: 存储的时候和当前存储的成员类型字节大小和默认对齐数比较,取小值 存在该对齐数的…