在confluence上傳excel檔案,預覽時發現亂碼問題主要是因為再上傳檔案的時候一般是Windows下的檔案上傳,而預覽的時候,是linux下的環境,由於linux下沒有微軟字型,所以預覽的時候無法識別文件字型,所以才會出現亂碼。還比如某個業務有個功能生成圖片,結果圖片裡的字全變空格了,這也是伺服器上沒相應的字型檔造成的。解決辦法:在伺服器上安裝中文字型。操作方法如下:
1)先安裝想要的字型, 如楷體等, 從本機"c盤->Windows-Fonts"資料夾裡複製simkai字型拷到confluence部署機上(也可以多下載幾個字型放過去)。 2)在linux系統下安裝新字型 linux用fontconfig來安裝字型庫 [root@confluence-server ~]# yum -y install fontconfig #一般是預設自帶的 安裝成功後,在/usr/shared目錄就可以看到fonts和fontconfig目錄了(之前是沒有的) [root@confluence-server ~]# ll -d /usr/share/fonts/ [root@confluence-server ~]# ll -d /usr/share/fontconfig/ drwxr-xr-x. 3 root root 4096 11月 9 2017 /usr/share/fontconfig/ 新增中文字型,如上面的楷體simkai字型檔案到confluence部署機的/usr/share/fonts下的某個目錄下(比如新建一個windowsfonts目錄放進去) [root@confluence-server ~]# cd /usr/share/fonts/ [root@confluence-server fonts]# mkdir windowsfonts [root@confluence-server fonts]# ll windowsfonts/ 總用量 4044 -rwxr-xr-x 1 root root 4135804 8月 17 2004 simkai.ttf 緊接著需要修改windowsfonts目錄的許可權: [root@confluence-server ~]# chmod -R 755 /usr/share/fonts/windowsfonts/ 接下來需要安裝ttmkfdir來搜尋目錄中所有的字型資訊,並彙總生成fonts.scale檔案 [root@confluence-server ~]# yum -y install ttmkfdir #一般會預設自帶 然後執行ttmkfdir命令 [root@confluence-server ~]# cd /usr/share/fonts/windowsfonts/ [root@confluence-server windowsfonts]# mkdir -p /usr/share/X11/fonts/encodings/encodings.dir [root@confluence-server windowsfonts]# ttmkfdir -e /usr/share/X11/fonts/encodings/encodings.dir 發現在/usr/share/fontconfig/windowsfonts/目錄下多了個fonts.scale [root@confluence-server windowsfonts]# cat fonts.scale 2 simkai.ttf -misc-KaiTi_GB2312-medium-r-normal--0-0-0-0-c-0-ascii-0 simkai.ttf -misc-KaiTi_GB2312-medium-r-normal--0-0-0-0-c-0-iso10646-1 最後一步就是修改字型配置檔案了,首先通過編輯器開啟配置檔案,可以看到一個Font list,即字型列表,在這裡需要把我們新增的中文字型位置加進去: [root@confluence-server windowsfonts]# vim /etc/fonts/fonts.conf ....... <!-- Font directory list --> <dir>/usr/share/fonts</dir> <dir>/usr/share/X11/fonts/Type1</dir> <dir>/usr/share/X11/fonts/TTF</dir> <dir>/usr/local/share/fonts</dir> <dir>/usr/share/fonts/windowsfonts</dir> #新增這一行 <dir>~/.fonts</dir> <!-- 然後輸入:wq儲存退出,最後別忘了重新整理記憶體中的字型快取,這樣就不用reboot重啟了: [root@confluence-server windowsfonts]# fc-cache 最後再次通過fc-list看一下字型列表: [root@confluence-server windowsfonts]# fc-list ........ 楷體_GB2312,KaiTi_GB2312:style=Regular ....... 可以看到已經成功安裝上了中文字型,至此安裝過程就全部結束,再次檢視報表可以發現中文樣式和內容均已可以正常顯示了。 3)在confluence部署機的安裝目錄, 如/opt/atlassian/confluence/bin下找到setenv.sh, 找到CATALINA_OPTS, 加入一行 [root@confluence-server ~]# vim /opt/atlassian/confluence/bin/setenv.sh ...... CATALINA_OPTS=”-Dconfluence.document.conversion.fontpath=/usr/share/fonts/windowsfonts/ ${CATALINA_OPTS}” 4)清空confluence的home下viewfile目錄和shared-home/dcl-document目錄裡的所有快取文件檔案, 不清空的話, confluence預覽舊檔案時還是會顯示方框, 只有新檔案才會正常。 [root@confluence-server ~]# cd /var/atlassian/application-data/confluence/shared-home/dcl-document [root@confluence-server dcl-document]# rm -rf ./* 5)重啟confluence就OK了。如果重啟後,發現原來上傳的附件預覽還出現亂碼,那就是快取文件檔案所導致!可以刪除這些檔案,重新上傳進去就可以正常預覽了!! [root@confluence-server ~]# lsof -i:8080 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME java 138112 jira 151u IPv6 230299384 0t0 TCP *:webcache (LISTEN) java 188894 confluence 868u IPv6 286937024 0t0 TCP confluence-server:37886->confluence-server:webcache (CLOSE_WAIT) [root@confluence-server ~]# /etc/init.d/confluence restart 順便說一句,confluence對資料庫的編碼格式要求是utf-8,所以請把資料庫編碼格式設定正確,以免其他地方出現亂碼。
========================================================================
以上是將字型直接安裝到伺服器上,還可以將字型安裝到java服務程式裡,步驟如下:
1)下載宋體字型檔案simsun.ttc(或者直接下載simsun.ttf)
2)將該檔案複製到$JAVA_HOME/jre/lib/fonts目錄下,改名為simsun.ttf
3) 重啟java服務程式