2020-06-30 14:41:58 +02:00
|
|
|
include::../description.adoc[]
|
|
|
|
|
|
|
|
include::../ask-yourself.adoc[]
|
|
|
|
|
|
|
|
include::../recommended.adoc[]
|
|
|
|
|
|
|
|
== Sensitive Code Example
|
|
|
|
|
|
|
|
----
|
|
|
|
Imports System.Security.Cryptography
|
|
|
|
|
|
|
|
Sub ComputeHash()
|
|
|
|
|
|
|
|
' Review all instantiations of classes that inherit from HashAlgorithm, for example:
|
|
|
|
Dim hashAlgo As HashAlgorithm = HashAlgorithm.Create() ' Sensitive
|
|
|
|
Dim hashAlgo2 As HashAlgorithm = HashAlgorithm.Create("SHA1") ' Sensitive
|
|
|
|
Dim sha As SHA1 = New SHA1CryptoServiceProvider() ' Sensitive
|
|
|
|
Dim md5 As MD5 = New MD5CryptoServiceProvider() ' Sensitive
|
|
|
|
|
|
|
|
' ...
|
|
|
|
End Sub
|
|
|
|
|
|
|
|
Class MyHashAlgorithm
|
|
|
|
Inherits HashAlgorithm ' Sensitive
|
|
|
|
|
|
|
|
' ...
|
|
|
|
End Class
|
|
|
|
----
|
|
|
|
|
|
|
|
== Compliant Solution
|
|
|
|
|
2022-02-04 17:28:24 +01:00
|
|
|
[source,vbnet]
|
2020-06-30 14:41:58 +02:00
|
|
|
----
|
|
|
|
Imports System.Security.Cryptography
|
|
|
|
|
|
|
|
Sub ComputeHash()
|
|
|
|
Dim sha256 = New SHA256CryptoServiceProvider() ' Compliant
|
|
|
|
Dim sha384 = New SHA384CryptoServiceProvider() ' Compliant
|
|
|
|
Dim sha512 = New SHA512CryptoServiceProvider() ' Compliant
|
|
|
|
|
|
|
|
' ...
|
|
|
|
End Sub
|
|
|
|
----
|
|
|
|
|
|
|
|
include::../see.adoc[]
|
2021-06-02 20:44:38 +02:00
|
|
|
|
2021-06-03 09:05:38 +02:00
|
|
|
ifdef::env-github,rspecator-view[]
|
2021-09-20 15:38:42 +02:00
|
|
|
|
|
|
|
'''
|
|
|
|
== Implementation Specification
|
|
|
|
(visible only on this page)
|
|
|
|
|
|
|
|
include::../message.adoc[]
|
|
|
|
|
|
|
|
include::../highlighting.adoc[]
|
|
|
|
|
2021-06-08 15:52:13 +02:00
|
|
|
'''
|
2021-06-02 20:44:38 +02:00
|
|
|
== Comments And Links
|
|
|
|
(visible only on this page)
|
|
|
|
|
|
|
|
include::../comments-and-links.adoc[]
|
2023-06-22 10:38:01 +02:00
|
|
|
|
2021-06-03 09:05:38 +02:00
|
|
|
endif::env-github,rspecator-view[]
|