zoukankan      html  css  js  c++  java
  • Linux环境下BufferedImage Graphics drawString 中文乱码解决方法

    http://blog.csdn.net/qiaoshuai0920/article/details/41113345


    在linux环境下的,生成的带文字的图片在前台一直显示为方框乱码,windows环境正常。

    img.setFont(new Font("宋体", Font.BOLD, 20));

    写中文进入图片之前必须设置字体,而且这个字体必须支持中文,否则就会出现乱码或者方框、问号等等。

    BufferedImage在内存创建的图像调用的是服务器端的字体,所以在img.drawString(str, x, y);时,如果服务器端找不到对应的中文字体,那么它就识别不了,最后写入图片的中文就变成了乱码、方框、问号等等了。

    在这里可以有两种方法添加服务器端的中文支持:

    第一种方法,添加系统中文字体(宋体):
    root@dragon-virtual-machine:~# cd /usr/share/fonts
    root@dragon-virtual-machine:/usr/share/fonts# mkdir winFonts
    root@dragon-virtual-machine:/usr/share/fonts# cp /home/dragon/Desktop/simsun.ttc winFonts
    root@dragon-virtual-machine:/usr/share/fonts# cd winFonts
    root@dragon-virtual-machine:/usr/share/fonts/winFonts# mkfontdir
    root@dragon-virtual-machine:/usr/share/fonts/winFonts# mkfontscale
    第二种方法,添加jre中文字体(宋体):
    root@dragon-virtual-machine:~# cd /usr/lib/jvm/java-6-sun/jre/lib/fonts
    root@dragon-virtual-machine:/usr/lib/jvm/java-6-sun/jre/lib/fonts# cp /home/dragon/Desktop/simsun.ttc .

    修改完必须重启服务器才有效。




    2017.10.30

    http://waddy.iteye.com/blog/2051496


    注意:阿里云CentOS的yum是默认的,其软件仓库也是基本的,在使用yum安装常见软件时可能都会提示找不到软件包,因此需要更新yum源(参考centos6.2更新yum源

    1、先从你本机 C:WindowsFonts 拷贝或者网络上下载你想要安装的字体文件(*.ttf文件)到/usr/share/fonts/chinese/TrueType 目录下(如果系统中没有此目录,则自行mkdir创建,亦可重命名为自己喜欢的文件夹名)

    2、修改字体文件的权限,使root用户以外的用户也可以使用

    # cd /usr/share/fonts/chinese/TrueType
    # chmod 755 *.ttf

    3、建立字体缓存

    # mkfontscale (如果提示 mkfontscale: command not found,需自行安装 # yum install mkfontscale )
    # mkfontdir 
    # fc-cache -fv (如果提示 fc-cache: command not found,则需要安装# yum install fontconfig )

    4、重启计算机(似乎必须重启才会有效)
    # reboot





    试下来,还真是要重启计算机

  • 相关阅读:
    关于对话框创建与销毁的虚函数用法
    控件属性设置注意事项
    删除非空文件夹下所有内容方法
    CString类使用技巧
    视图间通信方法
    CTreeCtrl控件使用技巧
    MFC MDI 遍历打开的所有文档
    将datagrid的数据源到出导excel
    ASP.NET 給一組控件賦值 範例.
    ASP.NET Resouce Kit
  • 原文地址:https://www.cnblogs.com/silyvin/p/9106817.html
Copyright © 2011-2022 走看看