LEADTOOLS Support
Document
Document SDK Examples
HOW TO: Pass Custom Headers When Using the JavaScript DocumentViewer
Groups: Registered, Tech Support, Administrators
Posts: 199
Was thanked: 28 time(s) in 28 post(s)
If you're using the DocumentViewer within your company's application, you may wish to add HTTP authorization for downloading internal documents. Below are the few steps you'll need to get started.
Step 1: Provide the header within the clientOur JavaScript SDK allows the developer to customize the requests made to the Documents Service in any way they'd like. You'll simply need to hook into the
DocumentFactory.prepareAjax event. Below are the code snippets from the full sample project, which showcases how to add the basic authorization header:
Code:
lt.Document.DocumentFactory.prepareAjax.add(prepareAjaxCallback);
function prepareAjaxCallback(sender, args) {
if (args.sourceClass.toLowerCase() != "documentfactory" ||
args.sourceMethod.toLowerCase() != "loadfromuri")
return;
if (!args.settings.headers)
args.settings.headers = {};
var myUsername = "username";
var myPassword = "password";
args.settings.headers["Authorization"] = "Basic " + btoa(myUsername + ":" + myPassword);
}
Note: A request made by the DocumentViewer for loading an image does not fire this event by default. To fire the prepareAjax event for requests made to the service, simply set the
DocumentViewer.useAjaxImageLoading property to true.
Below is a download link for the complete client-side demo for this:
Step 2: Pass-through the header within the Documents ServiceBy default, our Documents Service uses a blank
WebClient for the LoadFromUri requests. However, you can provide a custom one by modifying the
LoadDocumentOptions object used within the FactoryController.cs file:
Project Location: LEADTOOLS 20\Examples\JS\Documents\DocumentViewer\Services\DocumentsService
File Location: Controllers\FactoryController.cs
Line Number: 101 - 105
Code:var loadOptions = new LoadDocumentOptions();
loadOptions.Cache = cache;
loadOptions.UseCache = cache != null;
loadOptions.CachePolicy = ServiceHelper.CreatePolicy();
loadOptions.WebClient = new WebClient();
string[] passthroughHeaders = new string[] { "Authorization" };
foreach (string header in passthroughHeaders)
if (Request.Headers.Contains(header))
if (Request.Headers.TryGetValues(header, out IEnumerable<string> values))
foreach (string value in values)
loadOptions.WebClient.Headers.Add(header, value);
else
loadOptions.WebClient.Headers.Add(header);
As you can see from the
passthroughHeaders variable in the snippet above, this can be easily extended to pass any header you'd like.
Optional step 3: Testing the authorization headerBy default, this authorization header is not required. Below is the modification I made to the Documents Service for testing purposes.
Project Location: LEADTOOLS 20\Examples\JS\Documents\DocumentViewer\Services\DocumentsService
File Location: Controllers\TestController.cs
Line Number: 28
Code:
[HttpGet]
public HttpResponseMessage AuthorizedImage()
{
string expectedUsername = "username";
string expectedPassword = "password";
HttpResponseMessage response = new HttpResponseMessage
{
Content = new StringContent("Unknown error"),
StatusCode = HttpStatusCode.InternalServerError
};
try
{
var authHeader = Request.Headers.Authorization;
if (authHeader == null)
throw new NullReferenceException("No authorization header present");
if (!authHeader.Scheme.Equals("basic", StringComparison.CurrentCultureIgnoreCase))
throw new ArgumentException("Not using basic authorization");
string decoded = System.Text.Encoding.Default.GetString(
Convert.FromBase64String(authHeader.Parameter)
);
var match = new System.Text.RegularExpressions.Regex("^([^:]*):(.*)$").Match(decoded);
if (match == null || !match.Success)
throw new ArgumentException("Parameter not formatted properly");
if (!match.Groups[1].Value.Equals(expectedUsername))
throw new ArgumentException("Invalid username");
if (!match.Groups[2].Value.Equals(expectedPassword))
throw new ArgumentException("Invalid password");
}
catch (Exception ex)
{
response.Content = new StringContent(
$"Authorization header not configured properly: {ex.Message}"
);
response.StatusCode = HttpStatusCode.Unauthorized;
return response;
}
response.StatusCode = HttpStatusCode.OK;
response.Content = new ByteArrayContent(
System.IO.File.ReadAllBytes(@"C:\Users\Public\Documents\LEADTOOLS Images\cannon.jpg")
);
return response;
}
Anthony Northrup
Developer Support Engineer
LEAD Technologies, Inc.
data:image/s3,"s3://crabby-images/25566/25566c0afcb32a4f65602e767c98122bcbff3a76" alt="LEAD Logo LEAD Logo"
LEADTOOLS Support
Document
Document SDK Examples
HOW TO: Pass Custom Headers When Using the JavaScript DocumentViewer
You cannot post new topics in this forum.
You cannot reply to topics in this forum.
You cannot delete your posts in this forum.
You cannot edit your posts in this forum.
You cannot create polls in this forum.
You cannot vote in polls in this forum.