| |
| <html> |
| <head> |
| <meta http-equiv="content-type" content="text/html;charset=iso-8859-1"> |
| <title>Websh - Welcome</title> |
| <script language="JavaScript" src="buttons.js"></script> |
| <link href="websh.css" rel="styleSheet" type="text/css"> |
| <meta name="description" content="Websh - the rapid development environment to build powerful web applications."> |
| <META NAME="keywords" CONTENT="websh, Websh, e-commerce, web application, apache, perl, php, asp, cold fusion"> |
| </head> |
| |
| <body marginwidth="0" marginheight="0" topmargin="0" leftmargin="0" |
| bgcolor="#ffffff" link="#006699" alink="red" vlink="#006699"> |
| |
| <map name="grafik_navi"> |
| <area href="mailto:websh-dev@tcl.apache.org" coords="94,2,154,26" shape="rect"> |
| <area href="./" coords="4,2,64,26" shape="rect"> |
| <area href="contact.html" coords="184,2,244,26" shape="rect"> |
| </map> |
| <table border="0" cellpadding="0" cellspacing="0" width="100%" height="76"> |
| <tr valign="top"> |
| |
| <td width="500" bgcolor="#006699"><img height="50" width="300" src="images/grafik_navi_home.gif" alt="" border="0" usemap="#grafik_navi"><img height="50" width="200" src="images/grafik_index.gif" alt=""></td> |
| |
| <td><img height="50" width="270" src="images/logo.gif" alt="Websh"></td> |
| <td width="5000" bgcolor="#000000"> </td> |
| </tr> |
| <tr> |
| <td width="500"> |
| <table border="0" cellpadding="0" cellspacing="0" width="500" height="40"> |
| |
| <tr bgcolor="#006699"> |
| <td><a href="/websh/product.html" onmouseover="swap('prod','b_prod_b')" onmouseout="swap('prod','b_prod_a')"><img height="20" width="120" src="/websh/buttons/b_prod_a.gif" name="prod" border="0" alt="product description"></a></td> |
| <td width="100"><br></td> |
| <td><a href="/websh/support.html" onmouseover="swap('supp','b_supp_b')" onmouseout="swap('supp','b_supp_a')"><img height="20" width="70" src="/websh/buttons/b_supp_a.gif" name="supp" border="0" alt="support"></a></td> |
| <td><a href="/websh/resources.html" onmouseover="swap('ress','b_ress_b')" onmouseout="swap('ress','b_ress_a')"><img height="20" width="110" src="/websh/buttons/b_ress_a.gif" name="ress" border="0" alt="resources and links"></a></td> |
| <td><a href="/websh/download.html" onmouseover="swap('down','b_down_b')" onmouseout="swap('down','b_down_a')"><img height="20" width="100" src="/websh/buttons/b_down_a.gif" name="down" border="0" alt="download"></a></td> |
| </tr> |
| <tr height="20"> |
| <td width="120" height="20"><img height="20" width="120" src="images/title.gif"></td> |
| <td width="100" height="20"><img height="20" width="100" src="buttons/b_docu_c.gif"></td> |
| <td width="70" height="20"><img height="20" width="70" src="images/title.gif"></td> |
| <td width="110" height="20"><img height="20" width="110" src="images/title.gif"></td> |
| <td width="100" height="20"><img height="20" width="100" src="images/title.gif"></td> |
| </tr> |
| |
| </table> |
| </td> |
| <td><img height="40" width="270" src="images/logo_strich.gif"></td> |
| </tr> |
| </table> |
| |
| <div style="padding: 15px; color:#fff; background-color: #069; font-weight: bold; width: 730px; margin: 5px;"> |
| We are sorry but we discontinued Websh support and development for lack of resources. |
| Also the discussion mailing list was closed, so if you're interested in taking up this subproject within the Apache Tcl project to bring it back into life please contact private@tcl.apache.org |
| </div> |
| |
| <table border="0" cellpadding="0" cellspacing="0" width="770"> |
| |
| <tr height="30"> |
| <td width="10" valign="top"></td> |
| <td width="150" height="30"></td> |
| |
| <td width="610" height="30"> |
| <h1>white paper</h1> |
| </td> |
| |
| </tr> |
| |
| <tr valign="top"> |
| |
| |
| <td width="10"><img height="1" border="0" width="10" src="images/stuntFFFFFF001010.gif"></td> |
| <td width="150"> |
| <table border="0" cellpadding="0" cellspacing="0" width="141"> |
| |
| |
| <tr valign="top"> |
| <td width="10"><img height="11" width="10" src="images/pfeil.gif"></td> |
| <td class=nav> |
| <a href="/websh/docu.html"><b>documentation</b></a><br> |
| |
| <br></td></tr> |
| |
| |
| <tr valign="top"> |
| <td width="10"><img height="11" width="10" src="images/pfeil.gif"></td> |
| <td class=nav> |
| <b>white paper</b><br> |
| |
| <br></td></tr> |
| |
| |
| <tr valign="top"> |
| <td width="10"><img height="11" width="10" src="images/pfeil.gif"></td> |
| <td class=nav> |
| <a href="/websh/quickref.html"><b>quick reference</b></a><br> |
| |
| <br></td></tr> |
| |
| |
| <tr valign="top"> |
| <td width="10"><img height="11" width="10" src="images/pfeil.gif"></td> |
| <td class=nav> |
| <a href="/websh/examples.html"><b>examples</b></a><br> |
| |
| <br></td></tr> |
| |
| |
| </table> |
| </td> |
| |
| |
| <td width="610"> |
| |
| <a name="1"><a href="#toc"><h1>1 Introduction</h1></a> |
| |
| This white paper describes the key features of Websh, details it's |
| architecture, and motivates design decisions. The white paper gives |
| an overview of Websh and does not replace a technical reference. |
| |
| <br><br> |
| Websh is a rapid development environment for building powerful and |
| reliable web applications. It is a standard Tcl extension and is |
| released as Open Source Software. Websh is versatile and handles |
| everything from HTML generation to data-base driven one-to-one page |
| customization. Netcetera, has been using it for years for virtually |
| all their customer projects, which are typically E-commerce shops or |
| electronic banking applications. Websh is extensible and portable, |
| and its comprehensive set of commands is easily learned. Websh can |
| be used in a standard CGI environment or as Apache 2 module. Websh |
| provides a set of commands for |
| |
| <ul> |
| <li>web transaction state management</li> |
| <li>session management (server-side sessions; various storage</li> |
| managers) |
| <li>HTML form handling</li> |
| <li>encryption</li> |
| <li>logging</li> |
| </ul> |
| |
| <br> |
| <a name="toc"><a href="#toc"><h1>2 Table of Contents</h1></a> |
| <br>1 <a href="#1"><b>Introduction</b></a><br> |
| <br>2 <a href="#toc"><b>Table of Contents</b></a><br> |
| <br>3 <a href="#28"><b>Architecture</b></a><br> |
| 3.1 <a href="#34"><b>based on Tcl</b></a><br> |
| 3.2 <a href="#73"><b>Tcl</b></a><br> |
| 3.3 <a href="#139"><b>Environment</b></a><br> |
| 3.4 <a href="#203"><b>Design</b></a><br> |
| 3.4.1 <a href="#"><b>request and URL management</b></a><br> |
| 3.4.2 <a href="#"><b>session context management</b></a><br> |
| 3.4.3 <a href="#"><b>output management</b></a><br> |
| 3.4.4 <a href="#"><b>conversion</b></a><br> |
| 3.4.5 <a href="#"><b>security by encryption</b></a><br> |
| 3.4.6 <a href="#"><b>messages on streams</b></a><br> |
| 3.4.7 <a href="#"><b>logging facility</b></a><br> |
| <br>4 <a href="#400"><b>Hello, world!</b></a><br> |
| <br>5 <a href="#416"><b>Flow of control</b></a><br> |
| <br>6 <a href="#467"><b>Commands</b></a><br> |
| 6.1 <a href="#474"><b>request and url management</b></a><br> |
| 6.2 <a href="#484"><b>session management</b></a><br> |
| 6.3 <a href="#490"><b>output management</b></a><br> |
| 6.4 <a href="#497"><b>conversion</b></a><br> |
| 6.5 <a href="#506"><b>messages</b></a><br> |
| 6.6 <a href="#512"><b>encryption</b></a><br> |
| 6.7 <a href="#517"><b>logging</b></a><br> |
| 6.8 <a href="#523"><b>misc</b></a><br> |
| <br>7 <a href="#533"><b>Security issues</b></a><br> |
| <br>8 <a href="#609"><b>Requirements</b></a><br> |
| <br>9 <a href="# "><b>Copyright</b></a><br> |
| |
| <a name="28"><a href="#toc"><h1>3 Architecture</h1></a> |
| |
| Websh is a standard Tcl extension, written in C and in Tcl. |
| It is strictly modularized and thread safe. This section |
| gives an overview of the Websh architecture. |
| |
| <a name="34"><a href="#toc"><h2>3.1 based on Tcl</h2></a> |
| |
| Websh is based on the Tool Command Language (Tcl). Tcl is a fast, |
| comprehensive scripting language as well as a library. |
| |
| The decision to build Websh on top of Tcl has several |
| advantages which can be summarized with |
| "flexibility": configurability, extensability, and portability. |
| This is illustrated in Figure 1. |
| |
| <center><img src="images/ws3ov.gif" alt=""></center><br> |
| <b>Figure 1</b> - Websh Architecture <br><br> |
| |
| Most Web-based applications need to separate items with a high change |
| rate from other, static parts. Often, the rapidly changing components |
| are those related to any aspect of output rendering (e.g., HTML |
| generation) and input processing. Application logic, on the other |
| hand, remains rather constant. Therefore, Web-based applications need |
| to support easy modification of the frequently changing parts. For |
| example, one wishes to modify HTML output without the need to |
| recompile the entire application. This means that a high level of |
| configuration flexibility is needed. |
| |
| |
| Using Tcl as an embedded system, such configurable parts can be |
| designed as Tcl code snipplets, configuration files and so on. The |
| application can call and interpret Tcl code whenever necessary. The |
| Tcl code itself can call back the C-based application and use the |
| library routines. This offers a high degree of scalablity. |
| |
| <br><br> |
| Using a scripting language for web application development thus has |
| many advantages over traditional approaches. The potential drawback |
| of an interpreted language is slower execution as compared with a |
| compiled program. Experience has shown, however, that the advantage |
| of flexibility is much more important than these potential differences |
| in execution speed. |
| |
| <br><br> |
| <a name="73"><a href="#toc"><h2>3.2 Tcl</h2></a> |
| |
| The Tool Command Language (Tcl, pronounced "tickle"), was created by |
| John Ousterhout. Tcl development started 1987 at the University |
| of California at Berkeley. Today, Ousterhout is CEO of "Scriptics |
| Corporation", which continues to develop Tcl, and markets value added |
| products for Tcl. Worldwide, about half a million programmers rely on |
| Tcl. |
| |
| <br><br> |
| The Tcl platform was designed with the philosophy in mind |
| that one should actually |
| use two or more languages when designing large software systems. One for |
| manipulating complex internal data structures or where performance is key, |
| and another, such as Tcl, for writing smallish scripts that tie together |
| the other pieces, providing hooks for the user to extend. |
| |
| <br><br> |
| For the Tcl-script writer, ease of learning, ease of programming and |
| ease of glueing are more important than performance or facilities for |
| complex data structures and algorithms. Tcl was designed to make it |
| easy to drop into a lower language when you come across tasks that |
| make more sense at a lower level. In this way, the core functionality |
| can remain small and one needs only to bring along pieces that one |
| particularly wants or needs. |
| |
| <br><br> |
| Tcl is actually two things: a language and a library. First, Tcl is a |
| powerful textual language, intended primarily for issuing commands to |
| interactive programs such as text editors, debuggers, illustrators, |
| and shells. It has a simple syntax and is programmable, allowing Tcl |
| users to write command procedures to extend the built-in set of |
| commands. Further more, the library provides a wide range of |
| functions for OS abstraction and container management, which can be |
| used without the Tcl language itself. |
| |
| <br><br> |
| Second, Tcl is a library package that can be embedded in application |
| programs. The Tcl library consists of a parser for the Tcl language, |
| routines to implement the Tcl built-in commands, and procedures that allow |
| applications to extend Tcl. The application program generates Tcl |
| commands and passes them to the Tcl parser for execution. The parser |
| executes built-in commands directly, and uses the call-back method for |
| application-specific commands. |
| |
| <br><br> |
| This design allows three-tiered applications, having a middle-tier that |
| represents "business objects". The middle tier is the C-application, while |
| the third tier consists mainly of the Tcl code, which renders various views |
| of the business objects for the display e.g. in browsers. Embedding Tcl |
| gives Websh the flexibility needed in Web environments. It allows |
| combining state-of-the-art software engineering with the speed of HTML |
| publishing and separates these two development cycles. |
| |
| <br><br> |
| Tcl has been ported to all major operating systems. It is easily |
| extensible, and Tcl extensions like Websh can profit from |
| third-party extensions as well. Additional functionality, e.g., |
| application-specific commands written in C/C++, can be dynamically |
| added using shared libraries (on Unix platforms) or dynamic link |
| libraries (Microsoft Windows platforms). Such libraries are used, for |
| example, for database connectivity. This makes change management much |
| easier, since modules are clearly separated, ensures quick loading of |
| code, and does not affect a running system. |
| |
| <br><br> |
| <a name="139"><a href="#toc"><h2>3.3 Environment</h2></a> |
| |
| Websh is a Tcl extension. It can be run as a stand-alone application, |
| or it can be dynamically loaded into a Tcl application. In a Web |
| environment, Websh is run in a CGI environment (Common Gateway |
| Interface) or as Apache 2 module. |
| |
| Websh has been designed to ease the implementation of dynamic |
| content within WWW servers. There are several techniques in use to |
| provide such dynamic content: |
| |
| <ul> |
| <li>Server-side includes (SSI): This technique is available with several</li> |
| WWW servers (HTTP servers). It based on a custom extension to |
| HTML, which is parsed by the server whenever the corresponding |
| document is requested. These extensions contain directives for |
| conditional text and text substitution. This technique is only |
| suitable for applications where text substitution is possible, |
| that is, for simple replacements in the document. It also strongly |
| depends on the server software used, as there is no widely |
| accepted standard for the syntax. Products using this technique |
| include ASP or JSP. |
| </ul> |
| |
| <ul> |
| <li>Custom HTTP servers: Most off-the-shelf WWW-servers serve static</li> |
| contents from a repository, which typically is a file system or a |
| database management system. It might make sense for some |
| applications to manage the HTTP-protocol themselves, i.e., to act |
| as custom HTTP servers, having the full freedom on how the results |
| of HTTP requests are returned. This technique is the most |
| flexible. However, there is much application overhead introduced |
| in properly (and efficiently) handling HTTP-requests, that this |
| method is only sensible for very specific applications. |
| </ul> |
| |
| <ul> |
| <li>CGI-Applications: Often dynamic content is managed using the Common</li> |
| Gateway Interface (CGI). The widespread use of CGI is basically |
| due to its simplicity. The CGI specification relies on |
| POSIX-compliant execution of child processes. Parameter passing |
| happens via command line arguments, environment variables and |
| standard I/O. CGI has become the most popular technique for |
| dynamic content because it is standardized (not by an official |
| standardization body, but as an "industry-standard"). |
| </ul> |
| |
| <ul> |
| <li>Embedded handlers and modules: Most current WWW server software</li> |
| products support a direct extension through a specific API (e.g., |
| NSAPI for Netscape products, ISAPI with Microsoft Information |
| Server, "modules" for Apache-based Products). This method is |
| probably the most efficient, since there is a tight binding |
| between server and extension. On the other hand, this solution is |
| dependent on the WWW server used. Java servlets can be considered |
| to fall into this category. |
| </ul> |
| |
| <br><br> |
| Websh employes the latter two techniques. Its CGI interface |
| ensures that Websh can be employed virtually anywhere, using |
| off-the-shelf web servers. If performance is key, Websh can be run |
| as a Apache 2 module. In this case, the server does not spend time |
| spawning child processes, and communication between web server and |
| Websh directly uses the Apache API, which is considerably faster |
| than in the CGI case. In addition, Websh applications can be split |
| into two parts, the command definition and the command call part, and |
| Apache 2 can keep the command definition part in memory. This |
| eliminates the need to re-read most parts of a Websh application |
| for every HTTP request, and further increases the responsivness of the |
| Websh application. |
| |
| <a name="203"><a href="#toc"><h2>3.4 Design</h2></a> |
| |
| Websh is strictly modularized, particularly for thread safety. Each |
| module manages its own data, and locking mechanisms are used where |
| needed. Websh modules are extensible through plug-Ins. This |
| section gives an overview of the Websh modules and shortly |
| describes their function and design. |
| |
| <dl> |
| <dt><b>request and url management</b> |
| <dd> |
| handles input from the HTTP protocol, and state |
| <dt><b>session management</b> |
| <dd> |
| session data handling. On the client-side using Netscape cookies, |
| and on the server-side using various storage managers |
| (file system, data base, main-memory chache) |
| <dt><b>output management</b> |
| <dd> |
| sending data back to the browser |
| <dt><b>conversion</b> |
| <dd> |
| HTML- and URI-compliant encoding of data |
| <dt><b>encryption</b> |
| <dd> |
| security by strong encryption |
| <dt><b>messages</b> |
| <dd> |
| communication over TCP/IP sockets |
| <dt><b>logging</b> |
| <dd> |
| distribution of log messages |
| </dl> |
| |
| The Websh design is illustrated in Figure 2. |
| |
| <center><img src="images/ws3arch.gif" alt=""></center><br> |
| <b>Figure 2</b> - Websh Design <br><br> |
| |
| <a name=""><a href="#toc"><h3>3.4.1 request and URL management</h3></a> |
| |
| The Websh application developer does not need to get involved with the |
| details of the HTTP protocol or the parsing of data. Rather, he |
| concentrates on the application logic and leaves the rest to Websh. |
| This module parses input from the browser, e.g. HTML form data, and makes it |
| available to Websh. In addition, it adds state to the HTTP protocol |
| using the querystring. |
| |
| One of the distinctive features of Websh is its state management |
| capability. HTTP as a protocol is usually stateless (unless the secure |
| variant SSL is used). By protocol definition, there is no information |
| which lives from access to access. This design has many advantages, like |
| simple client-server application design. If state is needed, however, it |
| makes application development more difficult. |
| |
| Web-based applications often need to carry information from one HTTP |
| transaction to the next. As an example, a user might have a preferred |
| language. Applications for electronic commerce systems, Internet |
| banking an so on also need mechanisms to identify and group |
| transactions into longer transactions which cover more than one single |
| HTTP request and its response. In other words, state needs to be |
| introduced. |
| |
| Typically, there are three methods in use to identify state: |
| |
| <ul> |
| <li>Encoding of state information in the URL</li> |
| <li>Encoding of state information in hidden form fields</li> |
| <li>Using Netscape Cookies.</li> |
| </ul> |
| |
| Websh is designed to use all of these methods. However, the first is |
| Webshs preferred method. The reason to rely mainly on the URL is that |
| both hidden form fields and cookies have disadvantages: |
| |
| <ul> |
| <li>Hidden fields are only usable in forms. However, there are </li> |
| frequently cases |
| where state needs to be preserved without explicitly requiring |
| forms. Moreover, the state might be required to be "bookmarkable" |
| <li>Firewall setups can filter cookie information from the HTTP-stream in</li> |
| order to avoid external information from entering an organization. |
| Also, the user can disable cookies, and not all browsers |
| support cookies. |
| </ul> |
| |
| URL encoding, on the other hand, has the disadvantage that it produces |
| somewhat long URLs. Experience has shown that the advantages more |
| than compensate for this drawback. |
| |
| <a name=""><a href="#toc"><h3>3.4.2 session context management</h3></a> |
| |
| We have described above why web applications need state information. |
| Often, more information is needed than simply preferences. In these |
| cases, Websh relies on its session management module. |
| |
| The session management module handles session data, which can be stored on |
| the client side using Netscape cookies, or on the server side using the |
| file system (fs), a data base management system (DBMS), or the Netcetera |
| cache manager (ncm). The module provides a uniform interface to access the |
| session context regardless of the storage used. It is implemented in Tcl |
| and makes extensive use of namespaces. |
| |
| <a name=""><a href="#toc"><h3>3.4.3 output management</h3></a> |
| |
| Websh provides a set of commands to format HTTP-compliant output to |
| be sent back to the client. Output can be directed to Tcl channels or to |
| Tcl variables for buffering purposes. The technique of buffering output is |
| typically used to prepend additional information to the output |
| after the data have been processed. For example, one would like a table |
| of contents to a text document. |
| |
| <br><br> |
| Also this module has been designed with the philosophy in mind |
| that the application developer does not need to |
| care about the details of the HTTP protocol. As an example, he does not |
| track whether the MIME headers have been sent or not. Websh takes care |
| of that. |
| |
| <br><br> |
| If the developer needs control over the HTTP output, the configuration |
| facility of the output management module gives her full control over the |
| output. Of course, the output module is fully configurable, as are |
| all Websh modules. |
| |
| <a name=""><a href="#toc"><h3>3.4.4 conversion</h3></a> |
| |
| Need HTML compliant input ? Want to send data via URL, or in a form |
| field ? The conversion module makes sure that your data are properly |
| formatted, converting umlauts to their proper HTML entities or their |
| URI encoded equivalent, for example. Like every Websh module, this |
| module manages its data on its own. In order to ensure thread safety, |
| no Websh module maintains global or static variables. Such |
| variables would be shared across multiple Tcl interpreters and cause |
| conflicts. Each time an interpreter loads Websh and thus this |
| module, the module-specific data like the look-up tables for the |
| conversions will be set up, and destroyed again when the interpreter |
| is deleted. The disadvantage of this design, the duplication of data |
| in the memory of one process, is compensated by the long-term |
| stability of the process resulting from clean memory management. |
| |
| <br><br> |
| <a name=""><a href="#toc"><h3>3.4.5 security by encryption</h3></a> |
| |
| The proper handling of sensitive data is crucial for banking or |
| E-commerce applications. Three aspects are important: Data |
| transfer, data storage, and session hijacking. The first of |
| these aspects, data transfer, is not Websh's task. Websh |
| assumes that data transfer is secured whenever needed, for |
| example by means of SSL, and Websh deliberately chooses not |
| to provide any additional functionality here. |
| |
| <br><br> |
| Handling of sensitive data, on the other hand, is the task of Websh |
| and the Websh application. This is why Websh comes with a |
| strong encryption sub-system to store data securely. By default, |
| Websh encrypts the state information in every URL it generates. |
| The level of security is chosen by the application developer. She |
| selects both the encryption method and the encryption key. For highly |
| sensitive data, the application developer might not even know the |
| pass-phrase to decrypt data from the productive environment. |
| |
| <br><br> |
| Websh relies on well-known and well-tested encryption methods, |
| which are made available to Websh by means of plug-ins. Currently, |
| there are plug-Ins available for the IDEA and the blowfish encryption |
| methods, as well as for a simple encryption method for day-to-day use. |
| |
| <br><br> |
| Webshs encryption module protects data with a checksum to prevent |
| cipher tampering. For decryption, Webshs encryption sub-system |
| uses a auto-detection system to determine the encryption method. |
| |
| <br><br> |
| Note that Websh provides the framework to handle sensitive |
| data properly. The level of security, however, is determined by |
| the developer of a Websh application. |
| |
| <br><br> |
| <a name=""><a href="#toc"><h3>3.4.6 messages on streams</h3></a> |
| |
| This Websh module implements a simple protocol to facilitate |
| message-based communication over Tcl channels. Particularly, it is |
| used for communication over TCP/IP connections. |
| |
| <a name=""><a href="#toc"><h3>3.4.7 logging facility</h3></a> |
| |
| Like all service applications, web applications need a versatile |
| logging mechanism to report errors and state. In fact, Websh |
| itself makes heavy use of the logging facility. Logging must be easy |
| to use, fast, and extensible. Typically, Websh applications handle |
| hundreds of requests per second, and the logging facility has been |
| designed with this kind of load in mind. |
| |
| <br><br> |
| The Websh logging module manages a list of filters and a list of |
| destinations. Each log message comes with a &quot;address&quot; consisting |
| of a tag and a level, which is compared against two filters before the |
| message is delivered to its destination. First, an overall filter |
| determines whether or not Websh needs to process the message. Then, a second, |
| per-destination filter determines whether or not the message has to be sent |
| to the log destination. |
| |
| <br><br> |
| The Websh logging module is fully extensible through plug-Ins. |
| Out-of-the-box, Websh comes with plug-Ins to log to files, syslog, |
| Tcl channels, and Tcl |
| commands. The latter gives the application developer a simple mechanism to |
| extend the logging module by writing Tcl commands. |
| |
| <a name="400"><a href="#toc"><h1>4 Hello, world!</h1></a> |
| |
| The following example demonstrates a very simple Websh script which |
| produces the simple message <i>Hello, world</i> |
| <pre> |
| #!websh3 |
| web::command default { |
| web::put "Hello, world!\n" |
| } |
| web::dispatch |
| </pre> |
| |
| This script can be used as is as a CGI application. Websh |
| takes care of MIME-headers and other details of the HTTP |
| protocol. |
| |
| <a name="416"><a href="#toc"><h1>5 Flow of control</h1></a> |
| |
| <br><br> |
| The flow of control of a Websh application is as follows: |
| |
| <ol> |
| <li>Declaration and definition stage: Websh reads and evaluates</li> |
| the script. The command procedures defined |
| by web::command and all helper procedures are not executed |
| immediately, however (see below). |
| <li>Configuration stage: Additional configuration information is</li> |
| read. This happens after declaration, in order to allow specific |
| applications to override configuration settings and also to allow |
| logging parameters to be set in the declaration stage. This |
| allows problems in the configuration (e.g., incorrect configuration |
| information, configuration files cannot be accessed etc.) to be |
| logged accordingly. |
| <li>Initialization stage: Internal data structures are initialized,</li> |
| depending on the type of call (e.g., as CGI-application, as |
| stand-alone script). If the call was as a result of an HTTP-POST |
| message, any HTML form data is collected. At the |
| end of the initialization stage, all information provided by the |
| client is available to the application. |
| <li>Command dispatch: Based on the command selector, the appropriate</li> |
| web::command is executed. If there is no command selector |
| supplied, the default command is called. |
| <li>Termination stage: Application data is cleaned-up, all streams are</li> |
| flushed and control is returned to the caller. |
| </ol> |
| |
| <br><br> |
| The command-dispatch stage makes it possible for one script to deal with |
| many actions and states of an application. For example, one script can |
| generate many different pages within an application. That way, |
| Websh programmers can keep the focus on the application as a whole, |
| rather than writing one script per page. This is especially important for the |
| somewhat special transaction characteristics of Web-applications. |
| |
| <br><br> |
| In forms-based applications, a transaction, from the application's |
| point of view, is cut into two half-transactions. The first half |
| renders an HTML page with the corresponding form, while the second |
| part handles the data transmitted to the application. Both parts are |
| only glued together by the state management of Websh. However, it |
| is never known in advance when in time the second half of the |
| transaction will be executed (someone can open a form for edit and |
| then "forget" to submit it). The strong separation of these long |
| transactions into two halves is characteristic for Web-based |
| applications and differs from from traditional GUI applications where |
| both half steps, the display of a dialog and the collection of the |
| input, are usually executed in strong association (e.g., within the |
| same method of the application). |
| |
| <a name="467"><a href="#toc"><h1>6 Commands</h1></a> |
| |
| This section lists the main commands of Websh. For a complete |
| overview, you may want to look at the |
| <a href="quickref.html">Quick Reference</a>. |
| |
| <br><br> |
| <a name="474"><a href="#toc"><h2>6.1 request and url management</h2></a> |
| |
| <ul> |
| <li>::web::cmdurl</li> |
| <li>::web::cmdurlcfg</li> |
| <li>::web::dispatch</li> |
| <li>::web::formvar</li> |
| <li>::web::param</li> |
| <li>::web::command</li> |
| <li>::web::getcommand</li> |
| </ul> |
| |
| <a name="484"><a href="#toc"><h2>6.2 session management</h2></a> |
| |
| <ul> |
| <li>::web::cookiecontext</li> |
| <li>::web::filecontext</li> |
| <li>::web::filecounter</li> |
| </ul> |
| |
| <a name="490"><a href="#toc"><h2>6.3 output management</h2></a> |
| |
| <ul> |
| <li>::web::put</li> |
| <li>::web::putx</li> |
| <li>::web::putxfile</li> |
| <li>::web::output</li> |
| </ul> |
| |
| <a name="497"><a href="#toc"><h2>6.4 conversion</h2></a> |
| |
| <ul> |
| <li>::web::htmlify</li> |
| <li>::web::dehtmlify</li> |
| <li>::web::uriencode</li> |
| <li>::web::uridecode</li> |
| <li>::web::ascii64</li> |
| <li>::web::ascii85</li> |
| </ul> |
| |
| <a name="506"><a href="#toc"><h2>6.5 messages</h2></a> |
| |
| <ul> |
| <li>::web::send</li> |
| <li>::web::recv</li> |
| <li>::web::msgflag</li> |
| </ul> |
| |
| <a name="512"><a href="#toc"><h2>6.6 encryption</h2></a> |
| |
| <ul> |
| <li>::web::encrypt</li> |
| <li>::web::decrypt</li> |
| </ul> |
| |
| <a name="517"><a href="#toc"><h2>6.7 logging</h2></a> |
| |
| <ul> |
| <li>::web::log</li> |
| <li>::web::logdest</li> |
| <li>::web::loglevel</li> |
| </ul> |
| |
| <a name="523"><a href="#toc"><h2>6.8 misc</h2></a> |
| |
| <ul> |
| <li>::web::config</li> |
| <li>::web::include</li> |
| <li>::web::lockfile</li> |
| <li>::web::unlockfile</li> |
| <li>::web::readfile</li> |
| <li>::web::tempfile</li> |
| <li>::web::copyright</li> |
| </ul> |
| |
| <a name="533"><a href="#toc"><h1>7 Security issues</h1></a> |
| |
| Web-applications are subject to security issues as are all networked |
| applications. Furthermore, these applications are often deployed in the |
| Internet, making the security issues even more important. In the context |
| of Websh there are four different topics with the overall security |
| issues discussed here: |
| |
| <ul> |
| <li>Can Websh applications be used to gain unauthorized</li> |
| access to a computer ? |
| <li>What levels of stability do these applications show, i.e., do Websh</li> |
| applications often fail ? |
| <li>How does Websh manage user authentication and user</li> |
| authorization ? |
| <li>How is sensitive data handeled ?</li> |
| </ul> |
| |
| <br><br> |
| Websh does not offer any direct solution to these problems. Rather, |
| Websh is designed to avoid problems (intrusion, stability) and |
| allow simple inclusion of various authentication and data encryption |
| models. |
| |
| <br><br> |
| The problem of gaining unauthorized access is too important to be |
| solved by the tool used for application development. Therefore, the |
| design of Websh assumes that the surrounding system architecture, |
| i.e., Web server and Firewall handle these issues. This means, that |
| the Web server is responsible to execute CGI applications with |
| suitable low privileges, in Unix environments typically by setting the |
| effective UID to an unprivileged user and executing the |
| CGI-application in a chroot-environment. |
| |
| <br><br> |
| However, a Websh-developer can introduce security holes. The |
| flexibility of Websh clearly allows dangerous things to be |
| programmed. Therefore, security issues have to be checked with every |
| application. |
| |
| <br><br> |
| The stability issue has rather different characteristics than the |
| intrusion problems, but it is nontheless very important. Unstable |
| applications typically "get touched" very often, leading to generally |
| less secure systems. Also, crashing applications can impair a system's |
| stability if the applications take unexpected execution paths. The |
| design of Websh is lead by the idea to provide a simple, flexible |
| and easy-to-understand framework. Compared to other products, Websh |
| deliberately prefers transparency over high integration and |
| automation. This simplicity and flexibility, somehow similar to the |
| Unix model, leads to a high stability of the overall system. At the |
| time of this writing, Websh has been in production for almost four |
| years, without any major stability problems so far. |
| |
| <br><br> |
| User authentication is a third security domain important in many |
| Web-based applications. The design of Websh deliberately does not |
| include any specific method for user authentication. The reason for |
| this decision is that the specific authentication method needed |
| largely depends on the context of the application. Some applications |
| might authenticate users using a host system, others need specific |
| one-time-password schemes, and some applications might even rely on |
| authentication schemes provided by Web-servers and -browsers. The |
| extensibility of Websh allows various authentication schemes to be |
| adopted. |
| |
| <br><br> |
| Finally, the importance of the secure handling of sensitive data is |
| becoming more and more recognized. Here, Websh provides a extensible |
| encryption module which allows one to easily encrypt data before |
| storing, and to decrypt the data after reading. For example, a simple |
| encryption is used by default for the querystring generation, which |
| might contain sensible information. The encryption module uses |
| checksums to ensure the full transmission of encrypted text and |
| timestamps in order to ensure unique data. |
| The encryption sub-system of Websh is easily extensible by |
| plug-Ins which can be loaded when needed. |
| |
| <a name="609"><a href="#toc"><h1>8 Requirements</h1></a> |
| |
| Tcl 8.2.2 or higher |
| |
| <br><br> |
| For use as a web application, a web server supporting CGI is |
| needed. The Websh module for Apache 2 requires Apache 2. |
| |
| <a name=" "><a href="#toc"><h1>9 Copyright</h1></a> |
| |
| Copyright (C) 2000 by Netcetera.<br> |
| Copyright (C) 2001, 2002 by The Apache Software Foundation.<br> |
| All rights reserved.<br> |
| |
| You may always find an up-to-date version of the Websh white paper |
| at <a href="http://tcl.apache.org/websh/">http://tcl.apache.org/websh/</a>. |
| <p> |
| </td> |
| </tr> |
| </table> |
| |
| <table border="0" cellpadding="0" cellspacing="0" width="770" height="45"> |
| <tr valign="top"> |
| <td colspan="2"> |
| <hr noshade size="1"> |
| </td> |
| </tr> |
| <tr valign="top"> |
| <td width="10"></td> |
| <td width="760"> |
| <a href="product.html">description</a> | <span class="blue">documentation</span> | <a href="support.html">support</a> | <a href="resources.html">resources</a> | <a href="download.html">download</a> | <a href="credits.html">credits</a> | <a href="copyright.html">copyright</a> |
| </td></tr> |
| <tr valign="top"> |
| <td colspan="2"> |
| <hr noshade size="1"> |
| </td> |
| </tr> |
| <tr valign="top"> |
| <td width="10"></td> |
| <td width="760"> |
| <span class="klein"><b>© Websh - an <a href="http://tcl.apache.org">Apache Tcl</a> project - part of the <a href="http://www.apache.org/">Apache Software Foundation</a></b></span></td> |
| </tr> |
| </table> |
| </body> |
| </html> |
| |