HTTP - basic authentication example.
Jaime Wyant
programmer.py at gmail.com
Fri Sep 17 08:37:44 EDT 2004
Good stuff. I knew if we knocked our heads together something good
would come out ;-).
jw
On Fri, 17 Sep 2004 13:20:23 +0100, Michael Foord <fuzzyman at gmail.com> wrote:
> I've added this example to the python cookbook (which basically does
> what your example does I think) -
>
> The proper way of actually doing this is to use an
> HTTPBasicAuthHandler along with an HTTPPasswordMgr.
> The python documentation on this is actually pretty minimal - so below
> is an example showing how to do this.
> The main problem with HTTPPasswordMgr is that you must *already* know
> the realm - so we're going to use the HTTPPasswordMgrWithDefaultRealm
> instead !!
>
> theurl = 'http://www.someserver.com/highestlevelprotectedpath/somepage.htm'
> username = 'johnny'
> password = 'XXXXXX' # a great password
>
> passman = urllib2.HTTPPasswordMgrWithDefaultRealm() # this
> creates a password manager
> passman.add_password(None, theurl, username, password) # because
> we have put None at the start it will always use this
> username/password combination
>
> authhandler = urllib2.HTTPBasicAuthHandler(passman) #
> create the AuthHandler
>
> opener = urllib2.build_opener(authhandler)
> # build an 'opener' using the handler we've created
> # you can use the opener directly to open URLs
> # *or* you can install it as the default opener so that all calls to
> urllib2.urlopen use this opener
> urllib2.install_opener(opener)
>
> # All calls to urllib2.urlopen will now use our handler
>
>
>
>
> On Wed, 15 Sep 2004 11:21:21 -0500, Jaime Wyant <programmer.py at gmail.com> wrote:
> > FWIW, this is how I handle Basic Authentication:
> >
> > import urllib2
> > import sys
> >
> > class AuthenticateAllURIs:
> > """This class authenticates all Basic Authentication using uname
> > / pword."""
> > def __init__(self,uname,pword):
> > self.uname = uname
> > self.pword = pword
> >
> > def find_user_password(self, realm, host):
> > # Note, that this class doesn't take `realm' into consideration.
> > return self.uname, self.pword
> >
> > def add_password( self, realm, uri, user, password ):
> > pass
> >
> > auth = urllib2.ProxyBasicAuthHandler(AuthenticateAllURIs('umjaw', 'fuse3'))
> > opener = urllib2.build_opener( auth )
> > urllib2.install_opener( opener )
> > wp = urllib2.urlopen("http://www.slashdot.org")
> > print wp.read()
> >
> > HTH,
> > jw
> >
> > On 15 Sep 2004 08:37:12 -0700, Michael Foord <fuzzyman at gmail.com> wrote:
> > [ snip! ]
> >
>
> --
> http://www.Voidspace.org.uk
> The Place where headspace meets cyberspace. Online resource site -
> covering science, technology, computing, cyberpunk, psychology,
> spirituality, fiction and more.
>
> ---
> http://www.Voidspace.org.uk/atlantibots/pythonutils.html
> Python utilities, modules and apps.
> Including Nanagram, Dirwatcher and more.
> ---
> http://www.fuchsiashockz.co.uk
> http://groups.yahoo.com/group/void-shockz
> ---
>
> Everyone has talent. What is rare is the courage to follow talent
> to the dark place where it leads. -Erica Jong
> Ambition is a poor excuse for not having sense enough to be lazy.
> -Milan Kundera
>
More information about the Python-list
mailing list