580 likes | 715 Views
Developing Dynamic Web Pages Without Programming. Chia-Han Liu Helen Kleytman Pooja Garg Yih-Tsung Chiang Yingfeng Su. Research Project Led By: Professor David Wolber. Agenda. Problems with Traditional Web Development Our solution: WebSheets WebSheets Demo System Internals
E N D
Developing Dynamic Web PagesWithout Programming Chia-Han Liu Helen Kleytman Pooja Garg Yih-Tsung Chiang Yingfeng Su Research Project Led By: Professor David Wolber
Agenda • Problems with Traditional Web Development • Our solution: WebSheets • WebSheets Demo • System Internals • XML Extension • Conclusion
Problems of Traditional Web Development • Presentation and logic are mixed together • Artists/Designers can’t write code • Artists/Designers must know SQL well to generate dynamic contents from database
Solution:Integrated Development Environment • Macromedia DreamWeaver UltraDev4 • IBM Websphere Studio • ASPapp
Our Solution: WebSheets • Programming by Demonstration • Query by Example • Spreadsheet Functions Designers J2EE WebSheets IDE JDBC Servlet XMLC
What is an Application Server? Information Information Client Client Information Information SERVER Client Client
BEA WeblogicServer Side Services: • HTTP Servlets - Composition of Dynamic Web Pages • JDBC - Allows Java programs to access databases
HTTP Servlets HTTPResponse SERVLET HTTPRequest Client SERVER
JDBC Architecture Servlets JDBC Interface Driver (Oracle) Driver (ODBC) Driver (Sybase) Oracle DB MSAccess Sybase
HTTPServlet Designersand Programmers
Templates: Separating the Tasks of Designers and Programmers Designers Programmers HTML Template servlet code including DOM manipulation code and JDBC code XMLC Java DOM tree code HTML Output
JAVA DOM Manipulation Code Instance of XMLC Generated class XMLC provided Access functions
WebSheets Kills Programmers Programmers X Designers HTML Template servlet code including DOM manipulation code and JDBC code XMLC Java DOM tree code HTML Output
Demo • Bookstore scenario A bookstore manager who knows little about programming wants to create a dynamic page for customers to search books by title
WYSIWYG Editor • Format of the text • Hyperlinks • Images • Static tables • Dynamic tables • Preview
Wizard Bar • A context-sensitive guide • Response every time an action is finished • List several possible further steps
Centralized Configuration • Administrator can set up the server addresses and database pool names • Our system records these configuration • User doesn’t need to know the detail of IP and pool • Easy deployment
Multiple Document • Users can set up the relation between buttons and pages • Destination page needs incoming information
Code Generation WYSIWYG specs WebSheets Code Generator HTML Template servlet code including DOM manipulation code and JDBC code XMLC Java DOM tree code HTML Output
Code Generation Class GeneratedServlet extends HTTPServlet { // other methods public void act_delete(HttpServletRequest req, HttpServletRespons res) { // Access request parameters String minStock = req.getParameter(“MinStock”); // Access DOM tree created from HTML template BookListDOM doc = new BookListDOM(); Node tempRow = doc.getElementTempRow(); // Execute specified delete operations using JDBC // and SQL Delete statements stmt.execute("delete from BOOKS where INSTOCK<" + minStock); // Execute the specified Select statement to obtain // a resultset. rs =stmt.executeQuery("select * from BOOKS”);
Code Generation while(rs.next()) { // Use DOM manip. code to enter values in the // DOM tree. doc.setText_table1_col0(rs.getString(1)); doc.setText_table1_col1(rs.getString(2)); doc.setText_table1_col2(rs.getString(3)); // Evaluate the spreadsheet formulasdoc.setText_table1_col3( String.valueOf(rs.getInt(2) * rs.getInt(3))); // Clone the sample row tempRow.getParentNode().insertBefore( tempRow.cloneNode(true), tempRow); } // Remove the sample row tempRow.getParentNode().removeChild(tempRow); // Write the updated DOM tree to the browser out.println(doc.toDocument()); }
Code Generation • The service() method uses Java Reflection to dispatch the request to the corresponding handler public void service(HttpServletRequest req, HttpServletResponse resp) { String action = req.getParameter("act"); String mtdname = "act_" + action; Class[] paratypes = new Class[] { Class.forName("javax.servlet.http.HttpServletRequest”), Class.forName("javax.servlet.http.HttpServletResponse") }; Method mtd = this.getClass().getMethod(mtdname, paratypes); mtd.invoke(this, new Object[]{req, resp}); } // public void act_add(HttpServletRequest req, HttpServletResponse resp) { … } // public void act_delete(HttpServletRequest req, HttpServletResponse resp) { … }
Objective WebSheets Store & Retrieve Data Store & Retrieve Data Databases XML Files
XML Extension. Why? • Pros • search engine • data transfer • hierarchical • Cons • triggers • security • queries across multiple tables
Code Generation Model abstract class StorageProxy abstract void genAdd(); abstract void genDelete(); abstract void genSelect(); class JDBC_Storage void genAdd(); void genDelete(); void genSelect(); class XML_Storage void genAdd(); void genDelete(); void genSelect();
Reusability abstract class StorageProxy abstract void genAdd(); abstract void genDelete(); abstract void genSelect(); class Other_Storage class Other_Storage class JDBC_Storage void genAdd(); void genDelete(); void genSelect(); class XML_Storage void genAdd(); void genDelete(); void genSelect();
DOM ARCHITECTURE Java Tree XML Document XML Parser Object Object Object Object Object
Manipulation of the DOM tree Java Tree Object Servlet Hot Spots Object Object Object Object Object Object
act_add(String value) Step1 ROOT Object Object child child child child Object child child child child child child child child Object Object child child child child child child child child
act_add(String value) Step2 ROOT Object Object child child child child Object child child child child child child child child Object Object child child child child child child child child