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 das Einlesen auf bestimmte Formate, während RemoveFalsePositive einen zweiten Scan für mehrdeutige Einlesungen hinzufügt.
Dieser Leitfaden erklärt, wie man BarCode-Prüfsummen validiert, das Einlesen auf erwartete Formate beschränkt und beide Techniken mithilfe von BarcodeReaderOptions zu einem mehrstufigen Qualitätskontrollpunkt kombiniert.
Schnellstart: Barcodes mit Prüfsummen- und Formatbeschränkungen validieren
Konfigurieren Sie BarcodeReaderOptions mit ExpectBarcodeTypes und RemoveFalsePositive, um das Lesen auf erwartete Symbologien mit automatischer Prüfsummenüberprüfung 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. Wenn die Ziffern nicht übereinstimmen, wird der BARCODE stillschweigend abgelehnt und erscheint nicht in der BarcodeResults-Sammlung. 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-Schalters.
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 hat die 85-%-Konfidenzschwelle überschritten und die Prüfsummenvalidierung bestanden, daher wird er in BarcodeResults angezeigt.
Fehlerpfad
Das Anheben von ConfidenceThreshold über seinen Standardwert von 0,7 verschärft diese Anforderung für Symbologien mit optionaler Prüfsumme wie Code39 weiter.
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?
Die Enumeration BarcodeEncoding ist ein Flag-Typ, der die Kombination mehrerer Formate mithilfe des bitweisen OR-Operators ermöglicht. Die Einstellung ExpectBarcodeTypes beschränkt den Leser auf diese Formate und überspringt die Erkennung anderer.
| 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
}
Jedes zurückgegebene BarcodeResult.BarcodeType gibt an, welches Format dekodiert wurde, und ermöglicht so die Weiterleitung.
Welche Symbologien unterstützen die Prüfsummenvalidierung?
Nicht alle Barcode-Formate verwenden Prüfsummen auf die gleiche Weise. Die folgende Tabelle ordnet gängige Symbologien ihren Fehlererkennungsmerkmalen zu und gibt damit 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. Das ConfidenceThreshold gilt weiterhin während der ML-Erkennungsphase, während der Dekodierungsschritt von der in der Symbologie 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 produktionsreife 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/, das als Erfolgspfad verwendet wird: zwei EAN-13 und ein UPC-A. Ein Code128-Regaletikett wird als Fehlerpfad verwendet – die EAN-13/UPC-A-Einschränkung lehnt es ab und protokolliert eine Zeile REJECT.
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
Das Setzen von MinScanLines auf 3 erhöht die Mindestanzahl übereinstimmender Scanlinien, die erforderlich sind, damit ein 1D-BarCode gültig ist; 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 BarcodeType-Prüfung ist eine mehrschichtige 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 stellen beschädigte oder schlecht beleuchtete BarCodes wieder her, was jedoch längere Scanzeiten zur Folge hat.
Was sind meine nächsten Schritte?
Dieser Artikel behandelte das implizite Prüfsummen-Validierungsmodell von IronBarcode, die Enumeration BarcodeEncoding für formatgebundene Lesevorgänge sowie ein kombiniertes Validierungsmuster unter Verwendung von ExpectBarcodeTypes, ConfidenceThreshold, RemoveFalsePositive und MinScanLines als mehrstufige Qualitätskontrollen.
Für weiterführende Informationen konsultieren Sie bitte diese Ressourcen:
- IronBarcode Tutorials — Barcodes lesen: Schritt-für-Schritt-Anleitungen zum Lesen von Barcodes.
- Vermeidung von Fehlalarmen für den
RemoveFalsePositive-Mechanismus im Detail. - Beispiele für Konfidenzschwellenwerte zur Optimierung der ML-basierten Erkennung.
- Ausgabedatenformate für die
BarcodeResult-Eigenschaftsreferenz. - 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.
Welche Programmierkenntnisse sind erforderlich, um IronBarcode in einem Projekt zu implementieren?
Grundkenntnisse in C#-Programmierung reichen aus, um IronBarcode in einem Projekt zu implementieren, da es unkomplizierte Methoden und eine umfassende Dokumentation für Entwickler bietet.
Ist IronBarcode sowohl für kleine Projekte als auch für große Unternehmensanwendungen geeignet?
IronBarcode ist so konzipiert, dass es skalierbar und vielseitig ist, wodurch es sich sowohl für kleine Projekte als auch für große Unternehmensanwendungen eignet, die robuste Barcode-Lösungen benötigen.

