1

このようにftpフォルダからファイルを取得しています。

request = (FtpWebRequest)FtpWebRequest.Create(new Uri("ftp://ipaddress/foldername"));
                request.UseBinary = true;
                request.Credentials = new NetworkCredential("username", "password");
                request.Method = WebRequestMethods.Ftp.ListDirectory;
                request.UseBinary = true;

                WebResponse response = request.GetResponse();

                StreamReader reader = new StreamReader(response.GetResponseStream());

                    string line = reader.ReadLine();
                    while (line != null)
                    {
                        result.Append(line);
                        result.Append("\n");
                        line = reader.ReadLine();
                    }
                    // to remove the trailing '\n'
                    result.Remove(result.ToString().LastIndexOf('\n'), 1);
                    reader.Close();
                    response.Close();

                    string[] results = result.ToString().Split('\n');

                    foreach (string filename in results)

                    {
 connetionString = "Data Source=testservername;Initial Catalog=testdb;User ID=sa;Password=sa";
                   connection = new SqlConnection(connetionString);


                   FtpWebRequest request1 = (FtpWebRequest)FtpWebRequest.Create(new Uri("ftp://servername/"  + filename));
                   request1.Method = WebRequestMethods.Ftp.DownloadFile;
                   request1.UseBinary = true;
                   request1.Credentials = new NetworkCredential("username", "password");
                   responses = (FtpWebResponse)request1.GetResponse();
                   StreamReader reader1 = new StreamReader(responses.GetResponseStream());

                   string xml = reader1.ReadToEnd();



                   ds.ReadXml(new XmlTextReader(new StringReader(xml)));

                   int i = 0;
                   connection.Open();
                   for (i = 0; i <= ds.Tables[1].Rows.Count - 1 ; i++)
                    {

                   sql = "insert into Details values('" + ds.Tables[1].Rows[i].ItemArray[0]            
                                                       + "')";

                        command = new SqlCommand(sql, connection);
                        adpter.InsertCommand = command;
                        adpter.InsertCommand.ExecuteNonQuery();

                    }


                        FtpWebRequest requestDelete = (FtpWebRequest)WebRequest.Create("ftp://sername/" + filename);
                        requestDelete.Method = WebRequestMethods.Ftp.DeleteFile;
                        requestDelete.UseBinary = true;
                        requestDelete.Credentials = new NetworkCredential("username", "password");
                        responseDelete = (FtpWebResponse)requestDelete.GetResponse();
                        try
                        {
                            string res = responseDelete.StatusDescription;
                            if (res == "250 Delete operation successful.")
                            {
                                MessageBox.Show("Done......");

                            }
                        }
                        catch (Exception ex)
                        {
                            System.Windows.Forms.MessageBox.Show(ex.Message);

                        }
                    }

                    responseDelete.Close();
                    connection.Close();
                    responses.Close();



            }
            catch (Exception ex)
            {
               System.Windows.Forms.MessageBox.Show(ex.Message);

            }
        }

こんにちは、ftp フォルダーからファイルを取得し、その xml ファイルを 1 つずつ読み取り、データベースにレコードとして保存する必要があります。その後、そのファイルの ftp フォルダーを削除する必要があります。

テストのために2つのファイルをftpフォルダーに配置した場合、最初のファイルは正常に読み取りますが、2番目のファイルを読み取ると、次の行の「オブジェクト参照がオブジェクトのインスタンスに設定されていません」のようなエラーが発生します。

ds.ReadXml(new XmlTextReader(new StringReader(xml)));

私のコードに問題があることを教えてください。私はftpリクエストを複数回送信していますが、それは良いことですか、それとも上記のコード行を見てそれを行う方法を提案してくれますか?

4

0 に答える 0