0

私はSQLデータベースからxmlファイルを生成するこのコードを持っています:

    int counter;
    int counter2;
private void GenerovaniVse()
{
  SqlConnection con = new SqlConnection("Data Source=****");
  string strSQL = "select w.KOD_....";                
  SqlDataAdapter dt = new SqlDataAdapter(strSQL, con);
  DataSet ds = new DataSet("ITEMS");
  dt.Fill(ds, "ITEM");
  FileStream strFileName = File.Create(@"C:\\Users\\L\\Desktop\\" + (counter++) + ".xml");
  XmlWriterSettings settings = new XmlWriterSettings();
  settings.Encoding = Encoding.Unicode;

  using (XmlWriter xmlWriter = XmlWriter.Create(strFileName, settings))
    {
      ds.WriteXml(xmlWriter);
      xmlWriter.Close();
    }
}

そして、このファイルを ftp にアップロードするためのこのコード:

private void Upload()
 {
   FileInfo f = new FileInfo("C:\\Users\\L\\Desktop\\" + (counter2) + ".xml");
   long original_vel = f.Length; 
   FtpWebRequest request = (FtpWebRequest)WebRequest.Create(*****);
   request.Method = WebRequestMethods.Ftp.GetFileSize;
   request.Method = WebRequestMethods.Ftp.UploadFile;
   request.Credentials = new NetworkCredential("***", "***");

   StreamReader sourceStream = new StreamReader(??????);
   byte[] fileContents = Encoding.UTF8.GetBytes(sourceStream.ReadToEnd());
   sourceStream.Close();
   request.ContentLength = fileContents.Length;
   long ftp_vel = request.ContentLength; //velikost souboru na ftp      
   Stream requestStream = request.GetRequestStream();
   requestStream.Write(fileContents, 0, fileContents.Length);
   requestStream.Close();
   FtpWebResponse response = (FtpWebResponse)request.GetResponse();
                counter2++;
                response.Close();                         
}

問題があった: strmfile.Close(); しかし、xml を ftp にコピーすると、ftp 上のファイルは元の xml よりも小さくなります...そして元の xml には Unicode があり、ftp ファイルにはコードがありません...

4

1 に答える 1

1

strFileName関数内での書き込みが完了したら、おそらく を閉じる必要がありGenerovaniVseます。

于 2013-08-23T09:45:08.353 に答える