From 4f257c60f036db00257b4bad82f230aef5f43780 Mon Sep 17 00:00:00 2001 From: dbuechel Date: Fri, 15 Mar 2019 15:55:34 +0100 Subject: [PATCH] SEBWIN-106: Ensured invalid URIs entered by the user are not loaded by the browser. --- .../BrowserApplicationInstance.cs | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/SafeExamBrowser.Browser/BrowserApplicationInstance.cs b/SafeExamBrowser.Browser/BrowserApplicationInstance.cs index 510a54d9..f14f20a3 100644 --- a/SafeExamBrowser.Browser/BrowserApplicationInstance.cs +++ b/SafeExamBrowser.Browser/BrowserApplicationInstance.cs @@ -6,6 +6,7 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ +using System; using SafeExamBrowser.Browser.Events; using SafeExamBrowser.Browser.Handlers; using SafeExamBrowser.Contracts.Applications; @@ -194,8 +195,18 @@ namespace SafeExamBrowser.Browser private void Window_AddressChanged(string address) { - logger.Debug($"The user requested to navigate to '{address}'."); - control.NavigateTo(address); + var isValid = Uri.TryCreate(address, UriKind.Absolute, out _) || Uri.TryCreate($"https://{address}", UriKind.Absolute, out _); + + if (isValid) + { + logger.Debug($"The user requested to navigate to '{address}', the URI is valid."); + control.NavigateTo(address); + } + else + { + logger.Debug($"The user requested to navigate to '{address}', but the URI is not valid."); + window.UpdateAddress(string.Empty); + } } private void Window_BackwardNavigationRequested()