Intégrer Reporting Services à l’aide de l’accès URL - Application Windows

Même si l'accès URL à un serveur de rapports est optimisé pour un environnement Web, vous pouvez également utiliser l'accès URL pour incorporer des rapports Reporting Services dans une application Microsoft Windows. Toutefois, l'accès URL qui nécessite des Windows Forms requiert toujours l'utilisation de la technologie du navigateur Web. Vous pouvez utiliser les scénarios d'intégration suivants avec l'accès URL et les Windows Forms :

  • Afficher un rapport dans une application Windows Form en démarrant un navigateur Web par programme.

  • Utiliser le contrôle WebBrowser sur un Windows Form pour afficher un rapport.

Démarrer Internet Explorer à partir d’un Windows Form

Vous pouvez utiliser la classe Process pour accéder à un processus qui s'exécute sur un ordinateur. La classe Process est une construction Microsoft .NET Framework utile pour démarrer, arrêter, contrôler et surveiller des applications. Pour consulter un rapport spécifique dans votre base de données du serveur de rapports, vous pouvez démarrer le processus IExplore, en passant l’URL au rapport. L’exemple de code suivant peut être utilisé pour démarrer Microsoft Internet Explorer et passer une URL de rapport spécifique lorsque l’utilisateur sélectionne un bouton sur un Windows Form.

Private Sub viewReportButton_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles viewReportButton.Click  
   ' Build the URL access string based on values supplied by a user  
   Dim url As String = serverUrlTextBox.Text + "?" & reportPathTextBox.Text & _  
   "&rs:Command=Render" & "&rs:Format=HTML4.0"  
  
   ' If the user does not select the toolbar check box,  
   ' turn the toolbar off in the HTML Viewer  
   If toolbarCheckBox.Checked = False Then  
      url += "&rc:Toolbar=False"  
   End If  
   ' load report in the Web browser  
   Try  
      System.Diagnostics.Process.Start("IExplore", url)  
   Catch  
      MessageBox.Show("The system could not start the specified report using Internet Explorer.", _  
      "An error has occurred", MessageBoxButtons.OK, MessageBoxIcon.Error)  
   End Try  
End Sub 'viewReportButton_Click  
// Sample click event for a Button control on a Windows Form  
private void viewReportButton_Click(object sender, System.EventArgs e)  
{  
   // Build the URL access string based on values supplied by a user  
   string url = serverUrlTextBox.Text + "?" + reportPathTextBox.Text +  
      "&rs:Command=Render" + "&rs:Format=HTML4.0";  
  
   // If the user does not check the toolbar check box,  
   // turn the toolbar off in the HTML Viewer  
   if (toolbarCheckBox.Checked == false)  
      url += "&rc:Toolbar=False";  
  
   // load report in the Web browser  
   try  
   {  
      System.Diagnostics.Process.Start("IExplore", url);  
   }  
  
   catch (Exception)  
   {  
      MessageBox.Show(  
         "The system could not open the specified report using Internet Explorer.",   
         "An error has occurred", MessageBoxButtons.OK, MessageBoxIcon.Error);  
   }  
}  

Incorporer un contrôle de navigateur sur un Windows Form

Si vous ne souhaitez pas afficher votre rapport dans un navigateur Web externe, vous pouvez incorporer un navigateur Web de manière transparente dans le cadre de votre Windows Form à l’aide du WebBrowser contrôle.

Pour ajouter le contrôle WebBrowser à votre Windows Form
  1. Créez une application Windows dans Microsoft C# ou Microsoft Visual Basic.

  2. Localisez le contrôle WebBrowser dans la boîte de dialogue Boîte à outils.

    Si la boîte à outils n’est pas visible, vous pouvez y accéder en sélectionnant l’élément de menu Affichage et en sélectionnant Boîte à outils.

  3. Faites glisser le contrôle WebBrowser vers l’aire de conception de votre Windows Form.

    Le contrôle WebBrowser nommé webBrowser1 est ajouté au Formulaire

Dirigez le contrôle WebBrowser vers une URL en appelant sa méthode Navigate. Vous pouvez assigner une chaîne d'accès URL spécifique à votre contrôle WebBrowser au moment de l'exécution comme l'illustre l'exemple suivant.

Dim url As String = "https://localhost/reportserver?/" & _  
                    "AdventureWorks Sample Reports/" & _  
                    "Company Sales&rs:Command=Render"  
WebBrowser1.Navigate(url)  
string url = "https://localhost/reportserver?/" +  
             "AdventureWorks Sample Reports/" +  
             "Company Sales&rs:Command=Render";  
webBrowser1.Navigate(url);  

Intégration de Reporting Services dans des applications
Intégration de Reporting Services à l’aide de l’accès URL
Intégration de Reporting Services à l’aide de SOAP
Intégration de Reporting Services à l’aide des contrôles ReportViewer
Accès URL (SSRS)