Modify rule S5146: Add fix for Blazor (APPSEC-1905) (#4128)
Co-authored-by: Thomas Serre <118730793+thomas-serre-sonarsource@users.noreply.github.com>
This commit is contained in:
parent
22b1c621ad
commit
58f256f85c
50
rules/S5146/csharp/how-to-fix-it/blazor.adoc
Normal file
50
rules/S5146/csharp/how-to-fix-it/blazor.adoc
Normal file
@ -0,0 +1,50 @@
|
||||
== How to fix it in Blazor
|
||||
|
||||
=== Code examples
|
||||
|
||||
include::../../common/fix/code-rationale.adoc[]
|
||||
|
||||
==== Noncompliant code example
|
||||
|
||||
[source,csharp,diff-id=2,diff-type=noncompliant]
|
||||
----
|
||||
@page "/"
|
||||
@inject NavigationManager Navigation
|
||||
|
||||
@code {
|
||||
[SupplyParameterFromQuery]
|
||||
private String url {get ; set; }
|
||||
|
||||
protected override void OnInitialized() {
|
||||
Navigation.NavigateTo(url);
|
||||
}
|
||||
}
|
||||
----
|
||||
|
||||
==== Compliant solution
|
||||
|
||||
[source,csharp,diff-id=2,diff-type=compliant]
|
||||
----
|
||||
@page "/"
|
||||
@inject NavigationManager Navigation
|
||||
|
||||
@code {
|
||||
[SupplyParameterFromQuery]
|
||||
private String url {get ; set; }
|
||||
|
||||
private readonly string[] allowedUrls = { "/", "/login", "/logout" };
|
||||
|
||||
protected override void OnInitialized() {
|
||||
if (allowedUrls.Contains(url))
|
||||
{
|
||||
Navigation.NavigateTo(url);
|
||||
}
|
||||
}
|
||||
}
|
||||
----
|
||||
|
||||
include::../../common/fix/how-does-this-work.adoc[]
|
||||
|
||||
=== Pitfalls
|
||||
|
||||
include::../../common/pitfalls/starts-with.adoc[]
|
@ -8,6 +8,8 @@ include::../impact.adoc[]
|
||||
|
||||
include::how-to-fix-it/dotnet.adoc[]
|
||||
|
||||
include::how-to-fix-it/blazor.adoc[]
|
||||
|
||||
== Resources
|
||||
|
||||
include::../common/resources/standards.adoc[]
|
||||
|
Loading…
x
Reference in New Issue
Block a user