Publication Details

String Constraints with Concatenation and Transducers Solved Efficiently (Technical Report)

HOLÍK Lukáš, JANKŮ Petr, LIN Anthony W., RUMMER Philipp and VOJNAR Tomáš. String Constraints with Concatenation and Transducers Solved Efficiently (Technical Report). New York: Springer International Publishing, 2020. Available from:
Czech title
Řetězcová omezení s konkatenací a převodníky řešena efektivně (technická zpráva)
technical report
Holík Lukáš, doc. Mgr., Ph.D. (DITS FIT BUT)
Janků Petr, Ing. (DITS FIT BUT)
Lin Anthony W. (UOx)
Rummer Philipp (Uppsala)
Vojnar Tomáš, prof. Ing., Ph.D. (DITS FIT BUT)

string analysis, XSS, string constraints


String analysis is the problem of reasoning about how strings are manipulated by a program. It has numerous applications including automatic detection of cross-site scripting (XSS). A popular string analysis technique includes symbolic executions, which at their core use string (constraint) solvers. Such solvers typically reason about constraints expressed in theories over strings with the concatenation operator as an atomic constraint. In recent years, researchers started to recognise the importance of incorporating the replace-all operator and finite transductions in the theories of strings with concatenation. Such string operations are typically crucial for reasoning about XSS vulnerabilities in web applications, especially for modelling sanitisation functions and implicit browser transductions (e.g. innerHTML).
In this paper, we provide the first string solver that can reason about constraints involving both concatenation and finite transductions. Moreover, it has a completeness and termination guarantee for several important fragments (e.g. straight-line fragment). The main challenge addressed in the paper is the prohibitive worst-case complexity of the theory. To this end, we propose a method that exploits succinct alternating finite automata as concise symbolic representations of string constraints. Alternation offers not only exponential savings in space when representing Boolean combinations of transducers, but also a possibility of succinct representation of otherwise costly combinations of transducers and concatenation. Reasoning about the emptiness of the AFA language requires a state-space exploration in an exponential-sized graph, for which we use model checking algorithms (e.g. IC3). We have implemented our algorithm and demonstrated its efficacy on benchmarks that are derived from XSS and other examples in the literature.

Springer International Publishing
New York, US
   author = "Luk\'{a}\v{s} Hol\'{i}k and Petr Jank\r{u} and W. Anthony Lin and Philipp Rummer and Tom\'{a}\v{s} Vojnar",
   title = "String Constraints with Concatenation and Transducers Solved Efficiently (Technical Report)",
   pages = "1--33",
   year = 2020,
   location = "New York, US",
   publisher = "Springer International Publishing",
   language = "english",
   url = ""
Back to top