Andrew Pollack's Blog

Technology, Family, Entertainment, Politics, and Random Noise

Tip: Log a user into a Domino website without a page refresh with this simple javascript

By Andrew Pollack on 09/29/2006 at 02:16 PM EDT

These two functions are all you really need.

The trick is in the ultra-simple first function listed below. The function uses the xmlHttpRequest made so famous as the core of the "Ajax" programming style. By doing an Ajax style 'Post' of the credentials to the Domino server, the results you get back which normally redirect you somewhere else, are caught by the request object. You can discard them (or display them if you really want). In this function, I've used the ultra-small icon file "onepixel.gif" as the redirection target so that the server sends back as little data as possible.

Since the server is responding with a page, the session token cookie gets written to the browser normally, and that's all it takes. Now you're logged on and your other Ajax style requests will process normally.

For this to work, you must be using "Session Based" authentication. You also must have the username and password to submit. You can collect that on a form (maybe a popup layer?) if you like. You can even store them in a cookie on the browser side, giving you that "remember me" functionality. Be careful though, as this data won't be encrypted so storing it locally can create a security risk.

A final note on requirements -- the page you are displaying must be from the same server you're logging on to. This is due to a security consideration on the xmlHttpRequest object. The browser will not do a background submit to a different server.

function doDominoLogin(username, password) {
var logReq = createXHTMLHttpRequest() ;
var poststring = "RedirectTo=" + escape('/icons/onepixel.gif') +
"&Username=" + username + "&password=" + password;"POST", "/names.nsf?Login" , false);
if (logReq.status == 200){ return(true); } else { return(false);};

The second function is just to get an XMLHttpRequest object for either IE or Netscape, since it's a bit different for each.

function createXHTMLHttpRequest() {
try { return new ActiveXObject("Msxml2.XMLHTTP") ; } catch (e) {}
try { return new ActiveXObject("Microsoft.XMLHTTP") ; } catch (e) {}
try { return new XMLHttpRequest() ; } catch (e) {}
alert("XMLHttpRequest is not supported on this browser!");
return null;

The new Second Signal web site will be entirely Ajax driven -- no screen refreshes. The functions that talk to the back end pick up when a call fails due to an access requirement, and prompt using a simple html layer. Since the whole site is "windowed" rather than a traditional flowing page, I just gray out the current windows and bring up this one.....

There are  - loading -  comments....

Other Recent Stories...

  1. 01/28/2020Copyright Troll WarningThere's a copyright troll firm that has automated reverse-image searches and goes around looking for any posted images that they can make a quick copyright claim on. This is not quite a scam because it's technically legal, but it's run very much like a scam. This company works with a few "clients" that have vast repositories of copyrighted images. The trolls do a reverse web search on those images looking for hits. When they find one on a site that looks like someone they can scare, they work it like ...... 
  2. 03/26/2019Undestanding how OAUTH scopes will bring the concept of APPS to your Domino serverWhile a full description of OATH is way beyond what I can do in this quick blog entry, I wanted to talk a bit about how "SCOPES" interact with the already rich authorization model used by Domino. Thanks to the fantastic work by John Curtis and his team, the node.js integration with Domino is going to be getting a rich security model. What we know is that a user's authorizations will be respected through the node.js application to the Domino server -- including reader names, ACLs, Roles, and so on. The way ...... 
  3. 02/05/2019Toro Yard Equipment - Not really a premium brand as far as I am concernedDear Toro Customer Service, I arm writing about the following machine: Toro Power Max 1120 OXEModel:38654S/N:31000#### Specifically, bearing part #:63-3450 This is the part ($15 online / $25 at the local dealer) that caused me to raise my objections on-line. This piece of garbage is supposed to be a bearing. It carries the shaft which drives both stages of the auger. The shaft passes through the bearing (which is what bearings do) after the auger drive pulley as the shaft goes through the back (engine ...... 
  4. 10/08/2018Will you be at the NYC Launch Event for HCL Domino v10 -- Find me! 
  5. 09/04/2018With two big projects on hold, I suddenly find myself very available for new short and long term projects.  
  6. 07/13/2018Who is HCL and why is it a good thing that they are now the ones behind Notes and Domino? 
  7. 03/21/2018Domino Apps on IOS is a Game Changer. Quit holding back. 
  8. 02/15/2018Andrew’s Proposed Gun Laws 
  9. 05/05/2016Is the growing social-sourced economy the modern back door into socialism? 
  10. 04/20/2016Want to be whitelisted? Here are some sensible rules for web site advertising 
Click here for more articles.....

pen icon Comment Entry
Your Name
*Your Email
* Your email address is required, but not displayed.
Your thoughts....
Remember Me  

Please wait while your document is saved.