Design of Imacros-Based Data Crawler and the Behavioral Analysis of Facebook Users

Total Page:16

File Type:pdf, Size:1020Kb

Design of Imacros-Based Data Crawler and the Behavioral Analysis of Facebook Users Design of iMacros-based Data Crawler and the Behavioral Analysis of Facebook Users Mudasir Ahmad Wani Nancy Agarwal Suraiya Jabin Syed Zeesahn Hussain Research laboratory Research laboratory Department of Computer Department of Computer Department Computer Department Computer Science Science Science Science Faculty of Natural Science Faculty of Natural Science Faculty of Natural Science Faculty of Natural Science Jamia Millia Islamia (A Jamia Millia Islamia (A Jamia Millia Islamia (A Jamia Millia Islamia (A Central University) Central University) Central University) Central University) New Delhi, India New Delhi, India New Delhi, India New Delhi, India [email protected] [email protected] [email protected] [email protected] Abstract Obtaining the desired dataset is still a prime challenge faced by researchers while analyzing Online Social Network (OSN) sites. Application Programming Interfaces (APIs) provided by OSN service providers for retrieving data impose several unavoidable restrictions which make it difficult to get a desirable dataset. In this paper, we present an iMacros technology-based data crawler called IMcrawler, capable of collecting every piece of information which is accessible through a browser from the Facebook website within the legal framework which permits access to publicly shared user content on OSNs. The proposed crawler addresses most of the challenges allied with web data extraction approaches and most of the APIs provided by OSN service providers. Two broad sections have been extracted from Facebook user profiles, namely, Personal Information and Wall Activities. The present work is the first attempt towards providing the detailed description of crawler design for the Facebook website. Keywords: Online Social Networks, Information Retrieval, Data Extraction, Behavioral Analysis, Privacy and Security. Introduction Online Social Network (OSN) is a web application which focuses on the social life of netizens and provides them an excellent platform to build a network of relationships and share their social life. OSNs such as Facebook, LinkedIn and Twitter are increasingly becoming popular among internet users and turning to be an essential medium for people’ s daily activities. Since their structure significantly reflects the real-life communities and they contain a huge amount of user’ s personal and social information, they are of scientific importance to the researchers and disciplines in different domains including marketing, sociology, politics etc. Marketers study OSNs to design a viral marketing strategy (Staab et al., 2005), sociologists use them to study the human behavior (Christakis et al., 2013) and politicians use them to empower their political campaigns (Vergeer et al., 2013). For conducting any kind of analysis, sufficient amount of data is the preliminary requirement (Wani et al., 2018). OSNs like Facebook contain billions of user profiles and the service providers ensure that their data is protected which makes the process of data collection very challenging for researchers. OSN datasets are not publicly available because of privacy reasons and since the data is enormous, collecting it manually makes the task complex and time-consuming. However, most popular social networking sites like Facebook, Twitter, Flickr, etc. provide methods for retrieving information from the network through their own well defined Application Programming Interfaces (APIs) like Graph-API1, REST-API2 etc., but these APIs are associated with several unavoidable 1 https://developers.facebook.com/docs/graph-api 2 https://dev.twitter.com/rest/public constraints such as data request rate restrictions, selective data access, etc. Web scrapping provides an alternative solution by automatically extracting the information from the web pages in a systematic manner. Although it can solve the problem of data collection to a great extent but writing a scrapper is itself a challenging task. Generally, social media platforms including Facebook have inbuilt bot detection mechanism (Stein et al., 2011) which can recognize an automated activity on their platforms and, therefore data collection by means of software programs may lead to the suspension of the user account which is being used for data extraction. The feature of dynamic loading of content via various web technologies (e.g. JavaScript and Ajax) further complicates the task since this information is not available in the source code of a web page. Moreover, the call to dynamic content on the web page is mostly triggered by user interactions with the page which implies that there should be a mechanism to automate these interactions in order to load this dynamic content into the parent HTML document. Therefore, there is a need for a tool which is capable of circumventing the API constraints and can overcome the data scrapping barriers. The paper focuses on the designing of data crawler, IMcrawler for a Facebook network that addresses the above-discussed challenges and assists the end user in extracting the data in an efficient and convenient manner. Facebook is one of the topmost networking sites and has the most complex privacy policy structure. It’s API can be used to extract data from only those users who are already registered with the application. Unlike Twitter API, the Facebook API has to explicitly ask for permissions from its members to access their data. Users’ privacy settings and privileges granted to the application will decide the data that can be scrapped from their profiles. Facebook has also imposed constraints on the maximum request rate to limit the amount of data being scrapped. The crawler proposed in this paper does not face any of these hurdles and is able to extract every information of any amount which appears on the user profile. It is also capable of interacting with Timeline to load the dynamic content. The complete framework of the data collection is also described with step wise processes followed from crawling the network to obtain the featured dataset in a useful format. The crawler has been designed to extract two broad sections viz profile information (profile features) and wall activities (post features), particularly from the friends of a profile. Profile information consists of details provided by the users about themselves and wall activities consist of actions performed by the users on the Timeline. The collected information is divided into two datasets. The first dataset represents the attributes of a profile and the second dataset holds the post information. The remaining article is structured as follows: Initially, in section 2, the work relevant to data extraction from social networks and analysis on the information revealed by users has been discussed. Section 3 describes the novel contribution of the proposed work. The design of the IMcrawler and it's working have been explained in section 4. Finally, the section 5 concludes the overall work and provides future directions. 2. Related Work Given the massive amount of online user data, its extraction is the key challenge for the researchers. One of the most recent studies (Zhou, D. et al., 2018) presented a detailed survey on the existing data collection methods, mechanisms and architectures along with some open challenges associated with the process of data collection. The authors (Ferrara et al., 2014) in one more study has presented a detailed discussion on web data extraction techniques along with the application domains in which they are applied. In general, APIs and HTML scrapping are the two popular ways to retrieve data from OSNs. Although APIs provide well-organized data but with several restrictions. The HTML scrapping techniques offer an alternative solution that can circumvent the limitations imposed by APIs but at the price of technical complexities. The paper (Maynard et al., 2017) presented a semantic- based framework for collecting the social media data using APIs and analyzing it by the open source tools provided by GATE family3. The authors in (Mislove et al. 2007) have analyzed the structure of several popular OSNs such as YouTube, Flicker, LiveJournal, etc. The study has used the APIs provided by these OSNs and HTML scrapping technique in order to extract the required data. Data extraction schemes significantly depend on the policy of online 3 https://gate.ac.uk/family social networks as in (Alim et al., 2009), the authors have presented the process of extracting personal attributes and the list of top friends from MySpace social network without being its member. A study (Rungsawang et al., 2005) highlights the pros and cons of the existing data crawlers and proposed an algorithm to resolve the issues associated with previous data crawlers. MySpace provides a rich source of data to the nonmembers as well, whereas networks like Facebook, Friendster etc. expose either no content or minimal content to the external users. Several studies have been carried out on the Facebook network exclusively since it is one of the most popular online social networking websites and has the most complex privacy mechanism (Dwyer et al., 2007, Acquisti et al., 2006). Netviz (Rieder, 2013) is a Facebook application designed to help researchers in collecting features of a profile including personal networks, groups, and pages. However, just like any other API, the working of Netvizz application is also limited by the permission and privacy model of the Facebook service. First, it requires logged in Facebook account. Second, it explicitly asks the user for the permission to access their different data and third, the user can further restrict the data availability to the application by their privacy settings. In (Wong et al., 2014), the authors have implemented an HTML-based crawler by using PhantomJS, a headless browser4, to extract the friend's network of Facebook users of a specific region in Macau. In addition, authors have also discussed the technical challenges and their viable solutions while designing the data extractor for OSNs. OSN sites offer a great medium to its users to share varied amount of social as well as personal details with either all the members of the network or a specific community of users (Javed, M.
Recommended publications
  • An Overview of the 50 Most Common Web Scraping Tools
    AN OVERVIEW OF THE 50 MOST COMMON WEB SCRAPING TOOLS WEB SCRAPING IS THE PROCESS OF USING BOTS TO EXTRACT CONTENT AND DATA FROM A WEBSITE. UNLIKE SCREEN SCRAPING, WHICH ONLY COPIES PIXELS DISPLAYED ON SCREEN, WEB SCRAPING EXTRACTS UNDERLYING CODE — AND WITH IT, STORED DATA — AND OUTPUTS THAT INFORMATION INTO A DESIGNATED FILE FORMAT. While legitimate uses cases exist for data harvesting, illegal purposes exist as well, including undercutting prices and theft of copyrighted content. Understanding web scraping bots starts with understanding the diverse and assorted array of web scraping tools and existing platforms. Following is a high-level overview of the 50 most common web scraping tools and platforms currently available. PAGE 1 50 OF THE MOST COMMON WEB SCRAPING TOOLS NAME DESCRIPTION 1 Apache Nutch Apache Nutch is an extensible and scalable open-source web crawler software project. A-Parser is a multithreaded parser of search engines, site assessment services, keywords 2 A-Parser and content. 3 Apify Apify is a Node.js library similar to Scrapy and can be used for scraping libraries in JavaScript. Artoo.js provides script that can be run from your browser’s bookmark bar to scrape a website 4 Artoo.js and return the data in JSON format. Blockspring lets users build visualizations from the most innovative blocks developed 5 Blockspring by engineers within your organization. BotScraper is a tool for advanced web scraping and data extraction services that helps 6 BotScraper organizations from small and medium-sized businesses. Cheerio is a library that parses HTML and XML documents and allows use of jQuery syntax while 7 Cheerio working with the downloaded data.
    [Show full text]
  • Web Data Extraction
    MASTER THESIS Tom´aˇsNovella Web Data Extraction Department of Software Engineering Supervisor of the master thesis: doc. RNDr. Irena Holubov´a,Ph.D. Study programme: Computer Science Study branch: Theoretical Computer Science Prague 2016 I declare that I carried out this master thesis independently, and only with the cited sources, literature and other professional sources. I understand that my work relates to the rights and obligations under the Act No. 121/2000 Sb., the Copyright Act, as amended, in particular the fact that the Charles University has the right to conclude a license agreement on the use of this work as a school work pursuant to Section 60 subsection 1 of the Copyright Act. In ........ date ............ signature of the author i Title: Web Data Extraction Author: Tom´aˇsNovella Department: Department of Software Engineering Supervisor: doc. RNDr. Irena Holubov´a,Ph.D., department Abstract: Creation of web wrappers (i.e programs that extract data from the web) is a subject of study in the field of web data extraction. Designing a domain- specific language for a web wrapper is a challenging task, because it introduces trade-offs between expressiveness of a wrapper’s language and safety. In addition, little attention has been paid to execution of a wrapper in restricted environment. In this thesis, we present a new wrapping language – Serrano – that has three goals in mind. (1) Ability to run in restricted environment, such as a browser extension, (2) extensibility, to balance the tradeoffs between expressiveness of a command set and safety, and (3) processing capabilities, to eliminate the need for additional programs to clean the extracted data.
    [Show full text]
  • Leukemia Medical Application with Security Features
    Journal of Software Leukemia Medical Application with Security Features Radhi Rafiee Afandi1, Waidah Ismail1*, Azlan Husin2, Rosline Hassan3 1 Faculty Science and Technology, Universiti Sains Islam Malaysia, Negeri Sembilan, Malaysia. 2 Department of Internal Medicine, School of Medicine, Universiti Sains Malaysia, Kota Bahru, Malaysia. 3 Department of Hematology, School of Medicine, Universiti Sains Malaysia, Kota Bahru, Malaysia. * Corresponding author. Tel.: +6 06 7988056; email: [email protected]. Manuscript submitted January 27, 2015; accepted April 28, 2015 doi: 10.17706/jsw.10.5.577-598 Abstract: Information on the Leukemia patients is very crucial by keep track medical history and to know the current status of the patient’s. This paper explains on development of Hematology Information System (HIS) in Hospital Universiti Sains Malaysia (HUSM). HIS is the web application, which is the enhancement of the standalone application system that used previously. The previous system lack of the implementation of security framework and triple ‘A’ elements which are authentication, authorization and accounting. Therefore, the objective of this project is to ensure the security features are implemented and the information safely kept in the server. We are using agile methodology to develop the HIS which the involvement from the user at the beginning until end of the project. The user involvement at the beginning user requirement until implemented. As stated above, HIS is web application that used JSP technology. It can only be access within the HUSM only by using the local Internet Protocol (IP). HIS ease medical doctor and nurse to manage the Leukemia patients. For the security purpose HIS provided password to login, three different user access levels and activity log that recorded from each user that entered the system Key words: Hematology information system, security feature, agile methodology.
    [Show full text]
  • Computer Science) Thesis Title
    MS (Computer Science) Thesis title: Formal Automated Testing of an Information Management System Submitted by: Rozina Kamil Roll no. 11 Reg. no: IU15M2LA011 Supervised by: Dr. Nadeem Akhtar i Title Formal Automated Testing of an Information Management System By Rozina Kamil Roll no. 11 Reg. no: IU15M2LA011 Thesis submitted for the partial fulfilment of the requirement for the degree of MASTER OF SCIENCE In COMPUTER SCIENCE Department of Computer Science & IT The Islamic University of Bahawalpur - PAKISTAN Fall 2015-17 i DECLARATION Formal Automated Testing of an Information management System published source (except the references, standard mathematical or geometrical models/equations /formulae /protocols etc.). I further declare that this work has not been submitted for award of any other diploma/degree. The university may take action if information provided is found inaccurate at any stage. (In case of default, the scholar will be proceeded against as per HEC plagiarism policy). Rozina Kamil Roll no. 11 Reg no. IU15M2LA011 ii To, The Controller of Examinations The Islamia University of Bahawalpur, Pakistan We, the supervisory committee, certify that the contents and format of thesis titled Formal Automated testing of an information management system submitted by Rozina Kamil, Roll no. 11, and Registration no. IU15M2LA011 have been found satisfactory and recommend that it be processed for evaluation by the External Examiner(s) for the award of degree. Supervisor Dr. Nadeem Akhtar Department of Computer Science & IT The Islamia University of Bahawalpur Pakistan iii Dedication I dedicate my dissertation work to my all family members, friends, class mates and my supervisor. It cannot be possible for their sincere support and encourage.
    [Show full text]
  • Download Free Internet Explorer Latest Version 9
    Download free internet explorer latest version 9 Download Internet Explorer 9 for Windows now from Softonic: % safe and virus free. More than downloads this month. Download Internet Explorer 9. Internet Explorer 9, free and safe download. Internet Explorer 9 latest version: Microsoft's browser is becoming more up-to-date. The classic Microsoft browser. Internet Explorer 9 9 free download. Get new version of Internet Explorer 9. A PC program for surfing the web ✓ Free ✓ Updated ✓ Download now. Security, ease of use, and improvements in RSS, CSS, and Ajax support are Microsoft's priorities for Internet Explorer. This version of IE runs on. For faster and richer experience on the web, adopt Internet Explorer 9! The browser's image changes with this software because it uses the full. Windows Internet Explorer 9 (IE9) is a version of the Internet Explorer web browser from From Wikipedia, the free encyclopedia . Internet Explorer 9 Beta, , New user interface, download manager, and feedback issue with Internet Explorer 9 and the latest version of Windows Live Sign-in Assistant. Microsoft's Internet Explorer 9 (IE9) beta now available to the masses. have done in planning, developing, and releasing the latest version of Internet Explorer. Windows Internet Explorer 9 delivers web sites and applications that look and perform like native PC applications through the power of Windows. It has support. Internet Explorer 9 free download. Get the latest version now. The 9th version of the world's most popular web browser. Download the latest version of Internet Explorer free. The newest version of Windows, 7, includes the latest Internet Explorer 9, which is a true.
    [Show full text]
  • Ringer: Web Automation by Demonstration
    Ringer: Web Automation by Demonstration Shaon Barman Sarah Chasins Rastislav Bodik University of California, Berkeley University of California, Berkeley University of Washington (USA) (USA) (USA) [email protected] [email protected] [email protected] rtifact A Comple * t * te * n * A te Sumit Gulwani is W E s A e n C l l L o D C S o * * c P u e m s E u O e e n v R Microsoft Research (USA) t e O o d t a y * s E a * l u d a e [email protected] t Abstract scrape data for their studies and journalists for their stories (the investigative news organization ProPublica hires pro- With increasing amounts of data available on the web and a grammers to develop web scrapers [2]). Overall, the interest diverse range of users interested in programmatically access- in web automation is growing: the number of StackOverflow ing that data, web automation must become easier. Automa- questions on “scraping” grew by 16% in 2014 and 23% in tion helps users complete many tedious interactions, such as 2015 [34], and commercial scrapers such as Kimono [25] and scraping data, completing forms, or transferring data between import.io [22] appeared during the last three years. websites. However, writing web automation scripts typically Writing good web automation scripts is challenging. Since requires an expert programmer because the writer must be some websites do not offer APIs for accessing their data, able to reverse engineer the target webpage. We have built a retrieving the data programmatically requires reverse engi- record and replay tool, Ringer, that makes web automation neering their webpages’ DOM tree structures and event han- accessible to non-coders.
    [Show full text]
  • Acamia: Automating Configuration Across Multiple Interactive
    ACaMIA: Automating Configuration across Multiple Interactive Applications Paper # 22 — 14 pages ABSTRACT browser [3]) or require changes to the operating system ker- nel to track dependencies across applications [15], which Desktop setup and configuration is a common task in any makes them unacceptable to most organizations, which are computing environment, and its automation would save committed to using a stock, proprietary, off the shelf oper- time and money. Existing automation tools are generally ating system. application-specific (i.e., macros). Most non-trivial config- This paper introduces ACaMIA, a new approach for uration tasks, however, have dependencies across applica- automating configuration updates. The basic idea behind tions. To allow automation in an application-independent ACaMIA is to 1) record the graphical user interface actions manner, past work circumvents the GUI by modifying the that an initial, small set of users take when they perform kernel to track causal dependencies across applications and the configuration update, 2) combine the resulting traces to then taking diffs of the affected files. Such kernel modifica- extract a parameterized sequence of GUI actions that to- tions, however, are unsuitable for the commercial operating gether accomplish the update, and 3) apply this sequence systems typical in the desktop environment, and file diffs on demand to automatically perform the update to other are fragile in the face of complex, application-specific and machines. A key insight behind this approach is the iden- binary file formats. tification of the graphical user interface as the appropriate This paper introduces ACaMIA, a tool that uses a new interposition layer for recording and replaying configura- approach to automating configuration.
    [Show full text]
  • Syndicate Framework 55 Table of Contents Ix
    Individual Service Composition in the Web-age Inauguraldissertation zur Erlangung der Wurde¨ eines Doktors der Philosophie vorgelegt der Philosophisch-Naturwissenschaftlichen Fakultat¨ der Universitat¨ Basel von Sven Rizzotti aus Basel Basel, 2008 Genehmigt von der Philosophisch-Naturwissenschaftlichen Fakult¨atauf Antrag von Herrn Prof. Dr. Helmar Burkhart, Universit¨atBasel und Herrn Prof. Dr. Gustavo Alonso, ETH Z¨urich, Korreferent. Basel, den 11.12.2007 Prof. Dr. Hans-Peter Hauri, Dekan To my parents, Heide and Fritz Rizzotti and my brother J¨org. On the Internet, nobody knows you're a dog. Peter Steiner cartoon in The New Yorker (5 July 1993) page 61 Abstract Nowadays, for a web site to reach peak popularity it must present the latest information, combined from various sources, to give an interactive, customizable impression. Embedded content and functionality from a range of specialist fields has led to a significant improvement in web site quality. However, until now the capacity of a web site has been defined at the time of creation; extension of this capacity has only been possible with considerable additional effort. The aim of this thesis is to present a software architecture that allows users to personalize a web site themselves, with capabilities taken from the immense resources of the World Wide Web. Recent web sites are analyzed and categorized according to their customization potential. The results of this analysis are then related to patterns in the field of software engineering and from these results, a general conclusion is drawn about the requirements of an application architecture to support these patterns. A theoretical concept of such an architecture is proposed and described in detail.
    [Show full text]
  • Test Tools and Automation
    SHOWCASING THOUGHT LEADERSHIP AND ADVANCES IN SOFTWARE TESTING Test Tools and Automation Automation Selection Criteria: Picking the Right Candidates Robert Galen, Velocity Partners Test Automation Tool Avoid Epic Fail Cheap and Free Review Get Professional Help Software Test Tools LogiGear Staff Michael Hackett & Joe Luthy Randall Rice April 2014 | Volume VIII | Issue 2 2 Letter from the Editor esting tools - very important, very often overlooked, and Editor in Chief very often where mistakes are made. Michael Hackett T First, the most common mistake people make about tools is Managing Editor thinking tools are only about test automation! False. Automa- Brian Letwin tion tools are merely one type testing tool. I heard a story, very recently in fact, of a company that paid a Deputy Editor large licensing fee to a major tool vendor, and invested a lot Joe Luthy of training and time to develop a phase 1 automation project. The intent was to scale up the initial phase into a large prod- uct suite automated regression tool. After just 6 months the Worldwide Offices project was dropped due to high test maintenance costs, over- idealized expectations and time demands. A whole lot of mon- United States Headquarters ey went down the drain! I have heard too, too many of these stories with test tools, and 2015 Pioneer Ct., Suite B specifically automation tools. San Mateo, CA 94403 Tel +01 650 572 1400 This story is not new. I heard nearly the same thing in 1994. This really highlights the need to address things like designing code for testability, high reusability automation Fax +01 650 572 2822 frameworks, lower maintenance test design, unrealistic tool vendor marketing, unrealistic staff expectation, etc.
    [Show full text]
  • Optimizing Software Quality Through Automation Testing Ankit Sharma
    St. Cloud State University theRepository at St. Cloud State Culminating Projects in Mechanical and Department of Mechanical and Manufacturing Manufacturing Engineering Engineering 1-2017 Optimizing Software Quality through Automation Testing Ankit Sharma Follow this and additional works at: https://repository.stcloudstate.edu/mme_etds Recommended Citation Sharma, Ankit, "Optimizing Software Quality through Automation Testing" (2017). Culminating Projects in Mechanical and Manufacturing Engineering. 65. https://repository.stcloudstate.edu/mme_etds/65 This Starred Paper is brought to you for free and open access by the Department of Mechanical and Manufacturing Engineering at theRepository at St. Cloud State. It has been accepted for inclusion in Culminating Projects in Mechanical and Manufacturing Engineering by an authorized administrator of theRepository at St. Cloud State. For more information, please contact [email protected]. Optimizing Software Quality through Automation Testing by Ankit Sharma A Starred Paper Submitted to the Graduate Faculty of St. Cloud State University in partial Fulfillment of the Requirements for the Degree Master of Engineering Management December, 2016 Starred Paper Committee: Ben Baliga, Chairperson Hiral Shah Balasubramanian Kasi 2 Abstract The current business application is large, multi-tired, distributed and integrated which require higher level of sophistication to implement and manage. The current quality methodologies rely on manual work which makes the application venerable due to its limitation and entails higher cost. Running complete regression suite manually every time is cumbersome and often do not complete due to either time or resource limitation. Finding more defects during testing life cycle has tremendous effect on the quality of an application. This project is intended to run more number of tests in lesser time and reduction in overall cost of the project and this has been achieved by implementing an automation tool.
    [Show full text]
  • Internet Explorer
    Internet Explorer From Wikipedia, the free encyclopedia Jump to: navigation, search Windows Internet Explorer Wikipedia's Main Page in Windows Internet Explorer 7 running on Windows Vista. Developed by Microsoft Initial release August 1995 (12–13 years ago) Latest release 7.0.5730.13 (Windows XP/Windows 2003 Server) 7.0.6001.18000 (Windows Vista SP1) / 2008 Preview release 8.0.6001.17184 (IE8, Beta 1) / March 5, 2008 OS Microsoft Windows Mac OS System 7 to Mac OS X (discontinued) Solaris and HP-UX (discontinued) Genre Web browser and RSS Reader License Proprietary EULA Website microsoft.com/ie Windows Internet Explorer (formerly Microsoft Internet Explorer abbreviated MSIE), commonly abbreviated to IE, is a series of graphical web browsers developed by Microsoft and included as part of the Microsoft Windows line of operating systems starting in 1995. It has been the most widely used web browser since 1999, attaining a peak of about 95% usage share during 2002 and 2003 with IE5 and 6 but steadily declining since, despite the introduction of IE7. Microsoft spent over 100 million dollars (USD) a year [1] in the late 1990s, with over 1000 people working on IE by 1999. [2] Internet Explorer was first released as part of the add-on package Plus! for Windows 95. Later versions were available as free downloads, or in service packs, and included in the OEM service releases of Windows 95 and later versions of Windows. The most recent release is version 7.0, which is available as a free update for Windows XP Service Pack 2, and Windows Server 2003 with Service Pack 1 or later, Windows Vista, and Windows Server 2008.
    [Show full text]
  • Web Automation by Demonstration
    Ringer: Web Automation by Demonstration Shaon Barman Sarah Chasins Ras Bodik University of California, Berkeley University of California, Berkeley University of Washington (USA) (USA) (USA) [email protected] [email protected] [email protected] rtifact A Comple * t * te n * A * te Sumit Gulwani is W E s A e n C l l L o D C S o * * c P u e m s E u O e e n v R Microsoft Research (USA) t e O o d t a y * s E a * l u d a e [email protected] t Abstract scrape data for their studies and journalists for their stories (the investigative news organization ProPublica hires pro- With increasing amounts of data available on the web and a grammers to develop web scrapers [2]). Overall, the interest diverse range of users interested in programmatically access- in web automation is growing: the number of StackOverflow ing that data, web automation must become easier. Automa- questions on “scraping” grew by 16% in 2014 and 23% in tion helps users complete many tedious interactions, such as 2015 [34], and commercial scrapers such as Kimono [25] and scraping data, completing forms, or transferring data between import.io [22] appeared during the last three years. websites. However, writing web automation scripts typically Writing good web automation scripts is challenging. Since requires an expert programmer because the writer must be some websites do not offer APIs for accessing their data, able to reverse engineer the target webpage. We have built a retrieving the data programmatically requires reverse engi- record and replay tool, Ringer, that makes web automation neering their webpages’ DOM tree structures and event han- accessible to non-coders.
    [Show full text]