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;
logReq.open("POST", "/names.nsf?Login" , false);
logReq.send(poststring);
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. 10/08/2018Will you be at the NYC Launch Event for HCL Domino v10 -- Find me!Come find me in NYC on Wednesday at the Launch Event if you're there. I really do want to talk to ...... 
  2. 09/04/2018With two big projects on hold, I suddenly find myself very available for new short and long term projects. In twenty five years, I don't think I've ever written an entry like this, but if you need the kind of work I do now would be a great time to get in touch. Both of the big projects I had lined up for late summer and early fall have been placed on hold and will be that way for a while. With the kids now all off at college and careers, I'm open to more travel than such than I have been in decades, but unless something else comes along, I'll be here working on updates to Second Signal and other things that ...... 
  3. 07/13/2018Who is HCL and why is it a good thing that they are now the ones behind Notes and Domino?We need to address some biases here. IBM has made a deal under which the Notes & Domino software and intellectual property is now being developed and maintained by HCL America. HCL America is part of the very large "HCL Technologies" company that has grown from its roots in India to become an 8 Billion Dollar company with a global presence in the IT Industry. You could be excused for initially believing, as many people do when they hear this, that "they've outsourced the code to India where they'll milk it ...... 
  4. 03/21/2018Domino Apps on IOS is a Game Changer. Quit holding back. 
  5. 02/15/2018Andrew’s Proposed Gun Laws 
  6. 05/05/2016Is the growing social-sourced economy the modern back door into socialism? 
  7. 04/20/2016Want to be whitelisted? Here are some sensible rules for web site advertising 
  8. 12/30/2015Fantastic new series on Syfy called “The Expanse” – for people who love traditional science fiction 
  9. 10/20/2015My suggestion is to stay away from PayAnywhere(dot)com  
  10. 08/07/2015Here is one for you VMWARE gurus - particularly if you run ESXi without fancy drive arrays 
Click here for more articles.....


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

Please wait while your document is saved.