This tutorial shows how to convert and redact data using the LEADTOOLS Cloud Services in a C# .NET Core console application.
Overview | |
---|---|
Summary | This tutorial covers how to make ConvertRedact requests and process the results using the LEADTOOLS Cloud Services in a C# .NET Core console application. |
Completion Time | 30 minutes |
Project | Download tutorial project (2 KB) |
Platform | LEADTOOLS Cloud Services API |
IDE | Visual Studio 2019 |
Language | C# .NET Core |
Development License | Download LEADTOOLS |
Try it in another language |
Be sure to review the following sites for information about LEADTOOLS Cloud Services API.
LEADTOOLS Service Plan offerings:
Service Plan | Description |
---|---|
Free Trial | Free Evaluation |
Page Packages | Prepaid Page Packs |
Subscriptions | Prepaid Monthly Processed Pages |
To further explore the offerings, refer to Pricing Information for LEADTOOLS Hosted Cloud Services > Service Plan Terms.
For pricing details, refer to https://www.leadtools.com/sdk/products/hosted-services#pricing > Page Packages and Subscriptions.
To obtain the necessary Application ID and Application Password, refer to Create an Account and Application with the LEADTOOLS Hosted Cloud Services.
In Visual Studio, create a new C# .NET Core Console project, and add the following required NuGet package:
Newtonsoft.Json
With the project created and the package added, coding can begin.
In the Solution Explorer, open Program.cs
. Add the following statements to the using
block at the top.
// Using block at the top
using System;
using System.Text;
using System.Threading.Tasks;
using System.Net;
using System.Net.Http;
using System.Net.Http.Headers;
using System.IO;
using Newtonsoft.Json.Linq;
Add the class level enum FormatsEnum
and a string variable called hostedServicesUrl
, and an async Task called ConvertRedact()
.
This sends a ConvertRedact
request to the LEADTOOLS Cloud Services API, if successful a unique identifier (GUID) will be returned and then a query using this GUID will be made.
private enum FormatsEnum
{
Png = 1,
Jpeg = 2,
Tiff = 3,
Pdf = 4,
Pdfa = 5,
PdfImage = 6,
PdfImageOverText = 7,
PdfaImageOverText = 8,
Docx = 9,
DocxFramed = 10,
Rtf = 11,
RtfFramed = 12,
Txt = 13,
TxtFramed = 14,
}
private string hostedServicesUrl = "https://azure.leadtools.com/api/";
public async Task ConvertRedactFile()
{
var client = InitClient();
//The first page in the file to mark for processing
int firstPage = 1;
//Sending a value of -1 will indicate to the service that all pages in the file should be processed.
int lastPage = -1;
//Enum corresponding to the output format for the file. For the purposes of this script, we will be converting to tif.
int fileFormat = (int)FormatsEnum.Tiff;
var pattern = '(LEAD)';
// If using URL to the file
string fileURL = "https://demo.leadtools.com/images/pdf/leadtools.pdf";
string conversionUrl = string.Format("Conversion/ConvertRedact?firstPage={0}&lastPage={1}&fileurl={2}&format={3}&pattern={4}", firstPage, lastPage, fileURL, fileFormat, pattern);
var result = await client.PostAsync(conversionUrl, null);
/*
//If uploading a file as multi-part content:
HttpContent byteContent = new ByteArrayContent(File.ReadAllBytes(@"path/to/file"));
byteContent.Headers.ContentDisposition = new ContentDispositionHeaderValue("form-data")
{
Name = "attachment",
FileName = "file-name"
};
var formData = new MultipartFormDataContent();
formData.Add(byteContent, "formFieldName");
string conversionUrl = string.Format("Conversion/ConvertRedact?firstPage={0}&lastPage={1}&format={2}&pattern={3}", firstPage, lastPage, fileFormat, pattern);
var result = await client.PostAsync(conversionUrl, formData);
formData.Dispose();
*/
if (result.StatusCode == HttpStatusCode.OK)
{
//Unique ID returned by the services
string id = await result.Content.ReadAsStringAsync();
Console.WriteLine("Unique ID returned by the services: " + id);
await Query(id, client);
}
else
Console.WriteLine("Request failed with the following response: " + result.StatusCode);
}
Next, create an async Task called Task Query(string id, HttpClient client)
that utilizes the GUID provided by the ConvertRedactFile
task.
If successful the response body will contain all the request data in JSON format.
private async Task Query(string id, HttpClient client)
{
string queryUrl = string.Format("Query?id={0}", id.ToString());
HttpResponseMessage result;
string returnedContent;
JObject returnedData;
int fileStatus;
do
{
result = await client.PostAsync(queryUrl, null);
returnedContent = await result.Content.ReadAsStringAsync();
returnedData = JObject.Parse(returnedContent);
fileStatus = (int)returnedData.SelectToken("FileStatus");
//The file is still being processed -- we will sleep the current thread for 5 seconds before trying again.
await Task.Delay(5000);
} while (fileStatus == 100 || fileStatus == 123);
Console.WriteLine("File has finished processing with return code: " + returnedData.SelectToken("FileStatus"));
if ((int)returnedData.SelectToken("FileStatus") != 200)
return;
ParseJson(returnedData.SelectToken("RequestData").ToString());
}
Then, create the function ParseJson(string json)
to process the returned JSON data.
private void ParseJson(string json)
{
JArray requestArray = JArray.Parse(json);
foreach (var requestReturn in requestArray)
{
Console.WriteLine("Service Type: " + requestReturn.SelectToken("ServiceType"));
Console.WriteLine("Returned Data:");
var UrlArray = JArray.Parse(requestReturn.SelectToken("urls").ToString());
foreach (var obj in UrlArray)
{
Console.WriteLine(obj.ToString());
}
}
}
Finally, create the function InitClient()
to create a client connection to request the GUID and JSON data through.
Where it states Replace with Application ID
and Replace with Application Password
be sure to place your Application ID and Password accordingly.
private HttpClient InitClient()
{
string AppId = "Replace with Application ID";
string Password = "Replace with Application Password";
HttpClient client = new HttpClient();
client.BaseAddress = new Uri(hostedServicesUrl);
client.DefaultRequestHeaders.Accept.Clear();
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
string authData = string.Format("{0}:{1}", AppId, Password);
string authHeaderValue = Convert.ToBase64String(Encoding.UTF8.GetBytes(authData));
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", authHeaderValue);
return client;
}
In order to test run this code be sure to add ConvertRedactFile().GetAwaiter().GetResults();
to the static void Main
section.
Run the project by pressing F5, or by selecting Debug -> Start Debugging.
If the steps were followed correctly, the console appears and the application displays the link to the converted and redacted file from the returned JSON data.
This tutorial showed how to convert files with redaction via the LEADTOOLS Cloud Services API.