用第一种方法,上传服务器后,在一些服务器中,可能会出现以下错误:
必须在web.config中加 <system.web><identity impersonate="false"/></system.web> ,否则出现错误:System.Data.OleDb.OleDbException: 未指定的错误。加了以后,点多几次链接,会出现“用户 'NT AUTHORITY/NETWORK SERVICE' 登录失败”,需要重新上传,然后又出现同样的错误。
所以,如果要上传到服务器的话,就要用到第二种方法。如下:
public Random rd;
rd = new Random(1);
string filename = this.FileUpload1.PostedFile.FileName;
//string filename = this.FileUpload1.PostedFile.FileName;
string type = filename.Substring(filename.LastIndexOf("."));
string z = Server.MapPath("../file/") + Guid.NewGuid().ToString() + type;
this.FileUpload1.PostedFile.SaveAs(z);
SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionString ["IEISConnectionString"].ConnectionString);
SqlCommand cmd = new SqlCommand();
cmd.CommandText = "SELECT * FROM OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel 5.0;HDR=Yes;IMEX=1;DATABASE=" + z + "',sheet1$)";
SqlDataAdapter da = new SqlDataAdapter();
da.SelectCommand = cmd;
cmd.Connection = conn;
conn.Open();
DataSet ds = new DataSet();
da.Fill(ds);
conn.Close();
先上传文件,是因为服务器根据路径找不到文件,所以要先上传到服务器,否则出现错误。
这种方法,在一些服务器中可能会出现如下错误:
已拒绝对 OLE DB 提供程序 'MICROSOFT.JET.OLEDB.4.0' 的特殊访问。必须通过链接服务器来访问此提供程序。
可能要通过用“sa”登录才能解决问题,这时候用回第一种方法,可能问题就解决了。