zoukankan      html  css  js  c++  java
  • linux 下tomcat部署项目中包含中文名称文件,报404找不到文件错误

    1. 在linux系统中,如果将项目部署在tomcat下,项目中包含中文名称文件。可能会报404找不到文件的错误。
    2. Linux往 windows拷贝文件或者从windows往Linux拷贝文件,有时会出现中文文件名乱码的情况

    原因:

    1. windows的文件名中文编码默认为GBK,而Linux中默认文件名编码为UTF8,由于编码不一致,所以导致了文件名乱码的问题,解决这个问题需要对文件名进行转码。

    解决方法:

    1. 在Linux中专门提供了一种工具convmv进行文件名编码的转换,可以将文件名从GBK转换成UTF-8编码,或者从UTF-8转换到GBK。

      首先看一下你的系统上是否安装了convmv,如果没安装的话用在
      http://www.j3e.de/linux/convmv/convmv-1.14.tar.gz
      下载,然后在windows下面解压缩用winscp上传真个目录,之后进入此目录执行make install命令,之后用convmv命令测试是否安装成功,若显示一些命令提示则表示成功了。
      安装。

      下面看一下convmv的具体用法:
      convmv -f 源编码 -t 新编码 [选项] 文件名
      常用参数:
      -r 递归处理子文件夹
      --notest 真正进行操作,请注意在默认情况下是不对文件进行真实操作的,而只是试验。
      --list 显示所有支持的编码
      --unescap 可以做一下转义,比如把%20变成空格
      比如我们有一个utf8编码的文件名,转换成GBK编码,命令如下:
      convmv -f UTF-8 -t GBK --notest utf8编码的文件名

      这样转换以后"utf8编码的文件名"会被转换成GBK编码(只是文件名编码的转换,文件内容不会发生变化)
    2. tomcat服务器改为utf8编码 
      更改server.xml

      <Connector port=”8080″ protocol=”HTTP/1.1″ connectionTimeout=”20000″  redirectPort=”8443″ URIEncoding=”utf-8″ useBodyEncodingForURI=”true”/>
        
  • 相关阅读:
    用chardet判断字符编码的方法
    NLP--edit distance
    nfc是什么?nfc功能是什么?
    【转载】推荐系统的十大挑战
    python--网络爬虫一
    【转载】双调欧几里得距离的算法原理
    Java并发编程:线程池的使用
    Java集合--HashMap源码剖析
    java中集合类详解
    java collection接口源码
  • 原文地址:https://www.cnblogs.com/zhenmingliu/p/2790816.html
Copyright © 2011-2022 走看看