Skip to Content
Programming Jabber
book

Programming Jabber

by DJ Adams
January 2002
Beginner
480 pages
13h 15m
English
O'Reilly Media, Inc.
Content preview from Programming Jabber

Digest authentication method

The module that provides the digest authentication method, mod_auth_digest, works in conjunction with the plaintext module, mod_auth_plain. It provides a way to avoid having to send the plaintext password across the wire.

Method

The digest method is similar to the plaintext method, in that the password sent by the client is compared to the password stored on the server. However, in this case, the password is first encoded using a hashing algorithm. It is encoded by the client before being sent across the wire, and it is encoded by the server (having retrieved it in plaintext) before making the comparison.

The algorithm used is the NIST SHA-1 message digest algorithm.[6]

This algorithm takes arbitrary input and produces a fingerprint or “message digest” of it.[7]

A random string, shared between the client and the server, is appended to the password before being passed to the hashing algorithm. This random string is the connection ID—the value of the id attribute in the server’s XML stream header response that we saw in Example 7-3:

RECV: <?xml version='1.0'?>
<stream:stream xmlns:stream='http://etherx.jabber.org/streams'
  id='1ED34A55' xmlns='jabber:client' from='yak'>

which means, in the case where the password is “secret,” the string that will be hashed is:

secret1ED34A55

which is:

03ea09f012493415908d63dcb1f6dbdb9bfc09ba

The digested password is transmitted to the server inside the <digest/> tag.

mod_auth_digest is unlike the other two modules ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Professional XMPP Programming with JavaScript® and jQuery

Professional XMPP Programming with JavaScript® and jQuery

Jack Moffitt
Hacking Web Performance

Hacking Web Performance

Maximiliano Firtman

Publisher Resources

ISBN: 0596002025Errata Page