C#: Send A Letter with SendLetterAndAddressV2()


  1. Create a new Console Application project and add a web reference.
  2. Copy the entire code below, delete anything written in your application and paste the code there.
  3. Replace the values of the Const lines with your details:
    • Replace MyUsername and MyPassword with your PostalMethods user details.
    • Replace MyDescription with your own text to help you identify this letter in your activity log (optional).
    • Replace MyFileExtension with the extension of the document you are using for this test.
    • Replace MyPathToFile with a path to your test PDF file. Remember, method SendLetterAndAdressV2 will add the recipient's address so it would show through the envelope window. You can use one of our Sample Letter Documents.
    • MyWorkMode determines if your letter will be sent as Production, Development or will use your user's default Work Mode setting. Read more about Production and Development Work Modes.
    • Use the existing postal recipient or replace with another valid postal address. Leave an empty string ("") where no value is needed.
  4. Start your application. It will start, encode your document as Base64 and send a letter to the PostalMethods SendLetterAndAddressV2 Web Service method. If the response is a positive number, you will be able to see your letter in the PostalMethods Control Panel.
    If the response is negative number, check the Web Service Status Codes section.

That's it - you have successfully sent a letter to PostalMethods. Congratulations.

using System;
using System.IO;
namespace ConsoleApplication1
class Module1
        public static void Main()
            const string MyUsername = "MyUsername";
            const string MyPassword = "MyPassword";
            const string MyDescription = "Sending a letter using C#";
            const string MyFileExtension = "pdf";
            const string MyPathToFile = "C:\\MyFile.pdf";
            const com.postalmethods.api.WorkMode MyWorkMode = com.postalmethods.api.WorkMode.Default;
            const string MyAttention1 = "George Washington";
            const string MyAttention2 = "";
            const string MyAttention3 = "";
            const string MyCompanyName = "The White House";
            const string MyAddress1 = "1600 Pennsylvania Ave NW";
            const string MyAddress2 = "";
            const string MyCity = "Washington";
            const string MyState = "DC";
            const string MyPostalCode = "20500";
            const string MyCountry = "United States of America";
            com.postalmethods.api.PostalWSSimple objPM = new com.postalmethods.api.PostalWSSimple();
            long lngResult = 0;
            // Read your binary document. In this example: C:\MyFile.pdf
            FileStream objFR = default(FileStream);
            objFR = new FileStream(MyPathToFile, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
            byte[] B = new byte[objFR.Length];
            objFR.Read(B, 0, B.Length);
            objFR = null;
            // Invoke the SendLetter method
            lngResult = objPM.SendLetterAndAddressV2(MyUsername, MyPassword, MyDescription, MyFileExtension, B, MyWorkMode, MyAttention1, MyAttention2, MyAttention3, MyCompanyName,
            MyAddress1, MyAddress2, MyCity, MyState, MyPostalCode, MyCountry);
            // Check response status
            if (lngResult > 0)
                // A positive value means the message was successfully queued for processing.
                // The PostalMethods Letter ID is returned.
                Console.WriteLine("LetterID is: " + lngResult);
                // A negative value means an error occurred.
                // See the PostalMethods Status Codes: http://www.postalmethods.com/statuscodes#webservice.
                Console.WriteLine("Error is:" + lngResult);
            // In debug mode, the following lines prevent your console application from closing automatically upon termination
            Console.WriteLine("Hit ENTER to terminate application");