解决URL中有中文的问题,可以放心使用url.opnestream方法
来源:互联网 发布:网络购彩新闻 编辑:程序博客网 时间:2024/05/08 20:17
最近在做一个用POI提取excel文件内容的例子。
如果所提取的文件放在网络上。就需要用URL来打开该文件获得InputStream;
URL url = new URL("http://192.168.1.1:8080/resources/电话.xls");
InputStream in = url.openStream();
这样会报错
如果
URL url = new URL("http://192.168.1.1:8080/resources/1.xls");
InputStream in = url.openStream();
就不会有问题。
我用的服务器是Tomcat。
程序测试时的源码
URL url = new URL("http://192.168.1.110:8080/resources/电话.xls");
InputStream in = url.openStream();
POIFSFileSystem pfs = new POIFSFileSystem(in);
HSSFWorkbook wb = new HSSFWorkbook(pfs);
ExcelExtractor extractor = new ExcelExtractor(wb);
extractor.setFormulasNotResults(true);
extractor.setIncludeSheetNames(false);
String text = extractor.getText();
System.out.println(text);
如果所提取的文件放在网络上。就需要用URL来打开该文件获得InputStream;
URL url = new URL("http://192.168.1.1:8080/resources/电话.xls");
InputStream in = url.openStream();
这样会报错
如果
URL url = new URL("http://192.168.1.1:8080/resources/1.xls");
InputStream in = url.openStream();
就不会有问题。
我用的服务器是Tomcat。
程序测试时的源码
URL url = new URL("http://192.168.1.110:8080/resources/电话.xls");
InputStream in = url.openStream();
POIFSFileSystem pfs = new POIFSFileSystem(in);
HSSFWorkbook wb = new HSSFWorkbook(pfs);
ExcelExtractor extractor = new ExcelExtractor(wb);
extractor.setFormulasNotResults(true);
extractor.setIncludeSheetNames(false);
String text = extractor.getText();
System.out.println(text);
经过在论坛上发帖子,各路高手的帮忙,终于解决了这个问题,等知道答案后觉得这个挺简单的
只要写一个类 把URL中的中文转码就行了
package gameover;import java.io.UnsupportedEncodingException;import java.net.URLEncoder;import java.util.regex.Matcher;import java.util.regex.Pattern;/** * 正则替换字符串里面的汉字部分。 * * @author gameover */public class URLEncoderHZ { public static void main(String[] args) throws Exception { String str = "http://192.168.1.1:8080/resources/电话.xls"; System.out.println(encode(str, "UTF-8")); } private static String zhPattern = "[/u4e00-/u9fa5]+"; /** * 替换字符串卷 * * @param str 被替换的字符串 * @param charset 字符集 * @return 替换好的 * @throws UnsupportedEncodingException 不支持的字符集 */ public static String encode(String str, String charset) throws UnsupportedEncodingException { Pattern p = Pattern.compile(zhPattern); Matcher m = p.matcher(str); StringBuffer b = new StringBuffer(); while (m.find()) { m.appendReplacement(b, URLEncoder.encode(m.group(0), charset)); } m.appendTail(b); return b.toString(); }}比如例子中的urlhttp://192.168.1.1:8080/resources/电话.xls经过这个类中的方法转成utf-8编码后就变成了http://192.168.1.1:8080/resources/%E7%94%B5%E8%AF%9D.xls当然也可以根据需要转成其他编码格式。这样就可以放心的使用url.openstream这个方法的得到InputStream对象了不会再报错文件找不到。
- 解决URL中有中文的问题,可以放心使用url.opnestream方法
- 解决URL中有中文的问题,可以放心使用url.opnestream方法
- 在url中有中文乱码问题的解决
- java中调用Js的方法 & java.net.Url的使用 & Url中文乱码的解决 & Map 排序
- 解决tomcat下的URL中文乱码问题的方法
- jquery获取URL中参数解决中文乱码问题的两种方法
- 关于解决URL中中文乱码问题
- android url中中文参数乱码问题的解决
- URL中文字符的问题--使用encodeURI解决
- JSP使用URL编码传递中文参数问题的解决
- URL参数有中文的问题
- URL中文乱码问题的解决
- 解决URL请求的中文乱码问题
- 解决URL中文参数乱码的问题
- 解决URL中文参数乱码的问题
- CI框架中使用URI类segment方法获取url中的中文参数的问题
- 解决URL中文乱码问题
- nodejs解决中文加密问题和url中中文参数的问题
- C#编码习惯
- Google搜索技巧终极收集 - 101个Google技巧
- 诚信和聪明
- 系统开发流程
- 『经济论坛』 [经济杂谈]水煮经济学
- 解决URL中有中文的问题,可以放心使用url.opnestream方法
- WindowsXP 下搭建PHP环境(笔记)
- datediff的使用
- C#编程规范
- 面向对象设计过程步骤
- ASP.NET开发规范
- 将表数据生成SQL脚本的存储过程
- SQL SERVER作业调度
- 一些很实用的JS代码