Search This Blog

Sunday, October 6, 2019

SampleWebService url & Method - Get Dynamically and Add reference programmatic


Download

using System;
using System.CodeDom;
using System.CodeDom.Compiler;
using System.Configuration;
using System.Diagnostics;
using System.IO;
using System.Net;
using System.Reflection;
using System.Security.Permissions;
using System.ServiceModel;
using System.Web.Services;
using System.Web.Services.Description;
using System.Web.Services.Discovery;
using System.Xml;
using System.Xml.Serialization;

namespace SPWebServiceConnect
{
    class Program
    {


        [SecurityPermissionAttribute(SecurityAction.Demand, Unrestricted = true)]

        static void Main()
        {
        
            var asmxurl = ConfigurationManager.AppSettings["ASMXServiceUrl"];
            try
            {
                //  http://secure.smartbearsoftware.com/samples/testcomplete14/webservices/Service.asmx?op=HelloWorld
                object dataHlowrd = WsProxy.CallWebService(asmxurl, "SampleWebService", "HelloWorld", null);
                object curnttimeData = WsProxy.CallWebService(asmxurl, "SampleWebService", "GetCurrentTime", null);
                Console.WriteLine(dataHlowrd);
                Console.WriteLine(curnttimeData);
            }
            catch (Exception ex)
            {
                //  not available at all, for some reason
                Console.Write(string.Format("{0} unavailable: {1}", ex.StackTrace, ex.Message));
            }
            Console.Read();
        }

    }
    internal class WsProxy
    {
        [SecurityPermissionAttribute(SecurityAction.Demand, Unrestricted = true)]
        internal static object CallWebService(string webServiceAsmxUrl, string serviceName, string methodName, object[] args)
        {

            System.Net.WebClient client = new System.Net.WebClient();
            // Connect To the web service

            System.IO.Stream stream = client.OpenRead(webServiceAsmxUrl + "?wsdl");

            // Now read the WSDL file describing a service.

            ServiceDescription description = ServiceDescription.Read(stream);

            ///// LOAD THE DOM /////////

            // Initialize a service description importer.

            ServiceDescriptionImporter importer = new ServiceDescriptionImporter();

            importer.ProtocolName = "Soap12"; // Use SOAP 1.2.

            importer.AddServiceDescription(description, null, null);

            // Generate a proxy client.

            importer.Style = ServiceDescriptionImportStyle.Client;

            // Generate properties to represent primitive values.

            importer.CodeGenerationOptions = System.Xml.Serialization.CodeGenerationOptions.GenerateProperties;

            // Initialize a Code-DOM tree into which we will import the service.

            CodeNamespace nmspace = new CodeNamespace();

            CodeCompileUnit unit1 = new CodeCompileUnit();

            unit1.Namespaces.Add(nmspace);

            // Import the service into the Code-DOM tree. This creates proxy code that uses the service.

            ServiceDescriptionImportWarnings warning = importer.Import(nmspace, unit1);

            if (warning == 0) // If zero then we are good to go
            {

                // Generate the proxy code

                CodeDomProvider provider1 = CodeDomProvider.CreateProvider("CSharp");

                // Compile the assembly proxy with the appropriate references

                string[] assemblyReferences = new string[5] { "System.dll", "System.Web.Services.dll", "System.Web.dll", "System.Xml.dll", "System.Data.dll" };

                CompilerParameters parms = new CompilerParameters(assemblyReferences);

                CompilerResults results = provider1.CompileAssemblyFromDom(parms, unit1);

                // Check For Errors

                if (results.Errors.Count > 0)
                {

                    foreach (CompilerError oops in results.Errors)
                    {

                        System.Diagnostics.Debug.WriteLine("========Compiler error============");

                        System.Diagnostics.Debug.WriteLine(oops.ErrorText);
                    }

                    throw new System.Exception("Compile Error Occured calling webservice. Check Debug ouput window.");
                }
                // Finally, Invoke the web service method

                object wsvcClass = results.CompiledAssembly.CreateInstance(serviceName);

                MethodInfo mi = wsvcClass.GetType().GetMethod(methodName);

                return mi.Invoke(wsvcClass, args);
            }

            else
            {
                return null;
            }
        }
    }
}



No comments:

Post a Comment