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 条
  • [21] Client-Side Monitoring Techniques for Web Sites
    Filipe, Ricardo
    Araujo, Filipe
    [J]. 15TH IEEE INTERNATIONAL SYMPOSIUM ON NETWORK COMPUTING AND APPLICATIONS (IEEE NCA 2016), 2016, : 363 - 366
  • [22] A client-side Web agent for document categorization
    Boley, D
    Gini, M
    Hastings, K
    Mobasher, B
    Moore, J
    [J]. INTERNET RESEARCH-ELECTRONIC NETWORKING APPLICATIONS AND POLICY, 1998, 8 (05): : 387 - +
  • [23] Business-layer client-side racer: dynamic security testing of the web application against client-side race condition in the business layer
    Alidoosti, Mitra
    Nowroozi, Alireza
    Nickabadi, Ahmad
    [J]. INTERNATIONAL JOURNAL OF INFORMATION SECURITY, 2023, 22 (04) : 1029 - 1054
  • [24] Business-layer client-side racer: dynamic security testing of the web application against client-side race condition in the business layer
    Mitra Alidoosti
    Alireza Nowroozi
    Ahmad Nickabadi
    [J]. International Journal of Information Security, 2023, 22 : 1029 - 1054
  • [25] Causal inference of server- and client-side code smells in web apps evolution
    Rio, Americo
    Brito e Abreu, Fernando
    Mendes, Diana
    [J]. EMPIRICAL SOFTWARE ENGINEERING, 2024, 29 (05)
  • [26] Agent-Oriented Programming for Client-Side Concurrent Web 2.0 Applications
    Minotti, Mattia
    Piancastelli, Giulio
    Ricci, Alessandro
    [J]. WEB INFORMATION SYSTEMS AND TECHNOLOGIES, 2010, 45 : 17 - 29
  • [27] Integrating Web caching and Web prefetching in client-side proxies
    Teng, WG
    Chang, CY
    Chen, MS
    [J]. IEEE TRANSACTIONS ON PARALLEL AND DISTRIBUTED SYSTEMS, 2005, 16 (05) : 444 - 455
  • [28] ZigZag: Automatically Hardening Web Applications Against Client-side Validation Vulnerabilities
    Weissbacher, Michael
    Robertson, William
    Kirda, Engin
    Kruegel, Christopher
    Vigna, Giovanni
    [J]. PROCEEDINGS OF THE 24TH USENIX SECURITY SYMPOSIUM, 2015, : 737 - 752
  • [29] High-Performance Client-Side Web Applications through Haskell EDSLs
    Ekblad, Anton
    [J]. ACM SIGPLAN NOTICES, 2016, 51 (12) : 62 - 73
  • [30] AjaxScope: A Platform for Remotely Monitoring the Client-Side Behavior of Web 2.0 Applications
    Kiciman, Emre
    Livshits, Benjamin
    [J]. ACM TRANSACTIONS ON THE WEB, 2010, 4 (04)