ASP.NET文件操做幫助類

    public class FileHepler
    {
        /// <summary>
        /// 上傳一個文件
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public static FileModel RequestFile(string key,bool isUsed = false)
        {
            HttpPostedFile file = HttpContext.Current.Request.Files[key];
            if(isUsed)
            {
                return GetFileModel1(file);
            }
            return GetFileModel(file);
        }

        public static FileModel SaveFile(string key, string saveUrl,bool isChange=false, bool isUsed = false)
        {
            HttpPostedFile file = HttpContext.Current.Request.Files[key];
            FileModel model = new FileModel();
            try
            {   
                if(isChange)
                {
                    saveUrl = saveUrl + file.FileName;
                }
                else
                {
                    if (Path.GetExtension(file.FileName) != Path.GetExtension(saveUrl))
                    {
                        saveUrl = saveUrl.Replace(Path.GetExtension(saveUrl), Path.GetExtension(file.FileName));
                    }
                }
                string url = HttpContext.Current.Request.MapPath(saveUrl);
                file.SaveAs(url);
                if (isUsed)
                {
                    model = GetFileModel1(file);
                }
                else
                {
                    model = GetFileModel(file);
                }
                model.FileOldUrl = saveUrl;
                model.FileUrl = url;
            }
            catch (Exception ex)
            {
                model.Flag = false;
                model.Result = ex.Message;
            }
            return model;
        }

        public static FileModel SaveFirstFile(string saveUrl, bool isChange = false, bool isUsed = false)
        {
            HttpPostedFile file = HttpContext.Current.Request.Files[0];
            FileModel model = new FileModel();
            try
            {
                if (isChange)
                {
                    saveUrl = saveUrl + file.FileName;
                }
                else
                {
                    if (Path.GetExtension(file.FileName) != Path.GetExtension(saveUrl))
                    {
                        saveUrl = saveUrl.Replace(Path.GetExtension(saveUrl), Path.GetExtension(file.FileName));
                    }
                }
                string url = HttpContext.Current.Request.MapPath(saveUrl);
                file.SaveAs(url);
                if (isUsed)
                {
                    model = GetFileModel1(file);
                }
                else
                {
                    model = GetFileModel(file);
                }
                model.FileOldUrl = saveUrl;
                model.FileUrl = url;
            }
            catch (Exception ex)
            {
                model.Flag = false;
                model.Result = ex.Message;
            }
            return model;
        }

        public static FileModel SaveFile(HttpPostedFile _file,string saveUrl, bool isChange = false, bool isUsed = false)
        {
            HttpPostedFile file = _file;
            FileModel model = new FileModel();
            try
            {
                if (isChange)
                {
                    saveUrl = saveUrl + file.FileName;
                }
                else
                {
                    if (Path.GetExtension(file.FileName) != Path.GetExtension(saveUrl))
                    {
                        saveUrl = saveUrl.Replace(Path.GetExtension(saveUrl), Path.GetExtension(file.FileName));
                    }
                }
                string url = HttpContext.Current.Request.MapPath(saveUrl);
                file.SaveAs(url);
                if (isUsed)
                {
                    model = GetFileModel1(file);
                }
                else
                {
                    model = GetFileModel(file);
                }
                model.FileOldUrl = saveUrl;
                model.FileUrl = url;
            }
            catch (Exception ex)
            {
                model.Flag = false;
                model.Result = ex.Message;
            }
            return model;
        }

        public static List<FileModel> SaveFileList(int fileNum, string saveUrl, bool isChange = false, bool isUsed = false)
        {
            List<FileModel> filelist = new List<FileModel>();
            for (int i = 0; i < fileNum; i++)
            {
                HttpPostedFile file = HttpContext.Current.Request.Files[i];
                FileModel model = new FileModel();
                try
                {
                    if (isChange)
                    {
                        saveUrl = saveUrl + file.FileName;
                    }
                    else
                    {
                        if (Path.GetExtension(file.FileName) != Path.GetExtension(saveUrl))
                        {
                            saveUrl = saveUrl.Replace(Path.GetExtension(saveUrl), Path.GetExtension(file.FileName));
                        }
                    }
                    string url = HttpContext.Current.Request.MapPath(saveUrl);
                    file.SaveAs(url);
                    if (isUsed)
                    {
                        model = GetFileModel1(file);
                    }
                    else
                    {
                        model = GetFileModel(file);
                    }
                    model.FileOldUrl = saveUrl;
                    model.FileUrl = url;
                }
                catch (Exception ex)
                {
                    model.Flag = false;
                    model.Result = ex.Message;
                }
                filelist.Add(model);
            }
            return filelist;
        }

        /// <summary>
        /// 上傳多個文件,經過文件索引獲取
        /// </summary>
        /// <param name="fileNum"></param>
        /// <returns></returns>
        public static List<FileModel> RequestFileList(int fileNum, bool isUsed = false)
        {
            List<FileModel> filelist = new List<FileModel>();
            for (int i = 0; i < fileNum; i++)
            {
                HttpPostedFile file = HttpContext.Current.Request.Files[i];
                if (file != null)
                {
                    FileModel model = new FileModel();
                    if (isUsed)
                    {
                        model = GetFileModel1(file);
                    }
                    else
                    {
                        model = GetFileModel(file);
                    }         
                    filelist.Add(model);
                }
            }
            return filelist;
        }

        public static List<FileModel> RequestFileList2(int fileNum, bool isUsed = false)
        {
            List<FileModel> filelist = new List<FileModel>();
            for (int i = 0; i < fileNum; i++)
            {
                HttpPostedFile file = HttpContext.Current.Request.Files[i];
                if (file != null)
                {
                    FileModel model = new FileModel();
                    if (isUsed)
                    {
                        model = GetFileModel1(file);
                    }
                    else
                    {
                        model = GetFileModel(file);
                    }
                    filelist.Add(model);
                }
                else
                {
                    break;
                }
            }
            return filelist;
        }

        public static FileModel RequestFirstFile(bool isUsed = false)
        {
            FileModel model = new FileModel();
            HttpPostedFile file = HttpContext.Current.Request.Files[0];
            if (file != null)
            {
                if (isUsed)
                {
                    model = GetFileModel1(file);
                }
                else
                {
                    model = GetFileModel(file);
                }      
            }
            return model;
        }

        public static FileModel GetFileModel(HttpPostedFile file)
        {
            FileModel model = new FileModel();
            model.FileName = file.FileName;
            model.FileSingleName = Path.GetFileNameWithoutExtension(file.FileName);
            model.FileExt = Path.GetExtension(file.FileName).Replace(".", "");
            model.FileSize = file.ContentLength;
            model.FileStream = file.InputStream;
            model.NewFile = file;
            if (file == null)
            {
                return null;
            }
            int FileLen;
            FileLen = file.ContentLength;
            System.IO.Stream MyStream;
            byte[] bytes = new byte[FileLen];
            MyStream = file.InputStream;
            MyStream.Read(bytes, 0, FileLen);
            MyStream.Close();
            MyStream.Dispose();
            model.FileByte = bytes;
            return model;
        }

        public static FileModel GetFileModel1(HttpPostedFile file)
        {
            FileModel model = new FileModel();
            model.FileName = file.FileName;
            model.FileSingleName = Path.GetFileNameWithoutExtension(file.FileName);
            model.FileExt = Path.GetExtension(file.FileName).Replace(".", "");
            model.FileSize = file.ContentLength;
            model.FileStream = file.InputStream;
            model.NewFile = file;
            if (file == null)
            {
                return null;
            }
            int FileLen;
            FileLen = file.ContentLength;
            System.IO.Stream MyStream;
            byte[] bytes = new byte[FileLen];
            MyStream = file.InputStream;
            MyStream.Read(bytes, 0, FileLen);
            model.NewStream = MyStream;
            model.FileByte = bytes;
            return model;
        }

        public static DataTable GetExcelDatatable(string fileUrl)
        {
            //office2007以前 僅支持.xls
            //const string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1';";
            //支持.xls和.xlsx,即包括office2010等版本的   HDR=No表明第一行是標題,不是數據;Yes爲數據
            string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'";
            // string cmdText = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0;IMEX=1'";
            DataTable dt = null;
            //創建鏈接
            OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));
            //打開鏈接
            if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
            {
                conn.Open();
            }
            //獲取全部的sheet的名稱 即多個表格數據
            DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
            //獲取Excel的第一個Sheet名稱
            string sheetName = schemaTable.Rows[0]["TABLE_NAME"].ToString().Trim();
            //查詢sheet中的數據
            string strSql = "select * from [" + sheetName + "]";
            OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
            DataSet ds = new DataSet();
            da.Fill(ds);
            dt = ds.Tables[0];
            da.Dispose();//釋放資源 以避免影響後面對excel操做
            dt.Dispose();
            ds.Dispose();
            return dt;
        }

        public static DataTable GetExcelDatatable1(string fileUrl)
        {
            //office2007以前 僅支持.xls
            //const string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1';";
            //支持.xls和.xlsx,即包括office2010等版本的   HDR=No表明第一行是標題,不是數據;Yes爲數據
            string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=No; IMEX=1'";
            // string cmdText = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0;IMEX=1'";
            DataTable dt = null;
            //創建鏈接
            OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));
            //打開鏈接
            if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
            {
                conn.Open();
            }
            //獲取全部的sheet的名稱 即多個表格數據
            DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
            //獲取Excel的第一個Sheet名稱
            string sheetName = schemaTable.Rows[0]["TABLE_NAME"].ToString().Trim();
            //查詢sheet中的數據
            string strSql = "select * from [" + sheetName + "]";
            OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
            DataSet ds = new DataSet();
            da.Fill(ds);
            dt = ds.Tables[0];
            da.Dispose();//釋放資源 以避免影響後面對excel操做
            dt.Dispose();
            ds.Dispose();
            return dt;
        }

        public static DataSet GetExcelDataSet(string fileUrl)
        {
            //office2007以前 僅支持.xls
            //const string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1';";
            //支持.xls和.xlsx,即包括office2010等版本的   HDR=No表明第一行是標題,不是數據;Yes爲數據
            string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'";
            // string cmdText = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0;IMEX=1'";
            DataSet fileds = null;
            //創建鏈接
            OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));
            //打開鏈接
            if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
            {
                conn.Open();
            }
            //獲取全部的sheet的名稱 即多個表格數據
            DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
            for (int i = 0; i < schemaTable.Rows.Count; i++)
            {
                //獲取Excel的第一個Sheet名稱
                string sheetName = schemaTable.Rows[i]["TABLE_NAME"].ToString().Trim();
                //查詢sheet中的數據
                string strSql = "select * from [" + sheetName + "]";
                OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
                DataSet ds = new DataSet();
                da.Fill(ds);    
                fileds.Tables.Add(ds.Tables[0]);
                da.Dispose();//釋放資源 以避免影響後面對excel操做
                fileds.Dispose();
                ds.Dispose();
            }
            return fileds;
        }

        public static DataSet GetExcelDataSet1(string fileUrl)
        {
            //office2007以前 僅支持.xls
            //const string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1';";
            //支持.xls和.xlsx,即包括office2010等版本的   HDR=No表明第一行是標題,不是數據;Yes爲數據
            string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=No; IMEX=1'";
            // string cmdText = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0;IMEX=1'";
            DataSet fileds = null;
            //創建鏈接
            OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));
            //打開鏈接
            if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
            {
                conn.Open();
            }
            //獲取全部的sheet的名稱 即多個表格數據
            DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
            for (int i = 0; i < schemaTable.Rows.Count; i++)
            {
                //獲取Excel的第一個Sheet名稱
                string sheetName = schemaTable.Rows[i]["TABLE_NAME"].ToString().Trim();
                //查詢sheet中的數據
                string strSql = "select * from [" + sheetName + "]";
                OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
                DataSet ds = new DataSet();
                da.Fill(ds);
                fileds.Tables.Add(ds.Tables[0]);
                da.Dispose();//釋放資源 以避免影響後面對excel操做
                fileds.Dispose();
                ds.Dispose();
            }
            return fileds;
        }


    }

    public class FileModel
    {
        public byte[] FileByte { get; set; }
        public string FileName { get; set; }
        public string FileSingleName { get; set; }
        public string FileExt { get; set; }
        public long FileSize { get; set; }
        public Stream FileStream { get; set; }
        public Stream NewStream { get; set; } 
        public bool Flag { get; set; } = true;
        public string Result { get; set; }
        public string FileUrl { get; set; }
        public string FileOldUrl { get; set; }
        public HttpPostedFile NewFile { get; set; }
    }
相關文章
相關標籤/搜索