Building Call Graphs for Embedded Client-Side Code in Dynamic Web Applications

被引:20
|
作者
Hung Viet Nguyen [1 ]
Kastner, Christian [2 ]
Nguyen, Tien N. [1 ]
机构
[1] Iowa State Univ, ECpE Dept, Ames, IA 50011 USA
[2] Carnegie Mellon Univ, Sch Comp Sci, Pittsburgh, PA 15213 USA
基金
美国国家科学基金会;
关键词
Web Code Analysis; Embedded Code; Call Graphs;
D O I
10.1145/2635868.2635928
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
When developing and maintaining a software system, programmers often rely on IDEs to provide editor services such as syntax highlighting, auto-completion, and "jump to declaration". In dynamic web applications, such tool support is currently limited to either the server-side code or to hand-written or generated client-side code. Our goal is to build a call graph for providing editor services on client-side code while it is still embedded as string literals within server-side code. First, we symbolically execute the server-side code to identify all possible client-side code variations. Subsequently, we parse the generated client-side code with all its variations into a VarDOM that compactly represents all DOM variations for further analysis. Based on the VarDOM, we build conditional call graphs for embedded HTML, CSS, and JS. Our empirical evaluation on real-world web applications show that our analysis achieves 100% precision in identifying call-graph edges. 62% of the edges cross PHP strings, and 17% of them cross files-in both situations, navigation without tool support is tedious and error prone.
引用
收藏
页码:518 / 529
页数:12
相关论文
共 50 条
  • [1] Identifying Code of Individual Features in Client-Side Web Applications
    Maras, Josip
    Stula, Maja
    Carlson, Jan
    Crnkovic, Ivica
    [J]. IEEE TRANSACTIONS ON SOFTWARE ENGINEERING, 2013, 39 (12) : 1680 - 1697
  • [2] WAVES: Automatic Synthesis of Client-side Validation Code for Web Applications
    Skrupsky, Nazari
    Monshizadeh, Maliheh
    Bisht, Prithvi
    Hinrichs, Timothy
    Venkatakrishnan, V. N.
    Zuck, Lenore
    [J]. 2012 ASE INTERNATIONAL CONFERENCE ON CYBER SECURITY (CYBERSECURITY), 2012, : 46 - 53
  • [3] Automated Client-side Monitoring for Web Applications
    Choudhary, Shauvik Roy
    Orso, Alessandro
    [J]. ICSTW 2009: IEEE INTERNATIONAL CONFERENCE ON SOFTWARE TESTING, VERIFICATION, AND VALIDATION WORKSHOPS, 2009, : 303 - 306
  • [4] Client-Side Dynamic Metadata in Web 2.0
    Stamey, John
    Lassez, Jean-Louis
    Boorn, Daniel
    Rossi, Ryan
    [J]. SIGDOC'07: PROCEEDINGS OF THE 25TH ACM INTERNATIONAL CONFERENCE ON DESIGN OF COMMUNICATION, 2007, : 155 - 161
  • [5] Continuous Integration Processes for Modern Client-Side Web Applications
    Tim, Ratha
    Vukadinovic, Marko
    Lichter, Horst
    Tanachutiwat, Sansiri
    Schlebusch, Heinz-Josef
    [J]. 2017 INTERNATIONAL ELECTRICAL ENGINEERING CONGRESS (IEECON), 2017,
  • [6] Client-side web scripting with HaskellScript
    Meijer, E
    Leijen, D
    Hook, J
    [J]. PRACTICAL ASPECTS OF DECLARATIVE LANGUAGES, 1999, 1551 : 196 - 210
  • [7] Client-side monitoring for web mining
    Fenstermacher, KD
    Ginsburg, M
    [J]. JOURNAL OF THE AMERICAN SOCIETY FOR INFORMATION SCIENCE AND TECHNOLOGY, 2003, 54 (07): : 625 - 637
  • [8] DETECTING SERVER-SIDE ENDPOINTS IN WEB APPLICATIONS BASED ON STATIC ANALYSIS OF CLIENT-SIDE Java']JavaScript CODE
    Sigalov, D. A.
    Khashaev, A. A.
    Gamayunov, D. Yu.
    [J]. PRIKLADNAYA DISKRETNAYA MATEMATIKA, 2021, (53): : 32 - 54
  • [9] Improving the Responsiveness of Geospatial Web Applications Through Client-Side Processing
    Sroda, Kamila
    Labuz, Marek
    Ernst, Sebastian
    [J]. MULTIMEDIA AND NETWORK INFORMATION SYSTEMS, 2019, 833 : 142 - 150
  • [10] Detecting Concurrency Errors in Client-side Java']JavaScript Web Applications
    Hong, Shin
    Park, Yongbae
    Kim, Moonzoo
    [J]. 2014 IEEE SEVENTH INTERNATIONAL CONFERENCE ON SOFTWARE TESTING, VERIFICATION AND VALIDATION (ICST), 2014, : 61 - 70