As far as I undersand, API KEY is not something like ID, it's more
like a password for user's website URL, so it does not necessary have
to be unique.

For example, when you register an account for GMaps, you get an API
KEY for a specific URI.

Aidas Bendoraitis [aka Archatas]

On 8/11/06, Felix Ingram <[EMAIL PROTECTED]> wrote:
>
> On 8/11/06, Jay Klehr <[EMAIL PROTECTED]> wrote:
> > Felix Ingram wrote:
> > > On 8/10/06, Jeremy Dunck <[EMAIL PROTECTED]> wrote:
> > >> Just username+randomstring is good.
> > >> SHA better than md5.
> > >>
> > > Choice of hashing algorithm means nothing here. The only thing about
> > > SHA is that you'll get a longer string (160 bit rather than 128).
> > >
> > > If all you want is a random string then just use a random string.
> > >
> > However, a longer string gives you more unique combinations before you
> > have a collision.
>
> Well that's true but 128 bits still gives you 3 x 10^38 possible
> strings, so you could probably give everyone on the planet a key an
> still not have a collision.
>
> > I do agree that one small piece of non-random information will protect
> > you more against duplicates though.  That way, if the same random number
> > is generated for two different users, they wouldn't turn out to be the
> > same hash (using either MD5 or SHA).
> >
> > Say we have firstnames and two users get the same random bit added to
> > the firstname when generating their key:
> >
> > paul + 78uyy5jji = ADB01D7112EC1296DB1DFA87E37036B1 (md5)
> > julie + 78uyy5jji = A6EC2D3C8E0C831012F05E7A1EB4E080
> >
> > Obviously if you only used the random bit, a duplicate key would be
> > created here, both users would end up with the same key:
> >
> > 78uyy5jji = C5E9348386E8DECF6DDC879E7E914B92
> >
> > Of course, you should use a longer random string than my example here,
> > which would reduce the chances of getting a duplicate, but I still
> > recommend using some part of the user's profile (or even a timestamp) if
> > you're going to use MD5 or SHA.
>
> I do not think that recommendation makes much sense. In your example
> which is more likely: two random strings of length 4 being the same or
> two users being called 'paul'? Timestamps are better but what does
> this add? As soon as one uses a random string then the resulting api
> key, no matter what you add or what algorithm you pass it through,
> will still only be as random as the string itself. If you are worried
> about collisions then generate a longer random string.
>
> > Really, using a 128 bit or 160 bit (recommended) random string is all
> > you need to do, but MD5 and SHA make that step easier.
> > .
>
> They don't though do they? If you're generating a random string then
> it's as easy to generate one of a particular length that one of
> another. Adding timestamps or user details is going to cost you
> performance and space. Are you going to store the timestamp used? If
> so then why?
>
> Which of the code examples below is more random/more secure and why?
>
> ===========
> from random import choice
>
> characterSet = '[EMAIL PROTECTED]&*(-_=+)'
> api_key = ''.join([choice(characterSet) for i in range(50)])
> ===========
>
> import sha, random
>
> username = request.user.username
> api_key = sha.new(username + str(random.random())).hexdigest()
>
> ===========
> > No matter what you do there is always a chance for a duplicate key to
> > come up (something you should check in your system before assigning),
> > but the longer the key, the less likely that will happen.  But too long
> > and your users will hate you. ;)
>
> There are two things you can decide to do. Decide that you trust your
> random key generator and that the probability of a collision is
> sufficiently low for you to just hand out keys, or decide to implement
> a check and take the performance hit (which should be minimal in the
> grand scheme of things).
>
> Felix
>
> >
> > Jay
> >
>
> >
>

--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users
-~----------~----~----~----~------~----~------~--~---

Reply via email to