jsp导入excel到DB的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jsp导入excel到DB的问题相关的知识,希望对你有一定的参考价值。

我最近写了一个jsp导入excel数据到DB的网页,我只有一台机器,也就是说服务器和浏览器实际上是在一台机器上的。
现在的代码是jsp文件把excel的路径传到后台,然后在后台用jxl包处理excel数据,本来已经测试通过了,但今天想到一个问题,就是在后台得到的excel路径是浏览器中用户输入的路径,整个过程excel并没有上传到服务器上,也就是说后台实际上是从客户端浏览器的机器上读得的数据,而不是在服务器端读的数据,这样会造成问题吗?
本人没什么经验,而且机器也只有一台没法实验,希望知道的达人告诉我这样有没有问题,有问题的话怎么解决?是不是需要先上传文件再读取?说简略点就可以,细节方面我都可以解决的,谢谢

问题很大。你服务器端得到的路经所表示的文件,根本在服务器端不存在。
如果你是想从客户端传数据。必须把文件传到服务端,或是用js解析后再传。
参考技术A 虽然我对jsp不太了解,但我觉得直接读取客户端本地文件数据的可能很小,那将会是多大一漏洞啊,感觉上应该是上传文件.

怎样将Excel文件导入数据库(在JSP环境下Java代码)

如何实现在JSP页面下,通过类似于文件上传的组件,选择本地的Excel文件,点击“导入”按钮,Excel文件的内容保存到Oracle数据库中相应的表中,同时Excel文件的内容显示在页面下,数据库的表已经建好。
我的思路是:
1.把excel文件上传到服务器的目录下
2.通过Java读取文件的内容
3.写SQL语句将内容插入数据库
4.从数据库中查询上一步所插入的记录,通过JSP显示
麻烦哪位高手给做个详细的程序看看,我现在有点思路却不大会写代码,真的拜托具体点,最好有注释,建立什么样的Java文件等等,让我也好好学习学习,奉上15财富(基本上我就这些了)谢谢大家!!!

呵呵,楼主既然思路都有了还怕写不出代码么?
你这个思路没有问题的!
可以把这个问题拆分成几个小问题,就简单多了。
第一是文件上传,可以参照Jakarta的FileUpload组件,其实也不一定要用这个,用普通的Post也就行了。
第二是Excel解析,用JSL或者POI都行
第三是数据保存,这个应该简单吧,一个循环,一行对应一条数据,写好了方法循环赋值调用就行了。
第四是查询和显示,这个更简单了,不用多说。

文件上传和Excel解析的例子网上很多的,改改就变自己的了,何必在这管别人要代码呢~
参考技术A 我只给你说下第二步怎么样吧,其他的你自己应该可以解决的。
通过使用第三方包jxl.jar,我以前导过数据,也是解析Excel,将Excel中的数据导入数据库中,这个包很好下,如果找不到可以留下邮箱
//程序说明: 要导入jxl.jar到Classpath中。
import jxl.*;
import java.io.*;
import jxl.write.*;
/**
* <p>java读取Excel表格,拷贴心、更新Excel工作薄 </p>
*/
public class Test1
public static void main(String[] args)
jxl.Workbook rwb = null;
try
//构建Workbook对象 只读Workbook对象
//直接从本地文件创建Workbook
//从输入流创建Workbook
InputStream is = new FileInputStream("D://Book1.xls");
rwb = Workbook.getWorkbook(is);
//Sheet(术语:工作表)就是Excel表格左下角的Sheet1,Sheet2,Sheet3但在程序中
//Sheet的下标是从0开始的
//获取第一张Sheet表
Sheet rs = rwb.getSheet(0);
//获取Sheet表中所包含的总列数
int rsColumns = rs.getColumns();
//获取Sheet表中所包含的总行数
int rsRows = rs.getRows();
//获取指这下单元格的对象引用
for(int i=0;i<rsRows;i++)
for(int j=0;j<rsColumns;j++)
Cell cell = rs.getCell(j,i);
System.out.print(cell.getContents()+" ");

System.out.println();

//利用已经创建的Excel工作薄创建新的可写入的Excel工作薄
jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(new File("D://Book2.xls"),rwb);
//读取第一张工作表
jxl.write.WritableSheet ws = wwb.getSheet(0);
//获取第一个单元格对象
jxl.write.WritableCell wc = ws.getWritableCell(0, 0);
//决断单元格的类型,做出相应的转化
if (wc.getType() == CellType.LABEL)
Label l = (Label) wc;
l.setString("The value has been modified.");

//写入Excel对象
wwb.write();
wwb.close();
catch(Exception e)
e.printStackTrace();

finally
//操作完成时,关闭对象,翻译占用的内存空间
rwb.close();


参考资料:http://wing929.javaeye.com/blog/185505

参考技术B 利用poi组件读出excel文件内部及各单元格 再插入到表的相应字段中。我一直是这么做的。或者利用jxl组件。

以上是关于jsp导入excel到DB的问题的主要内容,如果未能解决你的问题,请参考以下文章

如何将jsp 中的数据导入到excel表格 中

JSP导入EXCEL样式

如何将excel导入到datagrid,然后通过db值进行过滤。

jsp导入和导出excel的代码(jsp连接excel的方法)

多个Excel文件快速导入到DB里面

jsp页面table导入excel数据