FixUpdate

This commit is contained in:
Christoph Hehl 2026-05-10 14:24:01 +02:00
parent 2e9f5f0699
commit e3beb244f0

View File

@ -1,50 +1,21 @@
# OPC UA Simulator fixed v2 **OPC UA Simulator **
**Voraussetzungen**
Dieser Stand behebt die Fehler aus der ZIP-Version: - JDK 17 oder neuer
- Maven 3.9 oder neuer
- Top-Level-Objekte behalten jetzt eine stabile, konsistente NodeId-Zuordnung. Views verweisen nicht mehr auf nicht vorhandene Nodes. **CLI starten**
- Der Server legt Parent-Forward- und Child-Inverse-Referenzen mit dem ReferenceType aus dem Export an (`Organizes`, `HasComponent`, `HasProperty`, ...). mvn -q exec:java -Dexec.args="examples/opcua-export-1775161283402.json 4840 /"
- Doppelte Nodes im Export werden nur einmal erzeugt und mehrfach verlinkt. Dadurch fehlen StateCondition-/Method-/Property-Bereiche nicht mehr durch Duplicate-Node-Fehler.  
- Variablen werden mit `AccessLevel` und `UserAccessLevel` erzeugt, damit OPC-UA-Clients Werte schreiben können. Dann verbinden mit:
- GUI-Änderungen setzen Werte live in-place, ohne Nodes zu löschen und View-Referenzen zu zerstören. opc.tcp://localhost:4840/
- Über **+ Rootelement** kann unabhängig von der aktuellen Markierung direkt unter `Objects` ein neues oberstes Objekt angelegt werden.  
- Die Anzeige **Aktueller Wert** wird während des Serverlaufs automatisch aus dem laufenden Node aktualisiert; Hintergrund-Simulation und Client-Writes sind ohne erneutes Selektieren sichtbar. Anonyme Anmeldung ist aktiv. Zusätzlich existieren Benutzer:
- Beim Serverstart wird der aktuelle GUI-Baum verwendet. Vor dem Start hinzugefügte Nodes werden dadurch ebenfalls publiziert. user / password1
 admin / password2
## Voraussetzungen  
**GUI starten**
- JDK 17 oder neuer mvn javafx:run
- Maven 3.9 oder neuer  
In der GUI zuerst den JSON-Export laden, danach den Server starten.
## CLI starten **Hinweise zur NodeId-Zuordnung**
Der Export enthält mehrere Custom-Namespace-Indizes (ns=1 bis ns=7). Ein einzelner Milo ManagedNamespace liefert aber nur eine Namespace aus. Deshalb werden Custom-Namespaces intern konsistent auf die Simulator-Namespace gemappt. String-NodeIds wie AirConditioner_1.Temperature bleiben als Identifier erhalten, numerische Custom-IDs werden kollisionsfrei als String-Identifier gespeichert, z. B. ns=3;i=5000.
```bash Im OPC-UA-Client immer die NodeIds verwenden, die der Simulator beim Browsen tatsächlich anzeigt.
mvn -q exec:java -Dexec.args="examples/opcua-export-1775161283402.json 4840 /"
```
Dann verbinden mit:
```text
opc.tcp://localhost:4840/
```
Anonyme Anmeldung ist aktiv. Zusätzlich existieren Benutzer:
```text
user / password1
admin / password2
```
## GUI starten
```bash
mvn javafx:run
```
In der GUI zuerst den JSON-Export laden, danach den Server starten.
## Hinweise zur NodeId-Zuordnung
Der Export enthält mehrere Custom-Namespace-Indizes (`ns=1` bis `ns=7`). Ein einzelner Milo `ManagedNamespace` liefert aber nur eine Namespace aus. Deshalb werden Custom-Namespaces intern konsistent auf die Simulator-Namespace gemappt. String-NodeIds wie `AirConditioner_1.Temperature` bleiben als Identifier erhalten, numerische Custom-IDs werden kollisionsfrei als String-Identifier gespeichert, z. B. `ns=3;i=5000`.
Im OPC-UA-Client immer die NodeIds verwenden, die der Simulator beim Browsen tatsächlich anzeigt.