内容显示页:

protected void btnIMP_Click(object sender, EventArgs e)         {             Response.Redirect("导入页.aspx?backurl=" + DESEncrypt.Encrypt(iurl));         }

aspx: <head runat="server">     <title></title>   <script type="text/javascript" src="../Page/js/jquery-1.7.2.min.js"></script>     <script type="text/javascript" src="../Page/js/hide_show.js"></script>     <link href="../Page/css/layout.css" rel="stylesheet" type="text/css" />     <link href="../Page/css/Dialog.css" rel="stylesheet" type="text/css" />     <script type="text/javascript" src="../Page/js/jQuery_Dialog.js"></script>     <script type="text/javascript" src="../Page/js/function.js"></script>     <script type="text/javascript" src="../Page/js/jquery.easydrag.js"></script>     <link href="../Page/css/style01.css" rel="stylesheet" type="text/css" /> </head> <body>      <form id="form1" runat="server">     <div class="DivMain">         <div class="m_nav">             <%=siteMap %><span>></span><a href="javascript:void(0);">记录信息导入</a>         </div>         <!--结束-->         <div class="clearDiv">         </div>         <div class="Search">             批量导入记录信息模板下载:<a href="../Resources/Template/批量导入记录信息.xls">【批量导入记录信息模板】</a>         </div>         <div class="div_right_search">

<table class="table_search_001" width="600">                 <tr>                     <td>                         &nbsp;选择文件:                         <asp:FileUpload ID="fileUpload" runat="server" CssClass="txt_file" Width="300px" />                         <asp:Button runat="server" Text="EXCEL导入" ID="btnImp" OnClientClick="return check()"                             OnClick="btnImp_Click" CssClass="button_sm7" />                         <asp:Button runat="server" ID="btnBack" CssClass="button_sm1" Text="返回" OnClick="btnBack_Click" />                     </td>                 </tr>             </table>         </div>         <div class="div_right_search" id="divHandel" runat="server" style="text-align: left;">             &nbsp;<input type="button" class="button_bg7" onclick="showExcelData('good')" value='显示验证通过' />             <input type="button" class="button_bg7" onclick="showExcelData('bad')" value='显示验证没通过' />             <input type="button" class="button_bg7" onclick="showExcelData('all')" value='显示所有' />             <asp:Button ID="btnImpRight" runat="server" CssClass="button_bg7" Text="导入验证通过" OnClick="btnImpRight_Click"                 OnClientClick="return checkIMP();" />             <asp:Button ID="btnCancel" runat="server" CssClass="button_sm1" Text="取  消" OnClick="btnCancel_Click" />         </div>         <div class='clearDiv'>         </div>         <div id="divBadData">             <%Response.Write(GetBadData()); %>         </div>         <div id="divGoodData">             <%Response.Write(GetGoodData()); %>         </div>     </div>     <!-- 背景层DIV -->     <div class="div_documentbg" id="div_documentbg">     </div>     <script language="javascript" type="text/javascript">         function check() {             if ($("#<%=fileUpload.ClientID %>").val() == "") {                 $.dialog.alert("请选择需要上传的EXCEL文件。");

return false;             }             var doc_name = $("#<%=fileUpload.ClientID %>").val();             var doc_type = doc_name.substring(doc_name.lastIndexOf("\\") + 1).split(".")[1];             if (doc_type != "xls") {                 $.dialog.alert("请选择后缀名为.xls文件。");                 return false;             }             if (confirm("您将要导入记录信息")) {                 SubmitData2(getLoadingDot("正在操作,请稍后"), 600);                 setInterval("$('.tips_jinggao').html(getLoadingDot(\"正在操作,请稍后\"))", 1000);             }         }

function checkIMP() {             SubmitData2(getLoadingDot("正在操作,请稍后"), 600);             setInterval("$('.tips_jinggao').html(getLoadingDot(\"正在操作,请稍后\"))", 1000);         }

function showExcelData(type) {             if (type == "good") {                 $("#divBadData").hide();                 $("#divGoodData").show();             }             else if (type == "bad") {                 $("#divBadData").show();                 $("#divGoodData").hide();             }             else {                 $("#divBadData").show();                 $("#divGoodData").show();             }         }     </script>     </form> </body> </html>

aspx.cs:  protected string strTempletTitle1 = string.Empty;  protected string strTemplet = string.Empty;         static string strGoodData = string.Empty;  static string strBadData = string.Empty;  static DataTable excelData = new DataTable();  protected string backurl = string.Empty;   protected void Page_Load(object sender, EventArgs e)         {             strTempletTitle1 = "内容一,内容二";             strTemplet = string.Empty;             backurl = Request.QueryString["backurl"];             if (!IsPostBack)             {                 strGoodData = string.Empty;                 strBadData = string.Empty;             }             ShowHandel();         }   protected void btnImp_Click(object sender, EventArgs e)         {             DataSet ds = new DataSet();             string uploadFileName = string.Empty;

if (fileUpload.HasFile)             {                 try                 {                     uploadFileName = fileUpload.FileName;                     string errorMessage = string.Empty;

if (!CheckFileName(fileUpload.FileName, out errorMessage))                     {                         ClientScript.RegisterStartupScript(this.GetType(), "check", "$.dialog.alert('" + errorMessage + "');", true);                         return;                     }                     DeleteInvoiceFile();                     string serverPath = Server.MapPath("../Resources/UpFile/");                     string fileName = serverPath + Guid.NewGuid() + ".xls";                     if (!Directory.Exists(serverPath))                     {                         Directory.CreateDirectory(serverPath);                     }                     fileUpload.SaveAs(fileName);                     OleDbConnection conn;                     OleDbDataAdapter da;                     System.Data.DataTable tblSchema;//存放领域表的结构                     IList<string> tblNames;//sheet名称                     GetExcelSchema(fileName, out conn, out da, out tblSchema, out tblNames, "YES", 1);                     if (ds != null) ds.Clear();                     ds = GetEachSheetContent(conn, ref da, tblSchema, ref tblNames);                     if (ds.Tables.Count == 0)                     {                         ClientScript.RegisterStartupScript(this.GetType(), "check", "$.dialog.alert('导入失败,你可能选择了错误的模板,请重新上传。');", true);                         return;                     }                     //验证模板结构                     strTemplet = strTempletTitle1;                     if (!CheckUploadDataStructure(ds, strTemplet, out errorMessage))                     {                         ClientScript.RegisterStartupScript(this.GetType(), "check", "$.dialog.alert('" + errorMessage + "');", true);                         return;                     }                     excelData = new DataTable();                     excelData = ds.Tables[0];                     DataColumn dcErr = new DataColumn();                     dcErr.ColumnName = "ErrorDate";                     dcErr.DataType = typeof(string);                     dcErr.Caption = "错误提示";                     excelData.Columns.Add(dcErr);                     CheckUploadData();                 }                 catch (Exception ex)                 {                     Response.Output.WriteLine(ex.Message);                     Response.Output.WriteLine(ex.StackTrace);                     Response.End();                 }             }             ShowHandel();         }         private void ShowHandel()         {

if (excelData.Rows.Count == 0)             {                 divHandel.Visible = false;             }             else             {                 divHandel.Visible = true;             }

}

private void InputExcelDataToDB()         {             int exData = 0;             string strSql = string.Empty;             List<string> listSql = new List<string>();             try             {                 DataRow[] dr = excelData.Select("ErrorDate='正确'");                 if (dr.Count() > 0)                 {                     strSql = string.Empty;                     #region 组SQL语句                     for (int i = 0; i < dr.Count(); i++)                     {                         strSql = @"insert into table(字段)";                                               strSql += "VALUES ('" + dr[i]["内容一"].ToString().Trim() + "'";                         strSql += ",'" + dr[i]["内容二"].ToString().Trim() + "'";                         listSql.Add(strSql);                     }                     #endregion

exData = DbHelperSQL.ExecuteSqlTran(listSql);                     if (exData > 0)                     {                         string url = string.IsNullOrEmpty(backurl) ? "内容显示页.aspx" : DESEncrypt.Decrypt(backurl);                         SYS_LOG.AddCommonLog(pfunction.SysLogQueryMenu(Module_Id), "【批量导入记录管理信息成功】,操作用户【" + CookiesMan.GetCookie("xy_admin_user", "userTrueName") + "】", CookiesMan.GetCookie("xy_admin_user", "userName"));                         ClientScript.RegisterStartupScript(this.GetType(), "handle", "SubmitDataSuccess('【" + exData + "】记录管理信息被成功导入','" + url + "','1');", true);                     }                     else                     {                         SYS_LOG.AddErrorLog(Request.Url.AbsolutePath, "【批量导入记录信息失败】,操作用户【" + CookiesMan.GetCookie("xy_admin_user", "userTrueName") + "】", CookiesMan.GetCookie("xy_admin_user", "userName"));                         ClientScript.RegisterStartupScript(this.GetType(), "handle", "SubmitDataError('操作失败','','3');", true);                     }                 }                 else                 {                     SYS_LOG.AddErrorLog(Request.Url.AbsolutePath, "【批量导入记录信息失败】,操作用户【" + CookiesMan.GetCookie("xy_admin_user", "userTrueName") + "】", CookiesMan.GetCookie("xy_admin_user", "userName"));                     ClientScript.RegisterStartupScript(this.GetType(), "handle", "SubmitDataError('数据为空,导入失败','','3');", true);                 }

}             catch (Exception ex)             {                 SYS_LOG.AddErrorLog(Request.Url.AbsolutePath, "【批量导入记录信息失败】" + ex.Message.ToString().Replace("'", "") + ",操作用户【" + CookiesMan.GetCookie("xy_admin_user", "userTrueName") + "】", CookiesMan.GetCookie("xy_admin_user", "userName"));                 ClientScript.RegisterStartupScript(this.GetType(), "handle", "SubmitDataError('操作失败:" + ex.Message.ToString() + "','','3');", true);             }

excelData.Clear();

}         /// <summary>         /// 验证导入数据         /// </summary>         /// <param name="goodData"></param>         /// <param name="badData"></param>         /// <param name="dataAll"></param>         private void CheckUploadData()         {             for (int i = 0; i < excelData.Rows.Count; i++)             {                 DataRow dr = excelData.Rows[i];                 string strErr = string.Empty;                 CheckOption(dr, out strErr);                 excelData.Rows[i]["ErrorDate"] = strErr;             }         }         /// <summary>         /// 显示验证通过的数据         /// </summary>         /// <returns></returns>         protected string GetGoodData()         {             if (excelData.Rows.Count == 0)             {                 return "";             }             DataRow[] dr = excelData.Select("ErrorDate='正确'");             if (dr.Count() == 0)             {                 return "";             }             string strAlert = string.Empty;

if (dr.Count() == excelData.Rows.Count)             {                 strAlert = "<font color='green'>全部记录信息都已验证通过</font>";             }             else             {                 strAlert = "<font color='yellow'>【" + dr.Count() + "】记录信息验证通过</font>";             }             #region             strGoodData = string.Empty;             strGoodData += "<div class='clearDiv'></div><div class=\"div_right_listtitle\">";             strGoodData += "<div style=\"margin-left:15px;font-weight:bold;padding-top:7px;\">" + strAlert + "</div>";             strGoodData += "</div>";             strGoodData += "<table class='table_list' cellpadding='0' cellspacing='0' >";             strGoodData += "<tr class='tr_title'>";             strGoodData += "<td>内容一</td>";             strGoodData += "<td>内容二</td>";             strGoodData += "</tr>";             for (int i = 0; i < dr.Count(); i++)             {                 strGoodData += "<tr class='tr_con_001'>";                 strGoodData += "<td>" + dr[i]["内容一"] + "</td>";                 strGoodData += "<td>" + dr[i]["内容二"] + "</td>";                                strGoodData += "</tr>";             }             strGoodData += "</table>";

#endregion

return strGoodData;         }         /// <summary>         /// 显示验证没有通过的数据         /// </summary>         /// <returns></returns>         protected string GetBadData()         {             if (excelData.Rows.Count == 0)             {                 return "";             }             DataRow[] dr = excelData.Select("ErrorDate<>'正确'");             if (dr.Count() == 0)             {                 return "";             }             string strAlert = string.Empty;             if (dr.Count() == excelData.Rows.Count)             {                 strAlert = "<font color='red'><div class='clearDiv'></div>全部记录信息都没有验证通过</font>";             }             else             {                 strAlert = "<font color='red'>【" + dr.Count() + "】记录信息验证没通过</font>";             }             #region             strBadData = string.Empty;             strBadData += "<div class=\"div_right_listtitle\">";             strBadData += "<div style=\"margin-left:15px;font-weight:bold;padding-top:7px;\">" + strAlert + "</div>";             strBadData += "</div>";             strBadData += "<table class='table_list' cellpadding='0' cellspacing='0' >";             strBadData += "<tr class='tr_title'>";             strBadData += "<td>内容一</td>";             strBadData += "<td>内容二</td>";             strBadData += "<td>错误提示</td>";             strBadData += "</tr>";

for (int i = 0; i < dr.Count(); i++)             {                 strBadData += "<tr class='tr_con_001'>";                 strBadData += "<td>" + dr[i]["内容一"] + "</td>";                 strBadData += "<td>" + dr[i]["内容二"] + "</td>";                 strBadData += "<td  style='text-align:left;'>" + dr[i]["ErrorDate"] + "</td>";                 strBadData += "</tr>";             }             strBadData += "</table>";

#endregion             return strBadData;         }         /// <summary>         /// 核对每一项的值         /// </summary>         /// <param name="dr"></param>         /// <param name="type"></param>         /// <param name="strErr"></param>         /// <returns></returns>         private bool CheckOption(DataRow dr, out string strErr)         {             bool bTemp = true;             strErr = string.Empty;

if (dr["内容一"].ToString().Trim() == "")             {                 bTemp = false;                 strErr += "内容一为空值<br>";             }             if (dr["内容二"].ToString().Trim() == "")             {                 bTemp = false;                 strErr += "内容二为空值<br>";             }             if (strErr.Length > 4)             {                 strErr = strErr.Remove(strErr.Length - 4);             }             if (bTemp)             {                 strErr = "正确";             }

return bTemp;

}         /// <summary>         /// 验证上传数据的模板结构         /// </summary>         /// <param name="ds"></param>         /// <param name="list"></param>         /// <param name="errorMessage"></param>         /// <returns></returns>         private bool CheckUploadDataStructure(DataSet ds, string strTitle, out string errorMessage)         {

if (ds.Tables[0].Columns.Count != strTitle.Split(',').Count())             {                 errorMessage = "上传文件模板字段的个数不对应,请核对模板后重新上传";                 return false;             }             List<string> listTemp = new List<string>();             for (int i = 0; i < ds.Tables[0].Columns.Count; i++)             {                 if (ds.Tables[0].Columns[i].ColumnName.Trim().ToUpper() != strTitle.Split(',')[i].ToUpper())                 {                     errorMessage = "第【" + (i + 1) + "】个字段的名称与定义模板中的名称不一致,请修改后重新上传";                     return false;                 }             }             errorMessage = string.Empty;             return true;         }         /// <summary>         /// 验证上传的文件         /// </summary>         /// <param name="fileName"></param>         /// <param name="errorMessage"></param>         /// <returns></returns>         private bool CheckFileName(string fileName, out string errorMessage)         {             if (fileName.Substring(fileName.LastIndexOf('.') + 1).ToLower() != "xls")             {                 errorMessage = "请选择后缀名为.xls的EXCEL文件上传";                 return false;             }             errorMessage = string.Empty;             return true;         }         /// <summary>         /// 删除上传的文件         /// </summary>         private void DeleteInvoiceFile()         {             string serverPath = Server.MapPath("../Resources/UpFile/");             if (!Directory.Exists(serverPath))             {                 Directory.CreateDirectory(serverPath);             }             foreach (string file in Directory.GetFiles(serverPath))             {                 File.Delete(file);             }         }         #region Excel读取         private void GetExcelSchema(string filename, out OleDbConnection conn, out OleDbDataAdapter da, out System.Data.DataTable tblSchema, out IList<string> tblNames, string ifFirst, int i)         {             // 读取Excel数据,填充DataSet             // 连接字符串                        string connStr = "Provider=Microsoft.Jet.OLEDB.4.0;" +                             "Extended Properties=\"Excel 8.0;HDR=" + ifFirst + ";IMEX=" + i + "\";" + // 指定扩展属性为 Microsoft Excel 8.0 (97) 9.0 (2000) 10.0 (2002),并且第一行作为数据返回,且以文本方式读取                             "data source=" + filename;             //string connStr = "Provider=Microsoft.ACE.OLEDB.12.0;" +             //                "Extended Properties=\"Excel 12.0 Xml;HDR=" + ifFirst + ";IMEX=" + i + "\";" + // 指定扩展属性为 Microsoft Excel 8.0 (97) 9.0 (2000) 10.0 (2002),并且第一行作为数据返回,且以文本方式读取             //                "data source=" + filename;             conn = null;             da = null;             tblSchema = null;             tblNames = null;             // 初始化连接,并打开             conn = new OleDbConnection(connStr);             conn.Open();             //获取数据源的表定义元数据             tblSchema = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });             conn.Close();         }         private static DataSet GetEachSheetContent(OleDbConnection conn, ref OleDbDataAdapter da, System.Data.DataTable tblSchema, ref IList<string> tblNames)         {             tblNames = new List<string>();             foreach (DataRow row in tblSchema.Rows)             {                 string tableName = (string)row["TABLE_NAME"];                 if (!tableName.StartsWith("_")) //skip system tables                 {                     tblNames.Add((string)row["TABLE_NAME"]); // 读取sheet名                 }             }

//*********************************************************             // 初始化适配器             da = new OleDbDataAdapter();             // 准备数据,导入DataSet             DataSet ds = new DataSet();             string sql_F = "SELECT * FROM [{0}]";             string sheetName = "学生违纪记录信息$";             foreach (string tblName in tblNames)             {                 if (tblNames.Count > 1 && !tblName.StartsWith(sheetName))                 {                     continue;                 }                 da.SelectCommand = new OleDbCommand(String.Format(sql_F, tblName), conn);                 try                 {                     da.Fill(ds, tblName);                 }                 catch                 {                     // 关闭连接                     if (conn.State == ConnectionState.Open)                     {                         conn.Close();                     }                     throw;                 }             }

// 关闭连接             if (conn.State == ConnectionState.Open)             {                 conn.Close();             }

return ds;         }         #endregion         /// <summary>         /// 用户事件 写入导入数据         /// </summary>         /// <param name="sender"></param>         /// <param name="e"></param>         protected void btnImpRight_Click(object sender, EventArgs e)         {             InputExcelDataToDB();         }

protected void btnCancel_Click(object sender, EventArgs e)         {             excelData.Clear();             ShowHandel();         }

protected void btnBack_Click(object sender, EventArgs e)         {             if (string.IsNullOrEmpty(backurl))             {                 Response.Redirect("内容显示页.aspx");             }             else             {                 Response.Redirect(DESEncrypt.Decrypt(backurl));             }         }

PS:导入的模版要和strTempletTitle1 中内容个数相同,且内容类型相同

OA项目之导入的更多相关文章

  1. 基于SSH2的OA项目1.0_20161206_需求分析与框架搭建

    1. SSH项目 OA项目,办公自动化,将公司的数据,文档,流程实现在系统中的管理. 降低人员交流过程中的成本.提高办公的效率. 2 .系统管理 主要实现系统权限的管理,不同的用户登陆后看到菜单项不一 ...

  2. 第一周博客之二---OA项目环境搭建及开发包部署

    OA项目环境搭建 一个项目想要能够在开发人员打包好项目包之后进行测试,就必须进行项目测试环境的搭建,要根据开发工程师的开发环境采用不同的测试环境,以下只是浅谈下Java项目OA(办公自动化平台)的环境 ...

  3. 搭建OA项目环境及卸载指南

    一.项目介绍 1).JDK是什么? 全称:Java Development Kit 中文名:java开发工具包 作用:提供java项目的运行环境         JDK安装 a.jdk.jre 安装 ...

  4. oa项目面试准备

    熟悉项目在ssm框架下的编程流程,了解mysql html spring springmvc mybatis技术.了解过springboot编程. 在上个寒假跟着培训机构用springboot框架编写 ...

  5. 【Java EE 学习 67 上】【OA项目练习】【JBPM工作流的使用】

    OA项目中有极大可能性使用到JBPM框架解决流程控制问题,比如请假流程.报销流程等等. JBPM:JBoss Business Process Management,翻译过来就是业务流程管理.实际上就 ...

  6. [deviceone开发]-企业OA项目开源分享

    一.简介 是一个真实的企业OA项目改造的开源项目,几乎涵盖了所有常用的组件,包括环信实现在线聊天等功能,类似微信的朋友圈功能,自定义的智能搜索等,而且这个是真实的通过Http链接后台web服务,里面很 ...

  7. 01传智_jbpm与OA项目_整体项目架构

    oA项目: 项目结构如下:

  8. 利用CocoaPods,在项目中导入AFNetworking类库

    场景1:利用CocoaPods,在项目中导入AFNetworking类库 AFNetworking类库在GitHub地址是:https://github.com/AFNetworking/AFNetw ...

  9. OA项目实战(二) 开发准备

    上次的博文OA系统实践(一) 概述中,我们已经了解了OA的相关概念.从本次博文开始,我们做一个简单的OA实例. 在OA开发之前,有几个工作们需要提前做.一个是对需求进行分析,另一个是对开发环境进行选择 ...

随机推荐

  1. JsonResult序列化并保存json文件 以及对json文件读取反序列

    项目中我们经常遇到一些经常访问的接口,并且更新及时度不是特别高,那么我们可以利用文件来做一些数据请求的缓存. 这里以微信公众号获取粉丝用户列表为例,我们把微信公众号查到的用户先缓存在文件中,这样在翻页 ...

  2. intellJ实用技巧

    常用语句 在IntelJ中和Eclipse中稍有不同,在Eclipse中,输入main再按Alt+/即可自动补全main函数,但是在IntellJ中则是输入psvm. 在方法体内部有for循环,在In ...

  3. 将框架的底层改掉,改成一个轻量级的ORM

    公司底层的缺点 1.功能有限,只有增删查改 2.不支持异步 3.不支持懒加载 4.不支持泛型 5.不支持Linq 6.性能没做到最好,比如FirsttOrDefault()只能通过查找select * ...

  4. Codeforces Round #228 (Div. 1) B

    B. Fox and Minimal path time limit per test 1 second memory limit per test 256 megabytes input stand ...

  5. Js_Ajax_用户名检测

    输入"root",OK:输入其它,Error ajax.jsp var xhr; function createXhr() { if (window.XMLHttpRequest) ...

  6. C# IO

    在.NET框架中进行的所有IO操作都要用到流(Stream). System.IO命名空间中包含许多IO相关的类,C#文件读写的类几乎都在其中,下面对其进行详细介绍. 主要类列表: 类 说明 Bina ...

  7. IDE神器intellij idea的基本使用

    摘自: http://www.cnblogs.com/newpanderking/p/4887981.html 一.编码快捷键(比较常用的快捷键)该套快捷键选择的是:Mac OS X 10.5+ 1. ...

  8. 5.Firedac错误信息

    主要错误信息属性: 1.EFDDBEngineException Errors -- TFDDBError对象集合. ErrorCount --错误的记录数 Kind -- DBMS的错误集合. Me ...

  9. TIJ读书笔记05-this关键字

    TIJ读书笔记05-this关键字 概述 this的用法 static方法 概述 两个对象同时调用一个方法,那么jvm怎么知道是哪个方法调用的呢. 我们在书写的时候会写成a.fun(1) 或者b.fu ...

  10. 第九十八天请假 PHP TP框架 空操作和命名空间

    访问空方法解决办法->在控制器里面创建 _empty 方法 <?php namespace Home\Controller; use Think\Controller; class Ind ...