一个关于上传的问题,老出错~~

佬侽孩 2010-10-10 04:14:41
上传的servlet类:

import java.io.File;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Iterator;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.ServletFileUpload;

/**
* 上传的组件,做修改
* @author Administrator
*
*/
public class FileUpload extends HttpServlet {

/**
* Destruction of the servlet. <br>
*/
private String uploadPath = "F:\\Tomcat5.5\\webapps\\TestUploadFile\\images\\item\\"; // 用于存放上传文件的目录
private File tempPath = new File("D:\\addnetFile\\tmp\\"); // 用于存放临时文件的目录

public void destroy() {
super.destroy(); // Just puts "destroy" string in log
// Put your code here
}

/**
* The doPost method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to
* post.
*
* @param request
* the request send by the client to the server
* @param response
* the response send by the server to the client
* @throws ServletException
* if an error occurred
* @throws IOException
* if an error occurred
*/
public void doPost(HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException {
res.setContentType("text/html; charset=GB2312");
PrintWriter out = res.getWriter();
System.out.println(req.getContentLength());
System.out.println(req.getContentType());
DiskFileItemFactory factory = new DiskFileItemFactory();
// maximum size that will be stored in memory
factory.setSizeThreshold(4096);
// the location for saving data that is larger than getSizeThreshold()
factory.setRepository(tempPath);

ServletFileUpload upload = new ServletFileUpload(factory);
// maximum size before a FileUploadException will be thrown
upload.setSizeMax(1000000);
try {
List fileItems = upload.parseRequest(req);
// assume we know there are two files. The first file is a small
// text file, the second is unknown and is written to a file on
// the server
Iterator iter = fileItems.iterator();

// 正则匹配,过滤路径取文件名
String regExp = ".+\\\\(.+)$";

// 过滤掉的文件类型
String[] errorType = { ".exe", ".com", ".cgi", ".asp" };
Pattern p = Pattern.compile(regExp);
while (iter.hasNext()) {
FileItem item = (FileItem) iter.next();
// 忽略其他不是文件域的所有表单信息
if (!item.isFormField()) {
String name = item.getName();
long size = item.getSize();
if ((name == null || name.equals("")) && size == 0)
continue;
Matcher m = p.matcher(name);
boolean result = m.find();
if (result) {
for (int temp = 0; temp < errorType.length; temp++) {
if (m.group(1).endsWith(errorType[temp])) {
throw new IOException(name + ": wrong type");
}
}
try {

// 保存上传的文件到指定的目录

// 在下文中上传文件至数据库时,将对这里改写
item.write(new File(uploadPath +"/"+ m.group(1)));

out.print(name + "  " + size + "<br>");
} catch (Exception e) {
out.println(e);
}

} else {
throw new IOException("fail to upload");

}
}
}
} catch (IOException e) {
out.println(e);
} catch (FileUploadException e) {
out.println(e);
}

// 保存上传的文件到指定的目录

// 在下文中上传文件至数据库时,将对这里改写

}

/**
* Initialization of the servlet. <br>
*
* @throws ServletException
* if an error occure
*/
public void init() throws ServletException {
// Put your code here
}

}


前台测试页面:


<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>index.html</title>

<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">

<!--<link rel="stylesheet" type="text/css" href="./styles.css">-->

</head>

<body>
<form action="./FileUpload" method="post" enctype="multipart/form-data" name="form1">
<input type="file" name="file">
<input type="submit" name="Submit" value="upload">
</form>
<form action="./servlet/HelloWord" method="post">
<input type="submit"/>
</form>
<form name="uploadform" method="POST" action="./FileUpload" ENCTYPE="multipart/form-data">

<table border="1" width="450" cellpadding="4" cellspacing="2" bordercolor="#9BD7FF">

<tr><td width="100%" colspan="2">

文件1:<input name="x" size="40" type="file">

</td></tr>

<tr><td width="100%" colspan="2">

文件2:<input name="y" size="40" type="file">

</td></tr>

<tr><td width="100%" colspan="2">

文件3:<input name="z" size="40" type="file">

</td></tr>

</table>

<br/><br/>

<table>

<tr><td align="center"><input name="upload" type="submit" value="开始上传"/></td></tr>

</table>

</form>

</body>
</html>



配置文件xml


<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<servlet>
<servlet-name>FileUpload</servlet-name>
<servlet-class>com.cn.fileupload.FileUpload</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>FileUpload</servlet-name>
<url-pattern>/FileUpload</url-pattern>
</servlet-mapping>
</web-app>


上传地址的文件包,都建立好了,但就是出错;一上传就显示 java.io.IOException: fail to upload
不知道咋回事
...全文
352 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
佬侽孩 2010-10-22
  • 打赏
  • 举报
回复
看来是包的问题啦 哎 换个包看看吧~~谢谢楼上的各位同志们啦~~
caofaping 2010-10-20
  • 打赏
  • 举报
回复
楼主,我帮你测试过,但这边没报错,代码一样,就是包不一样,
我用的是
commons-fileupload-1.2.1.jar
commons-io-1.3.2.jar
我是在struts2中找的包测得。

我看可能是包的问题。
sowuqing 2010-10-20
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 slabcde 的回复:]
// 忽略其他不是文件域的所有表单信息
if (!item.isFormField())
[/Quote]
和明显这里没有进去,看看这个方法的返回类型,是不是,如果是文件域就TRUE,不是就FALSE;
那就得把叹号去掉吧。
佬侽孩 2010-10-19
  • 打赏
  • 举报
回复
顶上去 ~~~待解决
佬侽孩 2010-10-16
  • 打赏
  • 举报
回复
呵呵 继续学习中~~·
闻志流e师兄 2010-10-14
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 kissau 的回复:]
文件类型的问题,根据你的代码 String[] errorType = { ".exe", ".com", ".cgi", ".asp" };
根据你的注释,你想剔除上面的文件类型,但是你的代码似乎是只能上传以上文件类型的文件。
[/Quote]
String regExp = ".+\\\\(.+)$";

// 过滤掉的文件类型
String[] errorType = { ".exe", ".com", ".cgi", ".asp" };
Pattern p = Pattern.compile(regExp);
不好意思看错了,可能和文件路径的\\\\有关
闻志流e师兄 2010-10-14
  • 打赏
  • 举报
回复
文件类型的问题,根据你的代码 String[] errorType = { ".exe", ".com", ".cgi", ".asp" };
根据你的注释,你想剔除上面的文件类型,但是你的代码似乎是只能上传以上文件类型的文件。
yudongming 2010-10-14
  • 打赏
  • 举报
回复
学习了
yaoweijq 2010-10-14
  • 打赏
  • 举报
回复
result是怎么得出来的?
[Quote=引用 6 楼 yimu0214 的回复:]
关键 后台没报一点异常;
前台也买你一上传后 页面出现的代码 就是java.io.IOException: fail to upload
用debug测试了下;是这个位置的result为false



Java code

if (result) {
for (int temp = 0; te……
[/Quote]
佬侽孩 2010-10-13
  • 打赏
  • 举报
回复
关键 后台没报一点异常;
前台也买你一上传后 页面出现的代码 就是java.io.IOException: fail to upload
用debug测试了下;是这个位置的result为false


if (result) {
for (int temp = 0; temp < errorType.length; temp++) {
if (m.group(1).endsWith(errorType[temp])) {
throw new IOException(name + ": wrong type");
}
}
try {

// 保存上传的文件到指定的目录

// 在下文中上传文件至数据库时,将对这里改写
item.write(new File(uploadPath +"/"+ m.group(1)));

out.print(name + "  " + size + "<br>");
} catch (Exception e) {
out.println(e);
}




没进这个result中,进行处理;拿这个代码给我同学,测试上传成功,没问题;靠,真没搞懂是咋回事;
以前用的jspsamart的组建 ,上传成功;现在换的这个apache的这个组建,上传就不成功了,驱动也导入进去了的;o(︶︿︶)o 唉

用到的驱动是:
commons-fileupload-1.1.1.jar
commons-io-1.2.jar
yaoweijq 2010-10-12
  • 打赏
  • 举报
回复
贴下完整的异常代码
佬侽孩 2010-10-12
  • 打赏
  • 举报
回复
o(︶︿︶)o 唉 没人顶 自己顶下吧
佬侽孩 2010-10-10
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 slabcde 的回复:]
1.检查下你getName()方法返回的值是否带路径
2.检查下返回的路径中分隔符是否是\,有可能是/
[/Quote]


getName()名字 不带路劲

路劲中的分隔符是“\”

这是测试结果:但还是报“java.io.IOException: fail to upload”这个错

multipart/form-data; boundary=---------------------------7da1a522602f8
uploadPath=F:\Tomcat5.5\webapps\TestUploadFile\images\item\
Name=bgToday1.gif

爱吃面条 2010-10-10
  • 打赏
  • 举报
回复
1.检查下你getName()方法返回的值是否带路径
2.检查下返回的路径中分隔符是否是\,有可能是/
爱吃面条 2010-10-10
  • 打赏
  • 举报
回复
// 忽略其他不是文件域的所有表单信息
if (!item.isFormField())

这里写的是忽略,else分支里不要抛异常就好了
​什么是共识算法背景分布式系统集群设计中面临着一个不可回避的问题,一致性问题对于系统中的多个服务节点,给定一系列操作,如何试图使全局对局部处理结果达成某种程度的一致?这个一致性问题大致有如下的场景:节点之间通讯不可靠的,延迟和阻塞节点的处理可能是错误的,甚至节点自身随时可能宕机节点作恶举例说明,就比如有两家电影院同时售卖总量一定的电影票,在这样的场景下,要如何设计方式来保证两家电影院协调同步不出现超卖或者错卖的问题呢?共识算法,就是解决对某一提案(目标,投票等各种协作工作),大家达成一致意见的过程比如上述的买票问题,就可以有如下的设计:1.每次卖票打电话给其他电影院,确认当前票数2.协商售卖时间,比如一三五A卖,二四六B卖3.成立个第三方存票机构,它统一发票通过以上的设计,可以看出一个很重要的解决一致性算法的解决思路,即:将可能引发不一致的并行操作进行串行化,就是现在计算机系统里处理分布式一致性问题基础思路和唯一秘诀 著名的共识设计理论FLP 不可能性原理  共识算法的理论下限提出该定理的论文是由 Fischer, Lynch 和 Patterson 三位作者于 1985 年发表,该论文后来获得了 Dijkstra(就是发明最短路径算法的那位)奖。FLP 原理认为对于允许节点失效情况下,纯粹异步系统无法确保一致性在有限时间内完成。三人三房间投票例子三个人在不同房间,进行投票(投票结果是 0 或者 1)。三个人彼此可以通过电话进行沟通,但经常会有人时不时地睡着。比如某个时候,A 投票 0,B 投票 1,C 收到了两人的投票,然后 C 睡着了。A 和 B 则永远无法在有限时间内获知最终的结果。如果可以重新投票,则类似情形每次在取得结果前发生带入到计算机领域就是说,即便在网络通信可靠情况下,一个可扩展的分布式系统的共识问题的下限是无解。即可靠性的下限是0%CAP  分布式系统领域的重要原理CAP 原理最早由 Eric Brewer 在 2000 年,ACM 组织的一个研讨会上提出猜想,后来 Lynch 等人进行了证明• C(一致性):所有的节点上的数据时刻保持同步,即数据一致• A(可用性):每个请求都能在一定时间内接受到一个响应,即低延迟• P(分区容错):当系统发生分区时仍然可以运行的定理:任何分布式系统只可同时满足二点,没法三者兼顾。即数据一致,响应及时,可分区执行不可能同时满足。举个例子:一个分布式网路上,某一个节点有一组依赖数据A,当网络无延迟,无阻塞时,依赖于X的操作可正常进行。但网络无延迟阻塞在现实世界中是没法100%保证的,那么当网络异常时,必然会产生分布式系统的分区和孤岛,那当一个执行操作在A分区之外时,如果要保证P,即当系统发生分区时仍可运行,就需要在分布式系统中多个节点有X的备份数据,以应对分区情况。则这时候就需要在C,A之间做出选择。假如选择C,即要保证数据在分布式网络中的一致性,那么就需要在X每次改动时,需要将全网节点的X数据同步刷新成最新的状态,那么在等待数据刷新完成之前,分布式系统是不可响应X的依赖操作的,即A的功能缺失假如选择A,即要突出低延迟的实时响应。那么在响应的时候,可能全节点的X数据并没有同步到最新的状态,则会导致C的缺失。上面看上去有些绕,那么你只要记住这句话,CAP原理在分布式网络系统的应用讨论,其实就是讨论在允许网络发生故障的系统中,该选择一致性还是可靠性?如果系统重视一致性,那么可以基于ACID原则做系统设计即 Atomicity(原子性)、Consistency(一致性)、Isolation(隔离性)、Durability(持久性)。ACID 原则描述了对分布式数据库的一致性需求,同时付出了可用性的代价。• Atomicity:每次操作是原子的,要么成功,要么不执行;• Consistency:数据库的状态是一致的,无中间状态;• Isolation:各种操作彼此互相不影响;• Durability:状态的改变是持久的,不会失效相应的有一个BASE原则,(Basic Availiability,Soft state,Eventually Consistency)则强调了可用性。 经典的共识算法设计业内,针对节点异常的情况,会有两种分类1.故障的,不响应的节点,成为非拜占庭错误2.恶意响应的节点,称为非拜占庭错误Paxos 最早的共识算法  非拜占庭算法的代表Paxos有三种角色:• proposer:提出一个提案,等待大家批准为结案。客户端担任该角色;• acceptor:负责对提案进行投票。往往是服务端担任该角色;• learner:被告知结案结果,并与之统一,不参与投票过程。即普通节点系统运行由proposer驱动,当合法提案在一定时间内收到1/2以上投票后达成共识。因此,可得出无法达成共识的条件:1.proposer故障2.二分之一以上acceptor故障拜占庭问题与BFT(Byzantine Fault Tolerant) 算法Leslie Lamport 1982 年提出用来解释一致性问题一个虚构模型。拜占庭是古代东罗马帝国的首都,由于地域宽广,守卫边境的多个将军(系统中的多个节点)需要通过信使来传递消息,达成某些一致的决定。但由于将军中可能存在叛徒(系统中节点出错),这些叛徒将努力向不同的将军发送不同的消息,试图会干扰一致性的达成。拜占庭问题即为在此情况下,如何让忠诚的将军们能达成行动的一致。对于拜占庭问题来说,假如将军总数为 N,叛变将军数为 F,则当N>=3F+1 时,问题才有解,即叛变的将军不超过1/3时,存在有效的算法,如BFT,不论叛变者如何折腾,忠诚的将军们总能达成一致的结果。这是一个数学论证的结论,有兴趣的同学可以自行推导。PBFT  一种高效拜占庭容错共识算法PBFT是Practical Byzantine Fault Tolerance的缩写,意为实用拜占庭容错算法。该算法是Miguel Castro 和Barbara Liskov(2008年图灵奖得主)在1999年提出来的,解决了原始拜占庭容错算法效率不高的问题。他的核心思想是:对于每一个收到命令的将军,都要去询问其他人,他们收到的命令是什么。如上图,假设命令由A将军分发,假如A是作恶异常,分发给B,C,D的操作分别是1,2,3.意图扰乱共识。拜占庭容错算法上设计实现是,当B,C,D收到命令后,相互之间也会沟通从A收到的命令是否一致,从而达到识破干扰的目的。其容错的极限值就是N>=3F+1。PBFT 在区块链上的实现区块链的节点分为记账节点和普通节点两个角色记账节点负责向全网提供记账服务,并维护全局账本,每过一段时间从记账节点中选一个议长,进行命令的分发,其他记账节点则作为议员进行验证将军就是记账节点,拥有全局账本,并验证交易的有效性,过互相传达验证结果,在f共识的一般流程如下:1.任一节点接收到发送者签名的交易数据请求后,向全网广播2.所有记账节点均独立监听全网的交易数据,并记录在内存3.议长在经过t后发送共识请求提案request4.议员在收到提案后,进行相关验证,发送响应response5.任意节点在限定时间内收到至少F+1个response后,共识达成,把交易记录入区块并发布给全网,如果超时,则更换视图和议长6.任意节点在收到完整区块后,把包含的交易从内存中删除开始下一个共识循环区块产生间隔t,    记账节点n,  可容错节点数f, 视图编号v,  区块高度h, 议长编号p,  议员编号i p=(h-v)%n  未来的发展POW算法建立了比特币帝国,具有划时代的意义。但其能耗和速度问题却是制约区块链普及的两大难以解决的问题。目前POS算法是一大趋势,以太坊的Casper,EOS的DPos等都是借鉴了上述前人的设计理念做的基于应用场景的优化改造,但万变不离其宗,我和大家一样,需要不断的学习和思考,没准,能有发明出自己的共识算法的一天呢。 

81,091

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧