Build a dotnet pe to trigger this issue VirusTotal#1708
HelloWorld_origin.dll
The size of pe should preferably be a multiple of pagesize, because we can only cause a maximum of 16 bytes out of bounds read.
- 
Write a metadata header at the end of file: The last 4 bytes is the Length,Lengthmust <= 16 to trigger the issue, and of course it must also be a legal value:// yara/libyara/modules/dotnet:1652 if (md_len == 0 || md_len > 255 || md_len % 4 != 0 || !fits_in_pe(pe, pe->data + offset, md_len)) { return false; } 
- 
Edit the last section header, make Virtual Sizebe the same asRaw Size, otherwise the metadata header at the end of file will not be considered as part of pe.
- 
Edit the MetaDataRVAto the RVA metadata header we write at the end of file
import "dotnet"
rule dotnet_version_rule
{
    condition:
        dotnet.version == "v4.0.30319"
}


