Skip to content
DataMiner Dojo

More results...

Generic selectors
Exact matches only
Search in title
Search in content
Post Type Selectors
Search in posts
Search in pages
Search in posts
Search in pages
Log in
Menu
  • Updates & Insights
  • Questions
  • Learning
    • E-learning Courses
    • Tutorials
    • Open Classroom Training
    • Certification
      • DataMiner Fundamentals
      • DataMiner Configurator
      • DataMiner Automation
      • Scripts & Connectors Developer: HTTP Basics
      • Scripts & Connectors Developer: SNMP Basics
      • Visual Overview – Level 1
      • Verify a certificate
    • YouTube Videos
    • Solutions & Use Cases
      • Solutions
      • Use Case Library
    • Agility
      • Learn more about Agile
        • Agile Webspace
        • Everything Agile
          • The Agile Manifesto
          • Best Practices
          • Retro Recipes
        • Methodologies
          • The Scrum Framework
          • Kanban
          • Extreme Programming
        • Roles
          • The Product Owner
          • The Agile Coach
          • The Quality & UX Coach (QX)
      • Book your Agile Fundamentals training
      • Book you Kanban workshop
    • >> Go to DataMiner Docs
  • DevOps
    • About the DevOps Program
    • Sign up for the DevOps Program
    • DataMiner DevOps Support
    • Feature Suggestions
  • Downloads
  • Swag Shop
  • PARTNERS
    • Business Partners
    • Technology Partners
  • Contact
    • Sales, Training & Certification
    • DataMiner Support
    • Global Feedback Survey
  • >> Go to dataminer.services

Dataminer API DeserializationException

Solved1.39K views17th July 2023API integration
2
Simone Rosignoli41 9th December 2021 0 Comments

Hello,

We receive the following exception in our integration script while performing GetParametersForElement() on some DMS elements.

The root cause are those characters in the XML response:

Those characters are not valid XML and cause an exception on the Java library on which we don’t have much control. In my opinion, Dataminer should sanitize those characters on the API layer.

Can you do something on your side to filter out those characters in the XML response?

Thank you.

Regards,
Simone

Marieke Goethals [SLC] [DevOps Catalyst] Selected answer as best 17th July 2023

1 Answer

  • Active
  • Voted
  • Newest
  • Oldest
1
Gellynck Jens [SLC]2.71K Posted 9th December 2021 5 Comments

Hi Simone,

This is indeed likely a software issue, I think it’s best to create a software issue task for us (possibly through your Skyline contact).

A possible workaround may be to use the JSON API instead of the Soap API. For more information see the web services API reference.

Marieke Goethals [SLC] [DevOps Catalyst] Selected answer as best 17th July 2023
Simone Rosignoli commented 9th December 2021

Hi Jens,

Thanks for the answer. I’m going to ask the support team to open a ticket.

Wim Bruynooghe [SLC] [DevOps Advocate] commented 9th December 2021

Might also be worth investigating how these null characters end-up in the value of this parameter, which gets stored in the database and might give issues in various places of DataMiner. I think the protocol should have trimmed the value before setting it on the parameter, or there might be an encoding issue.

Robin Devos [SLC] [DevOps Advocate] commented 14th December 2021

Hi Jens and Wim

This is for a serial device/protocol and specifically for a parameter with a fixed length of 16. The param value is f.e. “DEVICE”, so less than 16.
So for me it’s logical that a param with a fixed 16 chars would return 16 chars. Please let me know if this is still a SW issue.

+ the param isn’t stored in db.

Gellynck Jens [SLC] commented 14th December 2021

At the very least, the API should return valid XML

Wim Bruynooghe [SLC] [DevOps Advocate] commented 15th December 2021

Filling it up with null characters seems like a hacky way to avoid the fixed length.
If it is needed for a device (or serial communication) then I think the protocol should add/remove null characters as needed when sending/receiving values of the device, but these null characters shouldn’t be stored in the DataMiner parameter.
It’s not just null characters, several other characters are not valid in XML 1.0 standard (almost everything below 0x20, see https://www.w3.org/TR/REC-xml/#charsets). Note that these characters might not always be at the end of the string, they could also be in the middle. So a simple trim() won’t fix this. We could just remove them, or replace them (question is then with what), but this might be completely unexpected. Especially when doing a parameter set with a received value from the API, then the parameter value gets changed unexpectedly.
So I think the API should return the value as-is. The JSON and SOAP API share the same code base, and there is no issue with the JSON API. The SOAP API is generated by Microsoft .NET, and Microsoft also chose to keep the value as-is.
Don’t use the SOAP API on parameters containing characters which can not be stored in XML 1.0. So either: use the JSON API, or avoid the invalid characters to be in the parameter, or as a hacky workaround you could remove them yourself from the received SOAP message before deserializing it.

Please login to be able to comment or post an answer.

My DevOps rank

DevOps Members get more insights on their profile page.

My user earnings

0 Dojo credits

Spend your credits in our swag shop.

0 Reputation points

Boost your reputation, climb the leaderboard.

Promo banner DataMiner DevOps Professiona Program
DataMiner Integration Studio (DIS)
Empower Katas
Privacy Policy • Terms & Conditions • Contact

© 2025 Skyline Communications. All rights reserved.

DOJO Q&A widget

Can't find what you need?

? Explore the Q&A DataMiner Docs