无法访问“xxx.xls”。该文件可能已损坏,或文件所在的服务器没反映,或文件只是只读文件

 在系统中下载导出数据成excel时,下载完后,打开时出现错误

系统在本地上运行的时候,并不会出现这个问题,但移植到服务器上后,就出现了这样的问题

先在服务器确定输出的数据正常,可能是你数据量过大,数据输出不过来

也有可能excel版本可能不适用
比如2003的无法辨识2007或2010的word和excel
不过按你说的在你本地是没问题的 这个可能性不大

同样导出内容,看服务器导出文件的大小跟本地导出的大小是否一致,
再有一种情况可能就是服务器导出时有乱码问题

检查下服务器中 文件所在硬盘 的读写权限?~ 可那是只读的~

服务器端生成的Excel文件有问题。
先远程(或本机)登录到服务器,看下那个文件是否可以打开。

这是我写的
运行过,没有问题
package com.excel.mm;

import java.io.File;
import java.io.IOException;

import jxl.Cell;
import jxl.HeaderFooter;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableImage;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;

public class ExcelDaoImpl implements ExcelDao {

/**
 * 往Excel中插入图片
 * 
 * @param dataSheet
 *            待插入的工作表
 * @param col
 *            图片从该列开始
 * @param row
 *            图片从该行开始
 * @param width
 *            图片所占的列数
 * @param height
 *            图片所占的行数
 * @param imgFile
 *            要插入的图片文件
 */
public void insertImg(WritableSheet dataSheet, int col, int row, int width,
        int height, File imgFile) {
    WritableImage img = new WritableImage(col, row, width, height, imgFile);
    dataSheet.addImage(img);
}

/**
 * 读取Excel文件的内容
 * 
 * @param file
 *            待读取的文件
 * @return
 */
public String readExcel(File file) {
    StringBuffer sb = new StringBuffer();

    Workbook wb = null;
    try {
        // 构造Workbook(工作薄)对象
        wb = Workbook.getWorkbook(file);
    } catch (BiffException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

    if (wb == null)
        return null;

    // 获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了
    Sheet[] sheet = wb.getSheets();

    if (sheet != null && sheet.length > 0) {
        // 对每个工作表进行循环
        for (int i = 0; i < sheet.length; i++) {
            // 得到当前工作表的行数
            int rowNum = sheet[i].getRows();
            for (int j = 0; j < rowNum; j++) {
                // 得到当前行的所有单元格
                Cell[] cells = sheet[i].getRow(j);
                if (cells != null && cells.length > 0) {
                    // 对每个单元格进行循环
                    for (int k = 0; k < cells.length; k++) {
                        // 读取当前单元格的值
                        String cellValue = cells[k].getContents();
                        sb.append(cellValue + "\t");
                    }
                }
                sb.append("\r\n");
            }
            sb.append("\r\n");
        }
    }
    // 最后关闭资源,释放内存
    wb.close();
    return sb.toString();
}

/**
 * 搜索某一个文件中是否包含某个关键字
 * 
 * @param file
 *            待搜索的文件
 * @param keyWord
 *            要搜索的关键字
 * @return
 */
public boolean searchKeyWord(File file, String keyWord) {
    boolean res = false;

    Workbook wb = null;
    try {
        // 构造Workbook(工作薄)对象
        wb = Workbook.getWorkbook(file);
    } catch (BiffException e) {
        return res;
    } catch (IOException e) {
        return res;
    }

    if (wb == null)
        return res;

    // 获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了
    Sheet[] sheet = wb.getSheets();

    boolean breakSheet = false;

    if (sheet != null && sheet.length > 0) {
        // 对每个工作表进行循环
        for (int i = 0; i < sheet.length; i++) {
            if (breakSheet)
                break;

            // 得到当前工作表的行数
            int rowNum = sheet[i].getRows();

            boolean breakRow = false;

            for (int j = 0; j < rowNum; j++) {
                if (breakRow)
                    break;
                // 得到当前行的所有单元格
                Cell[] cells = sheet[i].getRow(j);
                if (cells != null && cells.length > 0) {
                    boolean breakCell = false;
                    // 对每个单元格进行循环
                    for (int k = 0; k < cells.length; k++) {
                        if (breakCell)
                            break;
                        // 读取当前单元格的值
                        String cellValue = cells[k].getContents();
                        if (cellValue == null)
                            continue;
                        if (cellValue.contains(keyWord)) {
                            res = true;
                            breakCell = true;
                            breakRow = true;
                            breakSheet = true;
                        }
                    }
                }
            }
        }
    }
    // 最后关闭资源,释放内存
    wb.close();

    return res;
}

/**
 * 向Excel中加入页眉
 * 
 * @param dataSheet
 *            待加入页眉的工作表
 * @param left
 * @param center
 * @param right
 */
public void setHeader(WritableSheet dataSheet, String left, String center,
        String right) {
    HeaderFooter hf = new HeaderFooter();
    hf.getLeft().append(left);
    hf.getCentre().append(center);
    hf.getRight().append(right);
    // 加入页眉
    dataSheet.getSettings().setHeader(hf);

}

/**
 * 向Excel中加入页脚
 * 
 * @param dataSheet
 *            待加入页眉的工作表
 * @param left
 * @param center
 * @param right
 */
public void setFooter(WritableSheet dataSheet, String left, String center,
        String right) {
    HeaderFooter hf = new HeaderFooter();
    hf.getLeft().append(left);
    hf.getCentre().append(center);
    hf.getRight().append(right);

    // 加入页脚
    dataSheet.getSettings().setFooter(hf);
}

/**
 * 生成一个Excel文件
 * 
 * @param fileName
 *            要生成的Excel文件名
 */
public void writeExcel(String fileName) {
    WritableWorkbook wwb = null;
    try {
        // 首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象
        wwb = Workbook.createWorkbook(new File(fileName));
    } catch (IOException e) {
        e.printStackTrace();
    }
    if (wwb != null) {
        // 创建一个可写入的工作表
        // Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置
        WritableSheet ws = wwb.createSheet("sheet1", 0);

        // 下面开始添加单元格
        for (int i = 0; i < 10; i++) {
            for (int j = 0; j < 5; j++) {
                // 这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行
                Label labelC = new Label(j, i, "这是第" + (i + 1) + "行,第"
                        + (j + 1) + "列");
                try {
                    // 将生成的单元格添加到工作表中
                    ws.addCell(labelC);
                } catch (RowsExceededException e) {
                    e.printStackTrace();
                } catch (WriteException e) {
                    e.printStackTrace();
                }

            }
        }

        try {
            // 从内存中写入文件中
            wwb.write();
            // 关闭资源,释放内存
            wwb.close();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (WriteException e) {
            e.printStackTrace();
        }
    }
}

}

先不直接打开,另存成xls文件,再打开看看

那估计是你的下载时的响应头没设置好。我一般这样写
String contentType = "application/octet-stream;charset=utf-8";
response.setContentType(contentType);
response.setHeader("Content-Disposition","attachment;filename=\"XXXXX\"");