今天在做一个项目时遇到一个问题,大致情况是这样的: 有两个服务器ServerA和ServerB.
ServerA是Web服务器,提供web访问 . ServerB是文件备份服务器提供web访问+文件存储
我想通过ServerA获取到ServerB的目录下的一个文件内容,并将该内容下载到本地.
因为ServerB存储文件的目录有可能是中文.如果通过URLConnection直接访问,会报出FileNotFound的错误
在查阅了相关的资料后,我发现,只要将访问Url中的汉字用URLEncoder以UTF-8编码方式重新编码即可附上代码
//要获取的文件路径 例如http://192.168.1.252:8080/filestore/backup/技术部门/张三/2012年报表.doc
//因为我的目录是从前台获取的 我就不写了
String urlStr = "";
//将中文分割出来 以UTF8编码
String strs[] = str.split("/");
System.out.println(strs.length);
int i = 0;
for(String s : strs){
if(i == (strs.length-1)){
if(isChinese(s)){
urlStr += URLEncoder.encode(s, "UTF-8")+"";
}else{
urlStr +=s+"";
}
}else{
if(isChinese(s)){
urlStr += URLEncoder.encode(s, "UTF-8")+"/";
}else{
urlStr +=s+"/";
}
}
i++;
}
URL url = new URL(urlStr);
URLConnection conn = url.openConnection();
//这里得到的就是该文件的字节流
conn.getInputStream()
//符个方法判断是否是中文字符
public static boolean isChinese(String strName) {
char[] ch = strName.toCharArray();
for (int i = 0; i < ch.length; i++) {
char c = ch[i];
if (isChinese(c) == true) {
return isChinese(c);
} else {
if(i == (ch.length-1)){
return isChinese(c);
}else{
continue;
}
}
}
return false;
}
private static boolean isChinese(char c) {
Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS
|| ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS
|| ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A
|| ub == Character.UnicodeBlock.GENERAL_PUNCTUATION
|| ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION
|| ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS) {
return true;
}
return false;
}