2016-08-30 5 views
0

Я пытаюсь развернуть свой сайт через Filezilla. Я создал базу данных в SQL Server 2012 и подключил свою визуальную студию к серверу sql. Когда я запускаю его на локальном сервере, он отлично работает, я могу легко войти и выйти, но когда я его развертываю в Интернете, он показывает эту ошибку на линии con.open(). Помоги пожалуйста.Не удалось найти сообщение об ошибке сети

Описание: Необработанное исключение произошло во время выполнения текущего веб-запроса. Просмотрите трассировку стека для получения дополнительной информации об ошибке и ее возникновении в коде.

Сведения об исключении: System.ComponentModel.Win32Exception: Сеть Путь не найден.

public partial class signinregistration : System.Web.UI.Page 
{ 

    protected void Page_Load(object sender, EventArgs e) 
    { 

    } 

    protected void Button1_Click1(object sender, EventArgs e) 
    { 
     SqlConnection con = new SqlConnection(@"Data Source=ISL-4;Initial Catalog=Cruisedb;Integrated Security=True"); 
     con.Open(); 
     DataTable dt = new DataTable(); 
     SqlDataAdapter sda = new SqlDataAdapter("SELECT * FROM [Login] WHERE Email = @email AND Password = @password", con); 
     using (con) 
     { 
      sda.SelectCommand.Parameters.AddWithValue("@email", this.textboxemail.Text); 
      sda.SelectCommand.Parameters.AddWithValue("@password", this.textboxpassword.Text); 

      sda.Fill(dt); 

      if (dt.Rows.Count == 0) 
      { 
       textboxemail.Text = ""; 
       textboxpassword.Text = ""; 
       Label3.Visible = true; 

       return; 
      } 

      string txt = textboxemail.Text; 
      Session["Email"] = txt; 
      Response.Redirect("index.aspx"); 
     } 
    } 
} 

Источник файла: линия 27..line 27 con.open().

Трассировка стека:

[Win32Exception (0x80004005): The network path was not found] 

[SqlException (0x80131904): A network-related or instance-specific error occurred while establishing a connection to SQL Server. The server was not found or was not accessible. Verify that the instance name is correct and that SQL Server is configured to allow remote connections. (provider: Named Pipes Provider, error: 40 - Could not open a connection to SQL Server)] 
System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction) 
+5341995 
System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj, Boolean callerHasConnectionLock, Boolean asyncClose) +546  
System.Data.SqlClient.TdsParser.Connect(ServerInfo serverInfo, SqlInternalConnectionTds connHandler, Boolean ignoreSniOpenTimeout, Int64 timerExpire, Boolean encrypt, Boolean trustServerCert, Boolean integratedSecurity, Boolean withFailover) +5353703  
System.Data.SqlClient.SqlInternalConnectionTds.AttemptOneLogin(ServerInfo serverInfo, String newPassword, SecureString newSecurePassword, Boolean ignoreSniOpenTimeout, TimeoutTimer timeout, Boolean withFailover) +145  
System.Data.SqlClient.SqlInternalConnectionTds.LoginNoFailover(ServerInfo serverInfo, String newPassword, SecureString newSecurePassword, Boolean redirectedUserInstance, SqlConnectionString connectionOptions, SqlCredential credential, TimeoutTimer timeout) +892 
System.Data.SqlClient.SqlInternalConnectionTds.OpenLoginEnlist(TimeoutTimer timeout, SqlConnectionString connectionOptions, SqlCredential credential, String newPassword, SecureString newSecurePassword, Boolean redirectedUserInstance) +311 
System.Data.SqlClient.SqlInternalConnectionTds..ctor(DbConnectionPoolIdentity identity, SqlConnectionString connectionOptions, SqlCredential credential, Object providerInfo, String newPassword, SecureString newSecurePassword, Boolean redirectedUserInstance, SqlConnectionString userConnectionOptions, SessionData reconnectSessionData) +646  
System.Data.SqlClient.SqlConnectionFactory.CreateConnection(DbConnectionOptions options, DbConnectionPoolKey poolKey, Object poolGroupProviderInfo, DbConnectionPool pool, DbConnection owningConnection, DbConnectionOptions userOptions) +278 
System.Data.ProviderBase.DbConnectionFactory.CreatePooledConnection(DbConnectionPool pool, DbConnection owningObject, DbConnectionOptions options, DbConnectionPoolKey poolKey, DbConnectionOptions userOptions) +38 System.Data.ProviderBase.DbConnectionPool.CreateObject(DbConnection owningObject, DbConnectionOptions userOptions, DbConnectionInternal oldConnection) +732  
System.Data.ProviderBase.DbConnectionPool.UserCreateRequest(DbConnection owningObject, DbConnectionOptions userOptions, DbConnectionInternal oldConnection) +85 
System.Data.ProviderBase.DbConnectionPool.TryGetConnection(DbConnection owningObject, UInt32 waitForMultipleObjectsTimeout, Boolean allowCreate, Boolean onlyOneCheckConnection, DbConnectionOptions userOptions, DbConnectionInternal& connection) +1057  
System.Data.ProviderBase.DbConnectionPool.TryGetConnection(DbConnection owningObject, TaskCompletionSource`1 retry, DbConnectionOptions userOptions, DbConnectionInternal& connection) +78 
System.Data.ProviderBase.DbConnectionFactory.TryGetConnection(DbConnection owningConnection, TaskCompletionSource`1 retry, DbConnectionOptions userOptions, DbConnectionInternal oldConnection, DbConnectionInternal& connection) +196 
System.Data.ProviderBase.DbConnectionInternal.TryOpenConnectionInternal(DbConnection outerConnection, DbConnectionFactory connectionFactory, TaskCompletionSource`1 retry, DbConnectionOptions userOptions) +146 
System.Data.ProviderBase.DbConnectionClosed.TryOpenConnection(DbConnection outerConnection, DbConnectionFactory connectionFactory, TaskCompletionSource`1 retry, DbConnectionOptions userOptions) +16 
System.Data.SqlClient.SqlConnection.TryOpenInner(TaskCompletionSource`1 retry) +94 
System.Data.SqlClient.SqlConnection.TryOpen(TaskCompletionSource`1 retry) +110 
System.Data.SqlClient.SqlConnection.Open() +96  
signinregistration.Button1_Click1(Object sender, EventArgs e) in \\smb-whst-www02\whst_www02$\ff8b1b\user\fareshoppers.co.uk\web\signinregistration.aspx.cs:27 System.Web.UI.WebControls.Button.OnClick(EventArgs e) +9628462 
System.Web.UI.WebControls.Button.RaisePostBackEvent(String eventArgument) +103 
System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) +10 
System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) +13 
System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData) +35 
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +1724 
@MachineLearning 
<?xml version="1.0"?> 
    <configuration> 
     <connectionStrings> 
      <add name="ConnectionString" connectionString="Data Source=ISL-4;Initial Catalog=Cruisedb;Integrated Security=True" providerName="System.Data.SqlClient"/> 
     </connectionStrings> 
     <system.web> 
      <compilation debug="true" targetFramework="4.0"> 
      <assemblies> 
       <add assembly="System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=B77A5C561934E089"/> 
      </assemblies> 
    </compilation> 
    <customErrors mode="Off"/> 
</system.web> 
</configuration> 
+0

Я вижу, что вы используете интегрированную систему безопасности для входа в систему. Где находится база данных? Где вы размещаете сайт? –

+0

Возможно, источник данных неправильно настроен на веб-сервере? Pls показать это ... –

+0

Я создал базу данных на сервере sql и получил доступ к ней в visual studio .. развертывание в Интернете –

ответ

0

При развертывании вашего сайта с помощью FileZilla, она копирует все файлы веб-приложений в папку FTP, но база данных не копируется, как это не существует в пути вашего веб-проекта. Вы найдете файлы базы данных (.mdf, .LDF и т.д.) в папке как

C:\Program Files (x86)\Microsoft SQL Server\MSSQL.1\MSSQL\Data

Но все-таки вы не можете копировать файлы базы данных на сервер и использовать их, как файлы базы данных обслуживаются SQL Server, поэтому SQL Server на вашем сервере (хосте) должен быть проинформирован о базе данных.

Первое требование для этого заключается в том, что ваш хостинг-провайдер предоставит вам базы данных MS SQL. Если ваш текущий провайдер не предоставляет, вы должны искать отдельного поставщика, который может предоставить вам только базу данных MS SQL или разместить базу данных MS SQL (вы определяете финансовые показатели этих опций)

Когда ваш хостинг-провайдер предоставляет вы базы данных MS SQL, вам нужно войти в панель управления хостинга и перейти к опции MS SQL (что бы вы ни называли в панели управления вашего хостинг-провайдера). Там вы можете получить возможность прикреплять существующие файлы базы данных или создавать новую базу данных и запускать запросы.

Если вы можете присоединить базу данных

  1. Скопируйте МДФ и LDF (и другие файлы, если таковые имеются) вашей базы данных на сервер и прикрепить их с помощью панели управления хостингом (может потребоваться остановки SQL Server сервис, чтобы сделать это)

Если поставщик услуг хостинга требует, чтобы создать новую базу данных

  1. Затем создайте новую базу данных там
  2. С локального сервера (на вашей машине) щелкните правой кнопкой мыши на базе данных, выберите Задачи затем Сгенерировать скрипт для создания сценария текущей базы данных (в Пойди разберись варианты на SO или Google)
  3. Скопируйте этот сценарий в окне запроса вашей панели управления хостингом (там, где эта опция доступна)
  4. выполнить запрос

Для обоих вышеизложенных случаев вам, возможно, потребуется изменить строку подключения (в зависимости от имени базы данных, имени пользователя, которое вы создали, и его пароля)

Надеюсь, что это поможет.

+0

Это потрясающе. Я создал базу данных на сервере хостинга. Но это не импорт моего файла mdf или ldf, а импорт CSV-файла. Мой хостинг-сервер регистрируется на другой машине, я отправил свою сгенерированную сценарий к этому махине и добавить новый запрос, но он не работает .. что делать сейчас? –

Смежные вопросы