Службы отчетов 2005 об ошибках выполнения

Я пытаюсь перенести программное обеспечение на новый сервер и не могу передать эту ошибку:Ошибка сработала на сервере

Код, который вызывает эту ошибку, выглядит следующим образом, но я не думаю, что это проблема. Я почти уверен, что это связано с чем-то, что было неправильно настроено на сервере, так как единственное, что изменилось, это информация о сервере? Любая идея о том, как исправить эту ошибку?

namespace ReportGenerator
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                DataClasses1DataContext classes1DataContext = new DataClasses1DataContext();
                foreach (reportsSent entity in classes1DataContext.reportsSents)
                {
                    new Form1.MyReportRenderer().RenderTest(entity.CaseNumberKey);
                    classes1DataContext.reportsSents.DeleteOnSubmit(entity);
                }
                classes1DataContext.SubmitChanges();
            }
            catch (Exception ex)
            {
                int num = (int)MessageBox.Show(((object)ex.StackTrace).ToString());
            }
        }



        public class MyReportRenderer
        {
            private rs2005.ReportingService2005 rs;
            private rs2005Execution.ReportExecutionService rsExec;

            public void RenderTest(String matchedCaseNumber)
            {
                string HistoryID = (string)null;
                string DeviceInfo = (string)null;
                string MimeType = string.Empty;
                string Encoding = string.Empty;
                string Extension = string.Empty;
                ReportGenerator.rs2005Execution.Warning[] Warnings = (ReportGenerator.rs2005Execution.Warning[])null;
                string[] StreamIds = (string[])null;
                this.rs = new ReportingService2005();
                this.rsExec = new ReportExecutionService();
                this.rs.Credentials = CredentialCache.DefaultCredentials;
                this.rsExec.Credentials = CredentialCache.DefaultCredentials;
                this.rs.Url = "http://www.aalacquest.com/ReportServer/ReportService2005.asmx";
                this.rsExec.Url = "http://www.aalacquest.com/ReportServer/ReportExecution2005.asmx";


                try
                {
                    // Load the selected report.
                    this.rsExec.LoadReport("/LawDept/LawDeptTIC", HistoryID);

                    // Set the parameters for the report needed.

                    rs2005Execution.ParameterValue[] parameters = new rs2005Execution.ParameterValue[1];
                    parameters[0] = new rs2005Execution.ParameterValue();
                    parameters[0].Name = "CaseNumberKey";
                    parameters[0].Value = matchedCaseNumber;

                    rsExec.SetExecutionParameters(parameters, "en-us");

                    // get pdf of report 
                    byte[] buffer = this.rsExec.Render("PDF", DeviceInfo, out Extension, out MimeType, out Encoding, out Warnings, out StreamIds);
                    DataClasses1DataContext classes1DataContext = new DataClasses1DataContext();
                    Queryable.SingleOrDefault<string>(Queryable.Select<vw_ProductClientInfo, string>(Queryable.Where<vw_ProductClientInfo>((IQueryable<vw_ProductClientInfo>)classes1DataContext.GetTable<vw_ProductClientInfo>(), (Expression<Func<vw_ProductClientInfo, bool>>)(c => c.CaseNumberKey == matchedCaseNumber)), (Expression<Func<vw_ProductClientInfo, string>>)(c => c.Description)));
                    string str1 = Queryable.SingleOrDefault<string>(Queryable.Select<vw_ProductClientInfo, string>(Queryable.Where<vw_ProductClientInfo>((IQueryable<vw_ProductClientInfo>)classes1DataContext.GetTable<vw_ProductClientInfo>(), (Expression<Func<vw_ProductClientInfo, bool>>)(c => c.CaseNumberKey == matchedCaseNumber)), (Expression<Func<vw_ProductClientInfo, string>>)(c => c.Summary)));
                    string str2 = Queryable.SingleOrDefault<string>(Queryable.Select<vw_ProductClientInfo, string>(Queryable.Where<vw_ProductClientInfo>((IQueryable<vw_ProductClientInfo>)classes1DataContext.GetTable<vw_ProductClientInfo>(), (Expression<Func<vw_ProductClientInfo, bool>>)(c => c.CaseNumberKey == matchedCaseNumber)), (Expression<Func<vw_ProductClientInfo, string>>)(c => string.Format("{0:C}", (object)c.Total))));
                    string str3 = Queryable.SingleOrDefault<string>(Queryable.Select<vw_ProductClientInfo, string>(Queryable.Where<vw_ProductClientInfo>((IQueryable<vw_ProductClientInfo>)classes1DataContext.GetTable<vw_ProductClientInfo>(), (Expression<Func<vw_ProductClientInfo, bool>>)(c => c.CaseNumberKey == matchedCaseNumber)), (Expression<Func<vw_ProductClientInfo, string>>)(c => c.BRTNumber)));
                    MailMessage message = new MailMessage("Reports@aalacquest.com", Queryable.SingleOrDefault<string>(Queryable.Select<vw_ProductClientInfo, string>(Queryable.Where<vw_ProductClientInfo>((IQueryable<vw_ProductClientInfo>)classes1DataContext.GetTable<vw_ProductClientInfo>(), (Expression<Func<vw_ProductClientInfo, bool>>)(c => c.CaseNumberKey == matchedCaseNumber)), (Expression<Func<vw_ProductClientInfo, string>>)(c => c.Email))), "Report for Property " + Queryable.SingleOrDefault<string>(Queryable.Select<vw_ProductClientInfo, string>(Queryable.Where<vw_ProductClientInfo>((IQueryable<vw_ProductClientInfo>)classes1DataContext.GetTable<vw_ProductClientInfo>(), (Expression<Func<vw_ProductClientInfo, bool>>)(c => c.CaseNumberKey == matchedCaseNumber)), (Expression<Func<vw_ProductClientInfo, string>>)(c => c.Premises))), "Tax Information Certificate.");
                    MailAddress mailAddress = new MailAddress("reports@aalacquest.com");
                    ((Collection<MailAddress>)message.CC).Add(mailAddress);
                    SmtpClient smtpClient = new SmtpClient("localhost");
                    message.Attachments.Add(new Attachment((Stream)new MemoryStream(buffer), string.Format("{0}" + str3 + ".pdf", (object)"BRT")));
                    smtpClient.Send(message);
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.ToString());
                }
            }
        }


    }
}

1 ответ

Проблема заключалась в том, что имя машины было изменено, но изменение фактически никогда не вступало в силу, поэтому логин был неверным. Имя компьютера ACME, которое было изменено с WIN-2MUFL6FJSPL, не работало правильно, и поэтому при попытке входа из приложения произошел сбой.

Другие вопросы по тегам