//我这里只记录重要的代码,不重要的我就没贴过来了
if(getResponse().containsHeader("ContentType"))
{getResponse().setHeader("ContentType","application/octet-stream");
}
else
{
getResponse().addHeader("ContentType","application/octet-stream");
}
if(getResponse().containsHeader("Content-Disposition"))
{
getResponse().setHeader("Content-Disposition","attachment;FileName="+fileName+"."+suffix);
}
else
{
getResponse().addHeader("Content-Disposition","attachment;FileName="+fileName+"."+suffix);
}
ServletOutputStream os;
//realPath是我经过uedit提交的时候处理的字段,这个当浏览者用户拿到东西后根据情况而定
File file = new File("realPath");
if(file.isFile()){
FileInputStream fis = null;
try {
fis = new FileInputStream(file);
} catch (FileNotFoundException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
BufferedInputStream bis = new BufferedInputStream(fis);
int len;
try {
os = getResponse().getOutputStream();
byte[] b = new byte[len = bis.available()];
if(len != bis.read(b, 0, len))
{
}
os.write(b);
os.close();
getResponse().flushBuffer();
}
catch (IOException e)
{
}
}
我做的这块是UEDIT自带的上传功能,把上传的文件经过substring处理之后包括指入后台的方法和指向的文件路径与文件名,存入数据库,当用户读取后会调用后台的这个方法,所以解决了直接打开文件的不当之处
要决是告诉台前用户这是一个文件,不能打开。主要是在response.setHeader这一块,然后把response.getOutputStream写入文件即可