• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 253
  • Last Modified:

CGI & Netscape Enterprise Server authentification

How can I pass the current login name used in an HT password window to a CGI?
(The web server is Netscape Enterprise 2.01)
0
xme
Asked:
xme
  • 3
  • 2
  • 2
  • +3
1 Solution
 
julio011597Commented:
Sorry, what's HT?
-julio
0
 
icdCommented:
If you mean the .htaccess method then the environmental variable
REMOTE_USER will give you the users login.
0
 
xmeAuthor Commented:
Ok, I tried REMOTE_USER and REMOTE_IDENT... Nothing!
Could you provide me an example?

0
Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

 
mravellCommented:
Are you talking about the User and Pass screen that a browser displays when you try to access a secured realm on your web server?

If so, let me know as I have done some work with this stuff just recently.


Regards
Marty
0
 
xmeAuthor Commented:
Using Netscape Enterprise server, when you set the 'Restrict Access' mode with a user database, you receive a prompt window when you access a protected zone of the site.
This is the login passed via this window that I want to use in
CGIs...
0
 
ernstCommented:
in C, it would be:
char *userid;
userid = malloc(strlen(getenv("REMOTE_USER")) + 1);
strcpy(userid, getenv("REMOTE_USER");

in perl:

$userid = $ENV{'REMOTE_USER'};

0
 
julio011597Commented:
Sorry, malloc() and getenv() may return NULL.
A safe code should look something like this:

--//--
char *temp;
char *userid;

if(temp = getenv("REMOTE_USER")) { /* env var found */
  if(!(userid = malloc(strlen(temp) + 1))) return MALLOC_FAILED;
  strcpy(userid, temp);
}
else {  /* env var not found */
  if(!(userid = malloc(1))) return MALLOC_FAILED;
  *userid = '\0';
}
--//--

Rgds, julio
0
 
ernstCommented:
oh yeah, big deal.
0
 
mgjvCommented:
Errmmm...

What's wrong with

char *user_id;

user_id = getenv("REMOTE_USER");

Why allocate memory, and duplicate the value, while it's already available? Unless you need to change it..
0
 
julio011597Commented:
 Hello mgjv,

you are right, unless you need to change that value, _and_ unless you are going to get more than just one env variable.

Each call to getenv() overwrites the previous value, since the pointer returned by getenv() is a pointer to a static variable.

That is, say you have something like this:

--//--
char *rm, *qs, *ru;

rm = getenv("REQUEST_METHOD");
qs = getenv("QUERY_STRING");
ru = getenv("REMOTE_USER");
--//--

This code would end up with the same value for rm, qs and ru, which is the location of the unique static variable handled by getenv(), and that static variable would point to the value requested in the last call to getenv(), i.e. "REMOTE_USER".

HTH, despite of my English :)

-julio
0

Featured Post

Hire Technology Freelancers with Gigs

Work with freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely, and get projects done right.

  • 3
  • 2
  • 2
  • +3
Tackle projects and never again get stuck behind a technical roadblock.
Join Now