Wie man Barcode-Prüfsummen validiert und formatbewusstes Lesen in C# verwendet
Barcode-Prüfsummen helfen, Substitutionsfehler zu erkennen. Beispielsweise kann eine einzige vertauschte Ziffer in einem EAN-13-Etikett dazu führen, dass ein Paket im falschen Lager landet. Formatbewusstes Lesen bietet eine zusätzliche Validierungsebene, indem der Decoder auf erwartete Symbologien beschränkt wird. Dieser Ansatz reduziert Fehlalarme durch Hintergrundrauschen und verkürzt die Scanzeit, indem unnötige Formatdetektoren übersprungen werden.
IronBarcode führt während der Dekodierung automatisch eine Prüfsummenverifizierung durch. Der Prüfziffernalgorithmus jeder Symbologie wird standardmäßig ausgeführt, und fehlerhafte Barcodes werden verworfen, bevor Ergebnisse zurückgegeben werden. Die Eigenschaft BarcodeReaderOptions.ExpectBarcodeTypes beschränkt die Lesevorgänge auf bestimmte Formate, während RemoveFalsePositive einen zweiten Scan für mehrdeutige Lesevorgänge hinzufügt.
Dieser Leitfaden erklärt, wie man Barcode-Prüfsummen validiert, Lesevorgänge auf erwartete Formate beschränkt und beide Techniken mithilfe von BarcodeReaderOptions zu einem mehrschichtigen Qualitätsgate kombiniert.
Schnellstart: Barcodes mit Prüfsummen- und Formatbeschränkungen validieren
Konfigurieren Sie BarcodeReaderOptions mit ExpectBarcodeTypes und RemoveFalsePositive, um Lesevorgänge auf erwartete Symbologien mit automatischer Prüfsummenverifizierung zu beschränken.
:path=/static-assets/barcode/content-code-examples/how-to/checksum-and-format-validation/quickstart.cs
using IronBarCode;
// Format-constrained read with false-positive removal.
// Limit the decoder to EAN-13 and Code128; checksums are
// validated automatically and failures are silently discarded.
var options = new BarcodeReaderOptions
{
ExpectBarcodeTypes = BarcodeEncoding.EAN13 | BarcodeEncoding.Code128,
RemoveFalsePositive = true,
Speed = ReadingSpeed.Balanced
};
BarcodeResults results = BarcodeReader.Read("label.png", options);
Imports IronBarCode
' Format-constrained read with false-positive removal.
' Limit the decoder to EAN-13 and Code128; checksums are
' validated automatically and failures are silently discarded.
Dim options As New BarcodeReaderOptions With {
.ExpectBarcodeTypes = BarcodeEncoding.EAN13 Or BarcodeEncoding.Code128,
.RemoveFalsePositive = True,
.Speed = ReadingSpeed.Balanced
}
Dim results As BarcodeResults = BarcodeReader.Read("label.png", options)
Minimaler Arbeitsablauf (5 Schritte)
- Laden Sie die IronBarcode Bibliothek von NuGet herunter.
- Erstellen Sie eine
BarcodeReaderOptionsInstanz - Setzen Sie
ExpectBarcodeTypesauf die in der Pipeline vorhandenen Symbologien. - Aktivieren Sie
RemoveFalsePositivefür die sekundäre Verifizierung. - Rufen Sie
BarcodeReader.Readzum Dekodieren auf; Prüfsummen werden während des Dekodierungsprozesses automatisch validiert.
Wie validiert man Barcode-Prüfsummen?
IronBarcode validiert Prüfsummen während der Dekodierung gemäß der Spezifikation jeder Symbologie. Beim Lesen eines EAN-13-Barcodes wird beispielsweise die Mod10-Prüfziffer aus den ersten 12 Ziffern berechnet und mit der 13. Ziffer verglichen. Stimmen die Ziffern nicht überein, wird der Barcode stillschweigend zurückgewiesen und erscheint nicht in der Sammlung BarcodeResults. Dieser Ansatz gilt für alle Formate mit obligatorischer Prüfziffer, einschließlich UPC-A, UPC-E, EAN-8, Code128, ITF und andere.
Dieses implizite Modell unterscheidet sich von Bibliotheken, die eine explizite Umschaltung ermöglichen. Die folgende Tabelle vergleicht die beiden Ansätze:
| Aspekt | IronBarcode | Aspose.BarCode |
|---|---|---|
| Validierungsauslöser | Automatisch; wird bei jeder Dekodierung ausgeführt. | Explizit: PrüfsummeValidation.On / Off / Default |
| Entwickleraktion erforderlich | Keine; ungültige Barcodes werden von den Ergebnissen ausgeschlossen. | Setzen Sie BarcodeSettings.PrüfsummeValidation vor dem Lesen. |
| Prüfsumme deaktiviert | Nicht offengelegt; Prüfsummen werden für obligatorische Formate immer erzwungen. | Ja; PrüfsummeValidation.Off überspringt die Überprüfung. |
| Optionale Prüfsummenformate (Code39) | Verwendet Confidence + RemoveFalsePositive , um minderwertige Lesevorgänge herauszufiltern. | Aktivieren Sie die Prüfsummeme explizit mit EnablePrüfsumme.Ja |
| Ausfallverhalten | Barcode wurde stillschweigend aus den Ergebnissen entfernt. | Der Barcode kann mit einer separaten Prüfsumme zur manuellen Überprüfung angezeigt werden. |
Bei Symbologien mit optionalen Prüfsummen, wie z. B. Code39, verwendet die Bibliothek eine Konfidenzbewertung und RemoveFalsePositive anstelle eines Prüfsummen-Umschalters.
Eingabe
Ein Code128-Lagerregaletikett (Erfolgspfad) und ein leeres Bild ohne Barcode (Fehlerpfad).
warehouse-rack.png (Erfolgspfad)
blank-no-barcode.png (Fehlerpfad – kein Barcode vorhanden)
:path=/static-assets/barcode/content-code-examples/how-to/checksum-and-format-validation/checksum-confidence.cs
using IronBarCode;
// Constrain reads to 1D formats and enable secondary verification.
// ConfidenceThreshold rejects decodes where the ML detector falls below 85%,
// acting as a quality gate for optional-checksum symbologies like Code39.
var options = new BarcodeReaderOptions
{
ExpectBarcodeTypes = BarcodeEncoding.AllOneDimensional,
RemoveFalsePositive = true,
ConfidenceThreshold = 0.85,
Speed = ReadingSpeed.Detailed
};
BarcodeResults results = BarcodeReader.Read("warehouse-rack.png", options);
foreach (BarcodeResult result in results)
{
// Each result has passed checksum validation (mandatory formats)
// and the 85% confidence threshold, so no additional filtering is needed.
Console.WriteLine($"[{result.BarcodeType}] {result.Value} page={result.PageNumber}");
}
if (results.Count == 0)
{
Console.Error.WriteLine("No valid barcodes found. Possible causes:");
Console.Error.WriteLine(" - Check digit mismatch (barcode silently rejected)");
Console.Error.WriteLine(" - Confidence below 85% threshold");
Console.Error.WriteLine(" - Format not in ExpectBarcodeTypes");
}
Imports IronBarCode
' Constrain reads to 1D formats and enable secondary verification.
' ConfidenceThreshold rejects decodes where the ML detector falls below 85%,
' acting as a quality gate for optional-checksum symbologies like Code39.
Dim options As New BarcodeReaderOptions With {
.ExpectBarcodeTypes = BarcodeEncoding.AllOneDimensional,
.RemoveFalsePositive = True,
.ConfidenceThreshold = 0.85,
.Speed = ReadingSpeed.Detailed
}
Dim results As BarcodeResults = BarcodeReader.Read("warehouse-rack.png", options)
For Each result As BarcodeResult In results
' Each result has passed checksum validation (mandatory formats)
' and the 85% confidence threshold, so no additional filtering is needed.
Console.WriteLine($"[{result.BarcodeType}] {result.Value} page={result.PageNumber}")
Next
If results.Count = 0 Then
Console.Error.WriteLine("No valid barcodes found. Possible causes:")
Console.Error.WriteLine(" - Check digit mismatch (barcode silently rejected)")
Console.Error.WriteLine(" - Confidence below 85% threshold")
Console.Error.WriteLine(" - Format not in ExpectBarcodeTypes")
End If
Ausgabe
Erfolgsweg
Der Barcode des Lagerregals wurde auf Seite 0 als RACK-A1-LOT-7382 zurückgegeben. Er überschritt die 85%-Konfidenzschwelle und bestand die Prüfsummenvalidierung, daher wird er in BarcodeResults angezeigt.
Fehlerpfad
Durch die Erhöhung des Wertes von ConfidenceThreshold über den Standardwert von 0,7 wird diese Barriere für optionale Prüfsummensymbologien wie Code39 weiter verschärft.
Nachdem die Prüfsummenvalidierung abgedeckt ist, besteht der nächste Schritt darin, den Leser auf die Barcode-Formate zu beschränken, die Ihre Pipeline erwartet.
Wie verwendet man formatbasiertes Barcode-Lesen?
Der Enum-Typ BarcodeEncoding ist ein Flag-Typ, der es ermöglicht, mehrere Formate mithilfe des bitweisen OR-Operators zu kombinieren. Die Einstellung ExpectBarcodeTypes beschränkt den Reader auf diese Formate und überspringt die Erkennung anderer Formate.
| Wert | Kategorie | Beschreibung | Prüfsumme |
|---|---|---|---|
BarcodeEncoding.All | Meta | Alle unterstützten Formate (Standardverhalten) | Pro Format |
BarcodeEncoding.AllOneDimensional | Meta | Alle linearen (1D) Formate einschließlich gestapelter | Pro Format |
BarcodeEncoding.AllTwoDimensional | Meta | Alle Matrix-/Gitterformate (2D) | Pro Format |
BarcodeEncoding.Code128 | 1D | Hochdichte alphanumerische Zeichen (Logistik, Versand) | Pflicht (gewichtetes Mod103) |
BarcodeEncoding.EAN13 | 1D | Produktkennzeichnung im Einzelhandel, 13 Ziffern | Obligatorisch (Mod10) |
BarcodeEncoding.QRCode | 2D | Hochleistungsmatrix (URLs, strukturierte Daten) | Reed-Solomon ECC |
BarcodeEncoding.Code39 | 1D | Alphanumerisch (Verteidigung, Automobilindustrie) | Optional (Mod43) |
BarcodeEncoding.UPCA | 1D | Nordamerikanischer Einzelhandel, 12-stellig | Obligatorisch (Mod10) |
BarcodeEncoding.DataMatrix | 2D | Kompaktmatrix (Elektronik, Pharma) | Reed-Solomon ECC |
BarcodeEncoding.PDF417 | 2D | Gestapelt (Ausweise, Transport) | Reed-Solomon ECC |
Neben der Geschwindigkeit dient die Beschränkung des Formatsets als Validierungsgatter: Barcodes jeglicher nicht aufgeführter Symbolik werden von den Ergebnissen ausgeschlossen, selbst wenn sie physisch im Bild vorhanden sind.
Eingabe
Ein Code128-Versandetikett (Erfolgspfad) und ein QR-Code, der nicht der Code128-Beschränkung entspricht (Fehlerpfad).
shipping-label.png (Erfolgspfad — Code128 entspricht der Bedingung)
qr-format-mismatch.png (Fehlerpfad – QR-Code wird vom Code128-Filter abgelehnt)
:path=/static-assets/barcode/content-code-examples/how-to/checksum-and-format-validation/format-constrained.cs
using IronBarCode;
// Constrained read: only Code128 barcodes are returned.
// Faster because the reader skips all other format detectors.
var constrainedOptions = new BarcodeReaderOptions
{
ExpectBarcodeTypes = BarcodeEncoding.Code128,
Speed = ReadingSpeed.Faster,
ExpectMultipleBarcodes = false
};
// Broad read: all supported formats are scanned.
// Useful for verification or when the image format is unknown.
var broadOptions = new BarcodeReaderOptions
{
ExpectBarcodeTypes = BarcodeEncoding.All,
Speed = ReadingSpeed.Detailed,
ExpectMultipleBarcodes = true
};
string imagePath = "shipping-label.png";
BarcodeResults constrained = BarcodeReader.Read(imagePath, constrainedOptions);
Console.WriteLine($"Constrained: {constrained.Count} Code128 barcode(s) found");
BarcodeResults broad = BarcodeReader.Read(imagePath, broadOptions);
Console.WriteLine($"Broad: {broad.Count} barcode(s) found across all formats");
foreach (BarcodeResult result in broad)
{
Console.WriteLine($" [{result.BarcodeType}] {result.Value}");
}
Imports IronBarCode
' Constrained read: only Code128 barcodes are returned.
' Faster because the reader skips all other format detectors.
Dim constrainedOptions As New BarcodeReaderOptions With {
.ExpectBarcodeTypes = BarcodeEncoding.Code128,
.Speed = ReadingSpeed.Faster,
.ExpectMultipleBarcodes = False
}
' Broad read: all supported formats are scanned.
' Useful for verification or when the image format is unknown.
Dim broadOptions As New BarcodeReaderOptions With {
.ExpectBarcodeTypes = BarcodeEncoding.All,
.Speed = ReadingSpeed.Detailed,
.ExpectMultipleBarcodes = True
}
Dim imagePath As String = "shipping-label.png"
Dim constrained As BarcodeResults = BarcodeReader.Read(imagePath, constrainedOptions)
Console.WriteLine($"Constrained: {constrained.Count} Code128 barcode(s) found")
Dim broad As BarcodeResults = BarcodeReader.Read(imagePath, broadOptions)
Console.WriteLine($"Broad: {broad.Count} barcode(s) found across all formats")
For Each result As BarcodeResult In broad
Console.WriteLine($" [{result.BarcodeType}] {result.Value}")
Next
Ausgabe
Erfolgsweg
Das Versandetikett hat den Wert SHIP-2024-00438. Die eingeschränkte Lesefunktion erkennt es sofort, da der Filter Code128 erwartet, und die umfassende Lesefunktion bestätigt dasselbe Ergebnis über alle Formate hinweg.
Fehlerpfad
Leere Ergebnisse bei einem eingeschränkten Lesevorgang sind ein Validierungssignal, kein Fehler; Die Abweichung zur Überprüfung protokollieren.
Bei Pipelines, die verschiedene Barcode-Typen mischen (z. B. ein Lieferschein mit EAN-13-Produktcode und Code128-Trackingnummer), kombinieren Sie die erwarteten Formate:
:path=/static-assets/barcode/content-code-examples/how-to/checksum-and-format-validation/multi-format-combine.cs
using IronBarCode;
// Combine multiple format flags with | to scan for more than one symbology
// in a single pass. Each BarcodeResult.BarcodeType identifies which format
// was decoded, enabling downstream routing logic per symbology.
var options = new BarcodeReaderOptions
{
ExpectBarcodeTypes = BarcodeEncoding.EAN13 | BarcodeEncoding.Code128,
ExpectMultipleBarcodes = true
};
Imports IronBarCode
' Combine multiple format flags with Or to scan for more than one symbology
' in a single pass. Each BarcodeResult.BarcodeType identifies which format
' was decoded, enabling downstream routing logic per symbology.
Dim options As New BarcodeReaderOptions With {
.ExpectBarcodeTypes = BarcodeEncoding.EAN13 Or BarcodeEncoding.Code128,
.ExpectMultipleBarcodes = True
}
Jeder zurückgegebene Code BarcodeResult.BarcodeType identifiziert das dekodierte Format und ermöglicht so das Downstream-Routing.
Welche Symbologien unterstützen die Prüfsummenvalidierung?
Nicht alle Barcode-Formate verwenden Prüfsummen auf die gleiche Weise. Die folgende Tabelle ordnet gängigen Symbologien ihre Fehlererkennungseigenschaften zu und gibt Aufschluss darüber, wie aggressiv ConfidenceThreshold und RemoveFalsePositive für jedes Format eingestellt werden sollten:
| Symbolik | Prüfsummentyp | Obligatorisch? | Empfehlung |
|---|---|---|---|
| EAN-13 / EAN-8 | Mod10 | Ja | Standardeinstellungen ausreichend; Prüfsumme wird immer erzwungen. |
| UPC-A / UPC-E | Mod10 | Ja | Standardeinstellungen ausreichend; Prüfziffer wird beim Schreiben automatisch korrigiert. |
| Code128 | Gewichtetes Mod103 | Ja | Standardeinstellungen ausreichend; gemäß Spezifikation obligatorisch. |
| Code39 | Mod43 | Optional | Erhöhen Sie ConfidenceThreshold auf 0,8+ und aktivieren Sie RemoveFalsePositive |
| Codabar | Mod16 | Optional | Wie bei Code 39; Vertrauen als Qualitätskriterium verwenden. |
| ITF | Mod10 | Optional | Aktivieren Sie RemoveFalsePositive für verschachtelte Formate. |
| QR-Code / DataMatrix | Reed-Solomon ECC | Stets | Strukturelle Fehlerkorrektur; keine zusätzliche Konfiguration erforderlich |
| PDF417 | Reed-Solomon ECC | Stets | Wie bei QR/DataMatrix; Fehlerkorrektur ist inhärent. |
Bei 2D-Symbologien wie QR, DataMatrix und PDF417 ist die Fehlerkorrektur in die Kodierungsstruktur integriert. Diese Formate können Teilschäden wiederherstellen, ohne auf eine einfache Prüfziffer angewiesen zu sein. Der Code ConfidenceThreshold gilt weiterhin während der ML-Erkennungsphase, während der Dekodierungsschritt von der in der Symbolik integrierten Redundanz profitiert.
Nachdem wir nun beide Techniken verstanden haben, kombinieren wir sie zu einem einzigen, produktionsreifen Validierungsmuster.
Wie lassen sich Prüfsummen mit Formatbeschränkungen kombinieren?
Das produktionsfertige Muster setzt ExpectBarcodeTypes, RemoveFalsePositive, ConfidenceThreshold und Speed in einem einzigen BarcodeReaderOptions Objekt. Zusammen bilden sie ein mehrschichtiges Kontrollsystem: Formatbeschränkungen verengen den Suchraum, die Prüfsummenvalidierung gewährleistet die Datenintegrität, die Konfidenzschwellenwertfilterung filtert Randdekodierungen und die Entfernung von Fehlalarmen fügt einen zweiten Verifizierungsdurchgang hinzu.
Eingabe
Drei POS-Scan-Barcodes aus dem Verzeichnis pos-scans/, die als Erfolgspfad verwendet wurden: zwei EAN-13 und ein UPC-A. Als Fehlerpfad wird ein Code128-Lagerregaletikett verwendet – die EAN-13/UPC-A-Beschränkung weist es zurück und protokolliert eine REJECT-Zeile.
pos-scan-1.png (Erfolg)
pos-scan-2.png (Erfolg)
pos-scan-3.png (Erfolg)
warehouse-rack.png (Fehler – Code128 abgelehnt)
:path=/static-assets/barcode/content-code-examples/how-to/checksum-and-format-validation/combined-validation.cs
using IronBarCode;
// Layered validation for retail POS: EAN-13, UPC-A, and UPC-E only.
// Each property adds a distinct filter to the read pipeline.
var options = new BarcodeReaderOptions
{
// Layer 1: format constraint, accept only retail symbologies
ExpectBarcodeTypes = BarcodeEncoding.EAN13 | BarcodeEncoding.UPCA | BarcodeEncoding.UPCE,
// Layer 2: confidence threshold, reject decodes below 80%
ConfidenceThreshold = 0.8,
// Layer 3: false-positive removal, runs a secondary verification pass
RemoveFalsePositive = true,
Speed = ReadingSpeed.Balanced,
ExpectMultipleBarcodes = false,
// Require 3 agreeing scan lines to reduce phantom reads from noisy images
MinScanLines = 3
};
string[] scanFiles = Directory.GetFiles("pos-scans/", "*.png");
foreach (string file in scanFiles)
{
BarcodeResults results = BarcodeReader.Read(file, options);
if (results.Count == 0)
{
// No barcode passed all validation layers
Console.Error.WriteLine($"REJECT {Path.GetFileName(file)}: "
+ "no valid EAN-13/UPC barcode (checksum, confidence, or format mismatch)");
continue;
}
BarcodeResult primary = results.First();
// Post-read assertion: verify the decoded format matches expectations.
// ExpectBarcodeTypes already constrains the reader; this check documents
// intent and surfaces unexpected results during future changes.
if (primary.BarcodeType != BarcodeEncoding.EAN13
&& primary.BarcodeType != BarcodeEncoding.UPCA
&& primary.BarcodeType != BarcodeEncoding.UPCE)
{
Console.Error.WriteLine($"UNEXPECTED FORMAT {Path.GetFileName(file)}: "
+ $"got {primary.BarcodeType}, expected EAN-13/UPC");
continue;
}
Console.WriteLine($"OK {Path.GetFileName(file)}: [{primary.BarcodeType}] {primary.Value}");
}
Imports IronBarCode
Imports System.IO
' Layered validation for retail POS: EAN-13, UPC-A, and UPC-E only.
' Each property adds a distinct filter to the read pipeline.
Dim options As New BarcodeReaderOptions With {
' Layer 1: format constraint, accept only retail symbologies
.ExpectBarcodeTypes = BarcodeEncoding.EAN13 Or BarcodeEncoding.UPCA Or BarcodeEncoding.UPCE,
' Layer 2: confidence threshold, reject decodes below 80%
.ConfidenceThreshold = 0.8,
' Layer 3: false-positive removal, runs a secondary verification pass
.RemoveFalsePositive = True,
.Speed = ReadingSpeed.Balanced,
.ExpectMultipleBarcodes = False,
' Require 3 agreeing scan lines to reduce phantom reads from noisy images
.MinScanLines = 3
}
Dim scanFiles As String() = Directory.GetFiles("pos-scans/", "*.png")
For Each file As String In scanFiles
Dim results As BarcodeResults = BarcodeReader.Read(file, options)
If results.Count = 0 Then
' No barcode passed all validation layers
Console.Error.WriteLine($"REJECT {Path.GetFileName(file)}: " &
"no valid EAN-13/UPC barcode (checksum, confidence, or format mismatch)")
Continue For
End If
Dim primary As BarcodeResult = results.First()
' Post-read assertion: verify the decoded format matches expectations.
' ExpectBarcodeTypes already constrains the reader; this check documents
' intent and surfaces unexpected results during future changes.
If primary.BarcodeType <> BarcodeEncoding.EAN13 AndAlso
primary.BarcodeType <> BarcodeEncoding.UPCA AndAlso
primary.BarcodeType <> BarcodeEncoding.UPCE Then
Console.Error.WriteLine($"UNEXPECTED FORMAT {Path.GetFileName(file)}: " &
$"got {primary.BarcodeType}, expected EAN-13/UPC")
Continue For
End If
Console.WriteLine($"OK {Path.GetFileName(file)}: [{primary.BarcodeType}] {primary.Value}")
Next
Ausgabe
Erfolgsweg
Alle drei POS-Scanbilder wurden erfolgreich übertragen. Der Reader gab die Werte 5901234123471, 4006381333931 und 012345678905 zurück. Jedes einzelne entsprach dem EAN13-Code. | UPCA | Der UPCE`-Filter wies eine gültige Mod10-Prüfsumme auf, und das Konfidenzintervall lag über 0,8.
Fehlerpfad
Durch Setzen von MinScanLines auf 3 erhöht sich die Mindestanzahl übereinstimmender Scanzeilen, die für die Gültigkeit eines 1D-Barcodes erforderlich sind; Der Standardwert ist 2. Durch Erhöhen dieses Wertes wird das Risiko von Phantom-Lesevorgängen aufgrund verrauschter Scanzeilen verringert, es kann jedoch dazu führen, dass dünne oder teilweise beschädigte Barcodes nicht erkannt werden. In Einzelhandels-POS-Umgebungen mit sauber gedruckten Etiketten ist ein Wert von 3 eine konservative Wahl, die die Validierung stärkt, ohne den Durchsatz zu beeinträchtigen.
Die nach dem Lesen durchgeführte Assertion BarcodeType dient der mehrstufigen Verteidigung: ExpectBarcodeTypes filtert bereits, aber die explizite Prüfung dokumentiert die Absicht und erkennt Konfigurationsabweichungen ohne Laufzeitkosten. Zur Geschwindigkeitsoptimierung eignet sich ReadingSpeed.Faster für saubere, maschinell gedruckte Etiketten; Detailed und ExtremeDetail können beschädigte oder schlecht beleuchtete Barcodes wiederherstellen, allerdings auf Kosten längerer Scanzeiten.
Was sind meine nächsten Schritte?
Dieser Artikel behandelte das implizite Prüfsummenvalidierungsmodell von IronBarcode, die BarcodeEncoding Flags-Enumeration für formatbeschränkte Lesevorgänge und ein kombiniertes Validierungsmuster, das ExpectBarcodeTypes, ConfidenceThreshold, RemoveFalsePositive und MinScanLines als geschichtete Qualitätsgates verwendet.
Für weiterführende Informationen konsultieren Sie bitte diese Ressourcen:
- IronBarcode Tutorials — Barcodes lesen: Schritt-für-Schritt-Anleitungen zum Lesen von Barcodes.
- Detaillierte Fehlervermeidung für den Mechanismus
RemoveFalsePositive. - Beispiele für Konfidenzschwellenwerte zur Optimierung der ML-basierten Erkennung.
- Ausgabedatenformate für die Eigenschaftsreferenz
BarcodeResult. - Bildkorrektur-Anleitung für Filter zur Verbesserung der Dekodierungsgenauigkeit.
- Die vollständige Konfigurationsdokumentation finden Sie in der BarcodeReaderOptions API-Referenz .
- Die vollständige Liste der unterstützten Symbologien finden Sie in der BarcodeEncoding API-Referenz .
Sichern Sie sich eine kostenlose Testlizenz, um alle Funktionen in einer Live-Umgebung zu testen, oder informieren Sie sich über die Lizenzoptionen, sobald die Pipeline produktionsbereit ist.
Häufig gestellte Fragen
Was ist Barcode-Prüfsummenvalidierung?
Die Prüfsummenvalidierung von Barcodes ist ein Verfahren, das die Genauigkeit der Barcode-Daten sicherstellt, indem die berechnete Prüfsumme mit dem im Barcode kodierten Wert verglichen wird. Dies hilft, Fehler beim Scannen zu erkennen.
Wie handhabt IronBarcode die Prüfsummenvalidierung?
IronBarcode übernimmt die Prüfsummenvalidierung implizit, indem es die Prüfsumme für die Barcodedaten berechnet und sie mit der codierten Prüfsumme vergleicht. Dadurch wird die Datenintegrität während des Scanvorgangs sichergestellt.
Was sind BarcodeEncoding-Filter?
Mit den BarcodeEncoding-Filtern in IronBarcode können Sie festlegen, welche Barcode-Formate beim Scannen gelesen oder ignoriert werden sollen. Dies ermöglicht eine genauere und effizientere Barcode-Verarbeitung, indem der Fokus auf bestimmte Barcode-Typen gelegt wird.
Kann IronBarcode eine kombinierte Validierung durchführen?
Ja, IronBarcode kann eine kombinierte Validierung durchführen, indem es während des Scanvorgangs sowohl die Prüfsumme als auch das Format der Barcodes überprüft und so sicherstellt, dass nur gültige und korrekt formatierte Barcodes verarbeitet werden.
Ist es mit IronBarcode in C# möglich, Barcode-Lesevorgänge nach Format einzuschränken?
Ja, IronBarcode ermöglicht es Ihnen, Barcode-Lesevorgänge einzuschränken, indem Sie die Formate angeben, die ein- oder ausgeschlossen werden sollen, und so sicherzustellen, dass Ihre Anwendung nur relevante Barcode-Typen verarbeitet.
Warum ist formatbewusstes Lesen bei der Barcode-Verarbeitung wichtig?
Formatbewusstes Lesen ist wichtig, weil es Ihrer Anwendung ermöglicht, nur bestimmte Barcode-Typen zu verarbeiten, wodurch Geschwindigkeit und Genauigkeit verbessert werden, indem irrelevante oder nicht unterstützte Barcode-Formate ignoriert werden.
Wie implementiere ich formatbewusstes Lesen in IronBarcode?
Um formatabhängiges Lesen in IronBarcode zu implementieren, verwenden Sie BarcodeEncoding-Filter, um die zu lesenden Barcode-Formate festzulegen. Dies erfolgt über die API der Bibliothek, die eine präzise Steuerung der Anforderungen an das Barcode-Scannen ermöglicht.
Welche Vorteile bietet die Verwendung von IronBarcode zur Barcode-Validierung?
IronBarcode bietet zahlreiche Vorteile für die Barcode-Validierung, darunter eine robuste Prüfsummenverifizierung, formatbewusstes Lesen und die Fähigkeit, eine breite Palette von Barcode-Standards zu verarbeiten, wodurch eine hohe Genauigkeit und Flexibilität bei der Barcode-Verarbeitung gewährleistet wird.

