1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841
|
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
"http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd" [
<!ENTITY figtype "#FIGTYPE#">
<!ENTITY timestamp "#DATE#">
<!ENTITY version "#VERSION#">
]>
<!-- <!DOCTYPE book SYSTEM "docbookx.dtd"> -->
<book>
<title>Guide to Mobile Internet Security</title>
<chapter>
<title>1 Introduction</title>
<para>Welcome to the Alligata Server <citetitle>Guide to Mobile Internet Security</citetitle>. This guide is part of the Alligata Server Secure package. It supplements the Alligata Server User Manual, and explains how you can use Alligata Server Secure's encryption features to set up secure Wireless Application Protocol (WAP) services such as credit card transactions and exchange of private information across the Mobile Internet or a mobile intranet.</para>
<para>This guide covers the following subjects:</para>
<itemizedlist>
<listitem>
<para>How security is implemented on the Internet using cryptography, message hashing, digital certificates and digital signatures.</para>
</listitem>
<listitem>
<para>How the Wireless Transport Layer Security (WTLS) component of the WAP stack extends security to the Mobile Internet.</para>
</listitem>
<listitem>
<para>How to obtain the data items items you need to set up secure Mobile Internet services: asymmetric key pairs and digital certificates.</para>
</listitem>
<listitem>
<para>How to configure Alligata Server Secure to offer secure WAP services.</para>
</listitem>
</itemizedlist>
</chapter>
<chapter>
<title>2 Internet Security Overview</title>
<para>For an understanding of security on the Mobile Internet, some knowledge is required of how security works on the terrestrial Internet. This section explains the ways in which confidential information sent across the Internet can be protected against interception, alteration and forgery by third parties.
</para>
<section>
<title>2.1 Aspects of Internet Security
</title>
<para>To be considered entirely secure, any method of communication must offer the following features:
</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="bold">Privacy</emphasis>. A message must not be readable by third parties between its source and its destination.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Integrity protection</emphasis>. A message must reach its destination in the same form as it left its source, or else the fact that it has been altered in transit must be obvious to its recipient.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Authentication.</emphasis> Means must exist for the recipient of a message to verify that its sender is trustworthy and genuine (that is, not impersonating a third party).</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Non-repudiation.</emphasis> The sender of a message must not be able to deny, at a later time, having sent it.</para>
</listitem>
</itemizedlist>
<para>All these features are available on the Internet through the use of encryption, hashing, digital certificates, digital signatures and password protection. These techniques are discussed in detail later in this section. Firstly, it is important to know why they are necessary to begin with.
</para>
</section>
<section>
<title>2.2 Insecurity of the Internet</title>
<para>The Internet is not an inherently secure medium. A message sent across the Internet from one computer to another typically travels via several intermediate computers, called routers. Anyone with access to a router can inspect or modify data packets as they pass through it. Furthermore, before and after its journey across the Internet, data will often pass through a local area network (LAN). The architecture of most LANs is such that data packets from and to one computer on the network can freely be read by any other computer on it.
</para>
<para>All this means that a message transmitted across the Internet can potentially be seen, and even altered, by hundreds of people (some known to the sender, others unknown) on its way to its destination.</para>
</section>
<section>
<title>2.3 Secure Sockets Layer (SSL)
</title>
<para>A solution to the problem of secure Internet communication was first developed by the software company Netscape in 1994. Netscape added a protocol layer, the <emphasis role="bold">Secure Sockets Layer (SSL)</emphasis>, on top of the Internet's TCP/IP protocol suite in its Navigator Web browser. SSL employs a collection of mathematical and computational techniques to allow data to be sent securely across the Internet in ways that meet all the criteria of privacy, integrity protection, authentication and non-repudiation. By 1998, SSL was firmly integrated into the infrastructure of the Internet as a whole, and was the main catalyst behind the e-commerce boom of the late 1990s. As Figure 1 shows, it can be used in conjunction with any of the higher-level Internet protocols, such as HTTP, File Transfer Protocol (FTP) and Internet Message Access Protocol (IMAP).
</para>
<mediaobject>
<imageobject>
<imagedata fileref="fig1o&figtype;"/>
</imageobject>
<caption>
<para>Figure 1: SSL's position among the Internet's protocols
</para>
</caption>
</mediaobject>
<para>SSL uses the following methods to provide security across the Internet:
</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="bold">Cryptography.</emphasis> This is the science of scrambling messages so that they cannot easily be understood by anyone other than their sender and their intended recipient. It enables privacy in Internet communications.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Message hashing.</emphasis> A message is run through a computational algorithm to produce a message 'fingerprint', which can be used to verify that the message has not been altered in transit.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Digital certificates.</emphasis> A digital certificate is a short electronic document that vouches for the authenticity of its holder. It is issued by an organisation called a <emphasis role="bold">certificate authority (CA)</emphasis> and is formatted in such a way that it is practically impossible to counterfeit.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Digital signatures.</emphasis> A digital signature is a way of formatting a message so that it is traceable to one source, and one source only. Digital signatures enable non-repudiation in Internet transactions.</para>
</listitem>
</itemizedlist>
<para>The methods used by SSL are generic mathematical and procedural ones, which can be applied to any secure means of communication. As we shall see in Section 3, they have already been adopted by the Mobile Internet's Wireless Transport Layer Security (WTLS) protocol (see Section 3), and they are likely to form the basis of any future developments in Internet security.
</para>
<para>Sections 2.4 to 2.8 examine the elements of Internet security as they are implemented in SSL.
</para>
</section>
<section>
<title>2.4 Privacy</title>
<para>The fundamental requirement of any method of secure communication is privacy. In inherently transparent media such as the Internet, this means finding ways of ensuring that even if a third party can see a message, they cannot understand it. The best way to achieve this is to scramble the message in a way that is systematic whilst being all but impossible to deduce from the scrambled message alone.
</para>
<section>
<title>2.4.1 Symmetric Key Cryptography</title>
<para>SSL uses techniques of <emphasis role="bold">cryptography</emphasis> to scramble and unscramble data. Cryptography is the art of rendering information opaque by passing it through mathematical scrambling algorithms. The scrambling of information using cryptography is called <emphasis role="bold">encryption</emphasis>; its unscrambling is called <emphasis role="bold">decryption</emphasis>. </para>
<para>In encryption, message data is passed through a mathematical algorithm involving a particular numeric value. This numeric value is called the <emphasis role="bold">key</emphasis>. In basic cryptography, a message can only easily be decrypted by someone with access to the key with which it was encrypted.
</para>
<para>Other important cryptographic terms are:
</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="bold">Plaintext:</emphasis> unencrypted data. Despite its name, the term usually refers to any kind of unencrypted data, whether textual, graphical, audio or binary.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Ciphertext:</emphasis> data that has been encrypted.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Cryptanalysis:</emphasis> the study of methods to 'break' ciphertext (that is, deduce its original plaintext form) without direct access to its encryption key, encryption algorithm, or both.</para>
</listitem>
</itemizedlist>
<para>An example of a very simple cryptographic algorithm is to add a value <replaceable>x</replaceable> (the key) to the code of each character in a message. To decrypt an encrypted message, its recipient must know both its encryption algorithm and the algorithm's key. They can then use the key to perform the inverse of the encryption operation on each character of the message. For example, if a message were encrypted by adding 6 to the code of each character in it, it would be decrypted by subtracting 6 from each code. Because the decryption operation is the exact inverse of the encryption operation, this type of cryptography is called <emphasis role="bold">symmetric key cryptography</emphasis>.
</para>
<para>The algorithms that are actually used in symmetric key cryptography on the Internet are much more complex than this example, in order to be able to withstand attempts to crack them by trial-and-error (known as 'brute force attacks'). Most symmetric agorithms encrypt messages not a character at a time, but a block of bits at a time (typically 64) ( a method called <emphasis role="bold">block cipher encryption</emphasis>). In block cipher encryption, a complicated series of transformations is applied to each block in turn, using a very long key (ideally at least 112 bits). In addition, a technique called <emphasis role="bold">cipher block chaining</emphasis> is often applied, whereby the result of the encryption of each block is used as a filter for the encryption of the next block (see Figure 2). Cipher block chaining hides any repeated patterns of data that occur in the plaintext message. (Such patterns are always a useful 'handle' for malicious cryptanalysts.)
</para>
<mediaobject>
<imageobject>
<imagedata fileref="fig2o&figtype;"/>
</imageobject>
<caption>
<para>Figure 2: Cipher block chaining
</para>
</caption>
</mediaobject>
</section>
<section>
<title>2.4.2 Public Key Cryptography
</title>
<para>Advanced symmetric key cryptography offers very effective security for most purposes. (According to one estimate, there is not enough energy available in the solar system to perform a computational brute force attack against a 256-bit key.) However, symmetric key cryptography has an important limitation: before any encrypted communication can take place, the encryption key itself must be securely conveyed from the sender to the recipient. Symmetric key cryptography only allows this to be done by extraneous means. For example, the sender could send the key in an armoured van to the recipient (this is how banks install keys in their cash machines). Of course, this undermines the main advantage of the Internet over other forms of communication, namely its practicality.
</para>
<para>To circumvent this limitation of symmetric key cryptography, another type of cryptography, called <emphasis role="bold">public key cryptography</emphasis> ( also known as <emphasis role="bold">asymmetric key cryptography</emphasis> ) is employed for the exchange of symmetric keys. Public key cryptography exploits the existence of a type of mathematical operation called a <emphasis role="bold">one-way function</emphasis>. A one-way function is one that is much easier to perform in one direction than in the other. A simple example of a one-way function is the multiplication of prime numbers: for instance, it is much easier to multiply 4253 by 5521 than it is to find the two prime factors of 23480813. (The multiplication of prime numbers plays a significant role in many cryptographic algorithms.)</para>
<para>Public key cryptography uses advanced one-way functions, consisting of a mathematical algorithm and a numerical key, to encrypt data. Unlike in symmetric key cryptography, however, the key used to encrypt a message cannot be used to decrypt it. Decrypting the message requires a different key that is mathematically related to the encryption key, but for all practical purposes impossible to derive from it. Even knowing the encryption algorithm is no help in calculating the encryption key, for which reason the best-known encryption algorithms are kept in the public domain. (The thinking is that submitting encryption algorithms to the scrutiny of the world's cryptanalysts is the best way of testing their robustness. For example, the RSA algorithm used by Alligata Secure has so far yielded no significant weaknesses.)
</para>
<para>Note that deriving a decryption key from an encryption key is always hypothetically possible; in fact, mathematically it is many times quicker to work out a private asymmetric key than it is to work out a symmetric key of the same length. Still, calculating a private assymetric key of 1792 bits should ( for the next few years, at least ) be all but computationally infeasible even using hundreds of thousands of computers working in parallel. Certainly, for almost every organisation in the world, it will be financially infeasible.
</para>
</section>
<section>
<title>2.4.3 Cryptography in Practice
</title>
<para>Let us suppose Brian wants to set up a secure Internet connection. He first uses an appropriate software tool to create an asymmetric key pair, consisting of one public and one private key. Others can then use his public key to encrypt messages to him, which he ( and no one else ) can read using his private key. In this way, anyone can send Brian a private message without going through the risk or inconvenience of exchanging symmetric keys beforehand.
</para>
<para>Conversely, if Brian wants to send a message that others can be sure originated with him, he encrypts it using his private key, and others use his public key to read it. (This is the process of creating a <emphasis role="bold">digital signature</emphasis>, and is elaborated in Section 2.7.)
</para>
<para>In practice, the complex mathematical processes used by public key cryptography make it rather slow for use with long messages. SSL therefore restricts its use of public key cryptography to the exchange of a symmetric key (see Section 2.3.1) between the client and the server at the start of a secure Internet session. This symmetric key is agreed on-the-fly between the client and the server and it is called the <emphasis role="bold">session key</emphasis>. After the session is over, it is discarded by both the client and the server.
</para>
<para>The ways in which symmetric and asymmetric cryptography are combined in real Internet transactions are illustrated in Section 2.8.</para>
</section>
</section>
<section>
<title>2.5 Integrity Protection
</title>
<para>We have seen how cryptography can be used to send messages across the Internet that are unreadable by third parties. However, this does not prevent third parties from blindly altering messages between their source and their destination. Depending on the content of the message, such alterations may be apparent to the recipient of the message or not. (For example, indiscriminate interference with a text message is usually easier to spot than with a block of binary data.)
</para>
<para>
<emphasis role="bold">Integrity protection</emphasis> is the term applied to techniques for verifying that a message reaches its intended recipient in exactly the same form as it leaves its sender. While integrity protection does not guarantee that a message will reach its desination unchanged, it does (virtually) guarantee that any change is obvious to the recipient.
</para>
<section>
<title>2.5.1 Hash Functions</title>
<para>Integrity protection uses computational algorithms called <emphasis role="bold">hash functions</emphasis>. A hash function is a one-way function (see Section 2.3.2) into which data ( such as an Internet message ) is fed, and whose result is a value of a fixed length in bits. Passing a message through a hash function produces a <emphasis role="bold">hash value</emphasis> that is effectively a 'fingerprint' of the message. This fingerprint is called the <emphasis role="bold">message digest</emphasis>. It is usually much shorter than the message itself.
</para>
<para>The sender of a message computes its digest, encrypts the digest using their private key and sends it appended to the message. The recipient verifies the integrity of the message by decrypting the digest using the sender's public key, then running the message through the same hashing algorithm that produced the digest. If the message has been interfered with on its journey, the hash value calculated by the recipient will not match the value of the digest.
</para>
<para>In fact, a matching hash value is not an absolute guarantee of integrity: a <emphasis role="bold">collision</emphasis> is theoretically possible, whereby the modified message happens to produce exactly the same hash value as the original message. However, collisions in good-quality hash functions are so rare that their calculation may be considered computationally intractable.
</para>
</section>
</section>
<section>
<title>2.6 Authentication
</title>
<para>SSL allows privacy and integrity in Internet communications. However, without further measures, the anonymity of the Internet makes it easy for a user to impersonate another user. For example, a malicious party could create a Web site on which they masquerade as a respected organisation, set up a private connection for transactions, and begin obtaining money and credit card details from unsuspecting 'customers'.
</para>
<mediaobject>
<imageobject>
<imagedata fileref="fig3o&figtype;"/>
</imageobject>
<caption>
<para>Figure 3: Creation of a message digest using a hash function
</para>
</caption>
</mediaobject>
<section>
<title>2.6.1 Digital Certificates
</title>
<para>This problem is addressed by the use of <emphasis role="bold">digital certificates</emphasis>. A digital certificate is a message sent by one party to another at the beginning of a secure Internet session, verifying the sender's identity and vouching for their integrity. The certificate is obtained from an organisation called a <emphasis role="bold">certificate authority (CA)</emphasis>. The certificate is virtually impossible to forge, for reasons that are explained later.
</para>
<para>Once a secure session has been requested by an Internet client such as a Web browser, it typically continues with the server sending the client its digital certificate. The server's digital certificate contains the following information:</para>
<itemizedlist>
<listitem>
<para>The server's public key</para>
</listitem>
<listitem>
<para>The certificate's serial number</para>
</listitem>
<listitem>
<para>The certificate's validity period</para>
</listitem>
<listitem>
<para>The server's domain name</para>
</listitem>
<listitem>
<para>The domain name of the CA that issued the certificate</para>
</listitem>
</itemizedlist>
<para>The certificate is supplied with its hashed digest (see Section 2.5.1). The digest is encrypted using the private key of the CA that issued the certificate; this encrypted digest constitutes the CA's digital signature. If the digital signature can be decrypted using the CA's public key, then the certificate must have originated with the CA. (See Section 2.7 for more on digital signatures.)
</para>
<para>Upon receiving the server's certificate, the client validates it by checking the following criteria:
</para>
<itemizedlist>
<listitem>
<para>That it is valid for the current date.</para>
</listitem>
<listitem>
<para>That it applies to the server that sent it.</para>
</listitem>
<listitem>
<para>That the CA that issued it is known and trusted. (To do this, the client checks the CA's own certificate, which is signed by the CA itself.)</para>
</listitem>
<listitem>
<para>That the CA's digital signature can be decrypted using the CA's public key. (Most Web clients contain a list of the public keys of the best known CAs, so they do not need to search the Internet for them.)</para>
</listitem>
</itemizedlist>
<para>The client warns the user if the certificate fails any of these tests. The user may continue with the session at their own risk, if they wish.
</para>
<para>Digital certificates can be issued in chains. For example, a large CA might issue a certificate to a smaller CA, which issues a certificate to a still smaller CA, which issues end-entity certificates to Internet traders. This helps distribute the task of administering digital certificates. When an Internet client receives a certificate from a chain, it checks the certificate of every CA in the chain as described above, until it reaches the self-signed certificate of a top-level CA.
</para>
<para>Digital certificates are not only used by Internet servers: they can also be obtained for Internet clients. In practice, though, demand for client certificates has proved minimal. Authentication of a client by a server, where it is implemented at all, is usually through use of a user name and a password. While this method is not infallible, it nevertheless adds a layer of security to Internet transactions that is absent from many non-Internet confidential transactions ( for example, ordering goods by credit card over the telephone).</para>
</section>
</section>
<section>
<title>2.7 Non-repudiation
</title>
<para>The final requirement of secure communications is non-repudiation: a message's source must be provable upon demand. Non-repudiation is normally achieved using <emphasis role="bold">digital signatures</emphasis>.
</para>
<section>
<title>2.7.1 Digital Signatures
</title>
<para>A digital signature is simply a way of encoding data so that its source and its integrity are verifiable. Digital signatures use the same techniques of cryptography and hashing that are used to provide privacy and integrity protection (see Sections 2.3 and 2.4). The difference is that the roles of public and private keys are reversed.
</para>
<para>Let us suppose that Abigail wants to stamp a message with her digital signature. First she passes the message through a hash function to create a message digest. She then uses her private key to encrypt the digest, and attaches the encrypted digest to the message. This encrypted digest constitutes her digital signature. (Of course, Abigail could encrypt the entire message using her private key; however, encrypting the digest is sufficient and much quicker.)
</para>
<para>If Brian is the recipient of Abigail's message and wants to verify that it originated with her, he uses Abigail's public key to decrypt her signature. He then runs the message through the same hash function that Abigail used to create the digest, and compares it with the value of Abigail's decrypted signature.
</para>
<para>The main users of digital signatures on the Internet at present are CAs, who stamp them on every certificate they issue (see Section 2.6). Although client-side digital signatures are an effective means of non-repudiation, demand for them has so far been minimal. This suggests that businesses and customers are happy to carry out transactions without them. Instead, client-side non-repudiation is normally implemented using password protection, which is regarded as an acceptable compromise between practicality and guaranteed security.
</para>
</section>
</section>
<section>
<title>2.8 Example Secure Transaction
</title>
<para>Secure Internet transactions rely on quite complex combinations of public key cryptography, symmetric key cryptography, hash functions, digital certificates and digital signatures. The following example illustrates the sequence of steps involved in a typical SSL session.
</para>
<para>Note that by far the most complex part of a secure Internet session is the initial <emphasis role="bold">handshake</emphasis>, whereby the parties agree on a secure data format for the rest of the session and, if necessary, establish each other's credentials.
</para>
<para>This example demonstrates the most usual type of SSL handshake, with the client authenticating the server, but without the server authenticating the client. The transaction is summarised graphically in Figures 4, 5 and 6.
</para>
<section>
<title>Part One: SSL Handshake
</title>
<orderedlist inheritnum="ignore" continuation="restarts">
<listitem>
<para>Abigail, a Web surfer, sees an item she would like to buy on Brian's Web site. </para>
</listitem>
<listitem>
<para>Abigail clicks a button on Brian's Web site that sends a request for a secure Internet session to Brian. The following items are appended to the request:
</para>
<para>- Various information about what versions of SSL Abigail's Web browser supports, what encryption algorithms it supports, and so on.
</para>
<para>- Some randomly generated data. This will be used, along with other data, to generate the session key (see step X).
</para>
</listitem>
<listitem>
<para>Brian receives Abigail's request for a secure session and sends her the following items:
</para>
<para>- His digital certificate, including his public key. The certificate is signed by a trusted CA using its private key.
</para>
<para>- Information about what versions of SSL Brian's Web server supports, what encryption algorithms it supports, and so on.
</para>
<para>- Some randomly generated data which will be used in the generation of the session key.
</para>
<para>Brian could also request Abigail's digital certificate. However, in practice it is very rare for a server to require a certificate from a client.
</para>
</listitem>
<listitem>
<para>Abigail validates Brian's certificate as outlined in Section 2.6.1. If the validation is successful, she is happy that Brian is who he says he is, and that he is a reputable trader.</para>
</listitem>
<listitem>
<para>Abigail performs a series of operations on the random data she sent to Brian, and the random data Brian sent to her, to produce a piece of data called the <emphasis role="bold">premaster secret</emphasis>.
</para>
</listitem>
<listitem>
<para>Abigail encrypts the premaster secret using Brian's public key and sends it to Brian. (If Brian had requested her digital certificate, she would also send her certificate for Brian to validate.)
</para>
</listitem>
<listitem>
<para>Brian receives the premaster secret from Abigail.
</para>
</listitem>
<listitem>
<para>Brian decrypts the premaster secret. He and Abigail simultaneously perform a series of operations on it, to arrive at a piece of data called the <emphasis role="bold">master secret</emphasis>.</para>
</listitem>
<listitem>
<para>Abigail and Brian simultaneously perform a series of operations on the master secret to arrive at the session key (see Section 2.4.3), which will be used to encrypt the information they want to send to each other.
</para>
</listitem>
<listitem>
<para>Abigail sends Brian two messages. The first confirms that all further messages from her will be encrypted using the session key. The second is an encrypted message that formally ends the handshake from her side.
</para>
</listitem>
<listitem>
<para>Brian sends Abigail two messages. The first confirms that all further messages from him will be encrypted using the session key. The second is an encrypted message that formally ends the handshake from his side.
</para>
</listitem>
</orderedlist>
<mediaobject>
<imageobject>
<imagedata fileref="fig4out&figtype;"/>
</imageobject>
<caption>
<para>Figure 4: SSL handshake. Step numbers correspond to those in the textual account
</para>
</caption>
</mediaobject>
</section>
<section>
<title>Part Two: Transfer of Confidential Information
</title>
<orderedlist inheritnum="ignore" continuation="continues">
<listitem>
<para>Abigail fills in the relevant form on Brian's Web site, including her credit card details. She presses a button which sends the form to Brian, encrypted using the session key.
</para>
</listitem>
<listitem>
<para>Brian receives Abigail's credit card details and decrypts them using the session key.
</para>
</listitem>
</orderedlist>
<mediaobject>
<imageobject>
<imagedata fileref="fig8o&figtype;"/>
</imageobject>
<caption>
<para>Figure 5: Transfer of confidential information using SSL. Step numbers correspond to those in the textual account
</para>
</caption>
</mediaobject>
</section>
<section>
<title>Part Three: Secure Session Closure
</title>
<orderedlist inheritnum="ignore" continuation="continues">
<listitem>
<para>Abigail and Brian both discard their session keys.</para>
</listitem>
<listitem>
<para>Brian closes the secure session.</para>
</listitem>
</orderedlist>
<para>Finally, Brian sends Abigail her item and her credit card company the bill.</para>
<mediaobject>
<imageobject>
<imagedata fileref="fig7o&figtype;"/>
</imageobject>
<caption>
<para>Figure 6: SSL session closure. Step numbers correspond to those in the textual account
</para>
</caption>
</mediaobject>
</section>
</section>
</chapter>
<chapter>
<title>3 Mobile Internet Security</title>
<section>
<title>3.1 Wireless Transport Layer Security (WTLS)</title>
<para>Mobile Internet security uses the same methods of encryption, hashing, digital certificates and digital signatures that SSL provides for the terrestrial Internet. However, instead of SSL, the Mobile Internet is served by a streamlined protocol called Wireless Transport Layer Security (WTLS). WTLS is an optional component of the Mobile Internet's Wireless Application Protocol (WAP) stack. It resides between the Wireless Datagram Protocol (WDP) and the Wireless Transaction Protocol (WTP) layers of the WAP stack. The structure of the WAP stack is shown in Figure 7.
</para>
<mediaobject>
<imageobject>
<imagedata fileref="fig10o&figtype;"/>
</imageobject>
<caption>
<para>Figure 7: The WAP stack
</para>
</caption>
</mediaobject>
<para>Like any Mobile Internet transaction, a secure Mobile Internet transaction extends across both the mobile telephone network and the Internet, using WAP for the wireless part of the journey, the Hypertext Transfer Protocol (HTTP) suite for the Internet part, and a WAP gateway in the middle to translate between the two. Figure 8 shows an overview of Mobile Internet communication, from the mobile device at one end to the HTTP server at the other. If security is required across the whole communication channel, SSL can be used between the WAP gateway and the HTTP server. Alternatively, the content provider can host the gateway themselves. (As will be seen later, this arrangement provides optimum security.)
</para>
<mediaobject>
<imageobject>
<imagedata fileref="fig9o&figtype;"/>
</imageobject>
<caption>
<para>Figure 8: WAP communication overview
</para>
</caption>
</mediaobject>
<para>Like WAP as a whole, WTLS uses the Internet as a model for its procedures and is very similar, in outline, to SSL. However, it has a number of additional characteristics:</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="bold">Compact coding.</emphasis> WTLS employs more compact coding than SSL, in order to keep messages as short as possible and to minimise the time and processing power required by the client device to interpret and transmit them. These measures help to offset the speed limitations imposed by the high latency and low bandwidth of wireless networks. They also compensate for the low power and computational resources of mobile devices.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Datagram support.</emphasis> WTLS operates directly above WAP's Wireless Datagram Protocol (WDP), and therefore needs to accommodate the unreliability and unpredictability of connectionless datagram communication. Rigorous confirmation and retransmission procedures are rendered doubly important by the intermittency and variable quality of radio transmission.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Optimised handshakes.</emphasis> WTLS allows the WAP gateway, acting as a server to the mobile WAP client, to authenticate the client by obtaining the client's digital certificate from an external source, rather than the client itself. This reduces the processing and memory burden on the client.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Dynamic key refreshing.</emphasis> Communication via radio signals is particularly vulnerable to 'tapping' by third parties. As an extra security measure against eavesdropping, WTLS allows for the symmetric session key to be changed regularly over the course of the session, without the need for a clean handshake.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Fast encryption and hashing algorithms.</emphasis> WTLS uses the quickest, most efficient algorithms available for hashing and encryption (see Section 2), so that client processing time and power consumption are kept within reasonable limits.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Client-gateway rather than client-server coverage.</emphasis> Unlike SSL, WTLS does not span the whole of the communication channel from the client to the content provider's HTTP server, but only communication over the mobile telephone network between the client and the WAP gateway. If security is also required between the gateway and the HTTP server, it must be implemented using SSL.</para>
</listitem>
</itemizedlist>
<para>The complete WTLS specification can be found on the WAP Forum's Web site at <ulink url="www.wapforum.org">www.wapforum.org</ulink>.
</para>
<section>
<title>3.1.1 WTLS Implementation Classes
</title>
<para>The WTLS specification allows for three classes (levels) of WTLS implementation:
</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="bold">Class 1: Anonymous encryption.</emphasis> Data is encrypted, but certificates are not exchanged between the client and the gateway.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Class 2: Encryption with server authentication.</emphasis> Data is encrypted and the client requires a digital certificate from the server.</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">Class 3: Encryption with client and server authentication.</emphasis> Data is encrypted and the client and the server exchange digital certificates.</para>
</listitem>
</itemizedlist>
</section>
<section>
<title>3.1.2 WTLS Handshake
</title>
<para>The WTLS handshake is very similar to the SSL handshake. The following example illustrates the most common form of the WTLS handshake, that for WTLS class 2 (see Section 3.1.1). This involves the client authenticating the gateway, but not vice versa. It is illustrated in Figure 9.
</para>
<para>This example shows the <emphasis role="bold">full handshake</emphasis>. WTLS also uses an <emphasis role="bold">abbreviated handshake</emphasis> for resumption of a previously established session. This involves re-exchanging a session identification code agreed when the session was first established.
</para>
<orderedlist inheritnum="ignore" continuation="restarts">
<listitem>
<para>Bollocks!</para>
</listitem>
<listitem>
<para>Abigail, a WAP phone user user, sees an item she would like to buy on a WAP site.</para>
</listitem>
<listitem>
<para>Abigail activates a link on her WAP phone that sends a request for a secure Internet session to the WAP gateway. The following information is appended to the request:</para>
<para>- Various information about what versions of WTLS Abigail's WAP browser supports, what encryption algorithms it supports, and so on.</para>
<para>- Some randomly generated data. This will be used, along with other data, to generate the session key (see steps 5 onward).</para>
</listitem>
<listitem>
<para>The gateway receives Abigail's request for a secure session and sends her the following items:
</para>
<para>- Its digital certificate, including its public key. The certificate is signed by a trusted CA using its private key.
</para>
<para>- Information about what versions of WTLS, encryption algorithms and so on are supported by the WAP gateway.
</para>
<para>- Some randomly generated data which will be used in the generation of the session key.
</para>
<para>In WTLS class 3 (see Section 3.1.1) the gateway would also request Abigail's digital certificate at this point. Alternatively, it could obtain Abigail's certificate from an external source on the Internet - a procedure which characterises the <emphasis role="bold">optimised WTLS handshake</emphasis>.</para>
</listitem>
<listitem>
<para>Abigail validates the gateway's certificate as outlined in Section 2.6.1. If the validation is successful, she is happy that the gateway's proprietor is genuine and trustworthy.
</para>
</listitem>
<listitem>
<para>Abigail performs a series of operations on the random data she sent to the gateway, and the random data the gateway sent to her, to produce the premaster secret.
</para>
</listitem>
<listitem>
<para>Abigail encrypts the premaster secret using the gateway's public key and sends it to the gateway. (In WTLS class 3, she would also send her digital certificate for the gateway to validate.)
</para>
</listitem>
<listitem>
<para>The gateway receives the premaster secret from Abigail.
</para>
</listitem>
<listitem>
<para>The gateway decrypts the premaster secret. The gateway and Abigail simultaneously perform a series of operations on it, to arrive at the master secret.</para>
</listitem>
<listitem>
<para>Abigail and the gateway simultaneously perform a series of operations on the master secret to arrive at the session key (see Section 2.4.3), which will be used to encrypt the information they want to send to each other.
</para>
</listitem>
<listitem>
<para>Abigail sends the gateway two messages. The first confirms that all further messages from her will be encrypted using the session key. The second is an encrypted message that formally ends the handshake from her side.
</para>
</listitem>
<listitem>
<para>The gateway sends Abigail two messages. The first confirms that all further messages from it will be encrypted using the session key. The second is an encrypted message that formally ends the handshake from the gateway's side.
</para>
</listitem>
</orderedlist>
<mediaobject>
<imageobject>
<imagedata fileref="fig5out&figtype;"/>
</imageobject>
<caption>
<para>Figure 9: WTLS handshake
</para>
</caption>
</mediaobject>
</section>
<section>
<title>3.1.3 Digital Certificate Formats
</title>
<para>WTLS specifies two possible formats for digital certificates:</para>
<itemizedlist>
<listitem>
<para>
<emphasis role="bold">X.509.</emphasis> This is the standard format for digital certificates in SSL, and is optional in implementations of WTLS. However, it is not supported by the current generation of WAP client devices.
</para>
<para>The principal information contained in an X.509 certificate is:
<itemizedlist>
<listitem>
<para>The subject's name</para>
</listitem>
<listitem>
<para>The issuing CA's name</para>
</listitem>
<listitem>
<para>The certificate's validity period
</para>
</listitem>
<listitem>
<para>The asymmetric and symmetric algorithms used for key exchange
</para>
</listitem>
<listitem>
<para>The subject's public key
</para>
</listitem>
<listitem>
<para>The digital signature of the issuing CA
</para>
</listitem>
<listitem>
<para>Alternative names for the subject (optional)
</para>
</listitem>
<listitem>
<para>Allowed key usage - for example, whether the subject's public key may be used for encryption, server authentication, signing other certificates, and so on (optional)
</para>
</listitem>
</itemizedlist>
</para>
</listitem>
<listitem>
<para>
<emphasis role="bold">WTLS.</emphasis> WTLS certificates are similar to X.509 certificates but more compactly coded, so as to suit the high latencies and low bandwidth of wireless networks, and the limited processing reources of WAP client devices. WTLS certificates also omit some of X.509's non-essential fields, such as alternative subject names and key usage options.
</para>
<para>A WTLS certificate includes the following information:</para>
<itemizedlist>
<listitem>
<para>The subject's name
</para>
</listitem>
<listitem>
<para>The issuing CA's name
</para>
</listitem>
<listitem>
<para>The certificate's validity period
</para>
</listitem>
<listitem>
<para>The asymmetric and symmetric algorithms used for key exchange
</para>
</listitem>
<listitem>
<para>The subject's public key
</para>
</listitem>
<listitem>
<para>The digital signature of the issuing CA</para>
</listitem>
</itemizedlist>
</listitem>
</itemizedlist>
</section>
<section>
<title>3.1.4 Certificate Revocation in WTLS
</title>
<para>On the terrestrial Internet, a CA can revoke a certificate it has issued before the end of the certificate's validity period, if the security of the owner's private key has been compromised or if there is new reason to doubt the owner's identity or integrity.
</para>
<para>Certificate revocation on the terrestrial Internet is implemented by means of <emphasis role="bold">certificate revocation lists</emphasis> issued by CAs. When an Internet client receives a certificate from a secure server, it retrieves the signing CA's certificate revocation list from the Internet, checks that the certificate does not appear it, and if not, accepts the certificate.
</para>
<para>On the Mobile Internet, it is impracticable for a small client device to check a revocation list every time it downloads a gateway's certificate. The problem of revocation is therefore addressed by the use of <emphasis role="bold">short-lived certificates</emphasis>. The CA, instead of issuing the secure WAP gateway with a single certificate valid for a long period, sends it a fresh certificate at short intervals throughout that period - for example every 25 hours. Each certificate is only valid until the next one arrives. If the CA needs to revoke its endorsement of a gateway (for example, because the security of the gateway's private key has been compromised), it simply stops sending the gateway certificates. Clients of the gateway will begin receiving expired certificates, and therefore will know that its security can no longer be relied on.
</para>
</section>
</section>
<section>
<title>3.2 WTLS in Alligata Secure
</title>
<para>NOTE: THIS SECTION WILL NEED UPDATING.
</para>
<section>
<title>3.2.1 Supported WTLS Implementation Classes
</title>
<para>
Alligata Secure supports all three WTLS implementation classes.
</para>
</section>
<section>
<title>3.2.2 Supported Digital Certificate Formats
</title>
<para>Alligata Secure supports both X.509 and WTLS certificates. Note, however, that X.509 certificates are not currently supported by WAP client devices.
</para>
</section>
<section>
<title>3.2.3 Supported Encryption Algorithms
</title>
<para>Alligata Secure supports asymmetric keys generated by the RSA alogorithm and symmetric keys generated by the MC5 algorithm. [check]
</para>
</section>
</section>
<section>
<title>3.3 End-to-End Mobile Internet Security
</title>
<para>As we have seen, WTLS provides security between the client device and the WAP gateway. Most secure Mobile Internet transactions will also require security between the WAP gateway and the HTTP server. This can be implemented using one of two arrangements:
</para>
<itemizedlist>
<listitem>
<para>SSL can be used between the gateway and the HTTP server. This method presents a very slight security risk, because data is momentarily held unencrypted inside the gateway (a phenonmenon known as the 'WAP Gap'). It is therefore important that administrative access to the gateway is strictly limited, that the relationship between the gateway host and the content provider is strong and trusting, and that the decrypted data is never stored outside the gateway's memory. This set-up is not recommended for operations requiring guaranteed security, such as online banking.
</para>
</listitem>
<listitem>
<para>The gateway can be hosted by the content provider and placed behind the content provider's firewall. This set-up obviates both the 'WAP Gap' and the need for SSL between the gateway and the HTTP server. The content provider can, if they want, act as an Internet service provider (ISP) to the whole of the Mobile Internet, once the secure transaction is over. Alternatively, the content provider can close the secure WAP connection after the secure transaction has taken place, in which case the client user must dial in to their usual gateway in order to view other WAP sites.
</para>
</listitem>
</itemizedlist>
<para>Figure 10 outlines a secure Mobile Internet transaction of the second type, with the WAP gateway behind the content provider's firewall. Abigail is now the user of a WAP client device, communicating with Brian via the WAP gateway.</para>
<mediaobject>
<imageobject>
<imagedata fileref="fig6out1&figtype;"/>
</imageobject>
<caption>
<para>Figure 10: WTLS transaction, with the WAP gateway hosted by the content provider
</para>
</caption>
</mediaobject>
</section>
</chapter>
<chapter>
<title>4 Using Alligata Secure with OpenSSL</title>
<para>NOTE: THIS SECTION IS INCOMPLETE AND IN PLACES INACCURATE. IT MAY, HOWEVER, BE USABLE AS THE BASIS FOR THE DOCUMENTATION FOR THE SECURE VERSION OF [KANNEL], WHEN THE LATTER IS RELEASED.</para>
<para>Alligata Secure is supplied with the OpenSSL open source software toolkit. OpenSSL includes a library of general purpose security functions that you can use in conjunction with Alligata Secure to implement secure Mobile Internet services. OpenSSL enables you to:
</para>
<itemizedlist>
<listitem>
<para>create symmetric or asymmetric keys
</para>
</listitem>
<listitem>
<para>create [digital certificates]
</para>
</listitem>
<listitem>
<para>encrypt messages
</para>
</listitem>
<listitem>
<para>calculate message digests
</para>
</listitem>
</itemizedlist>
<para>Of OpenSSL's features, creation of symmetric keys, message encryption and digest calculation are incorporated into the Alligata Secure software. You can customise them by changing the configuration variables described in Section 4.X. Before you do anything else, however, you must create an asymmetric key pair.
</para>
<section>
<title>4.1 Creating an Asymmetric Key Pair
</title>
<para>An asymmetric key pair is required for WTLS connections between a WAP gateway and client devices (see Section 3). Alligata Secure supports keys generated by the RSA algorithm.
</para>
<para>The following instructions show you how to create an RSA key pair using OpenSSL. Many additional options are also available: see the OpenSSL man pages (in particular openssl and genrsa) for details.
</para>
<formalpara><title>To create an asymmetric key pair:</title>
<para>
<orderedlist inheritnum="ignore" continuation="restarts">
<listitem>
<para>Create three or four files containing random data. You can do this by using the command
</para>
<para>
<userinput moreinfo="none">echo <replaceable>random_string </replaceable>><replaceable> file_name</replaceable></userinput>
</para>
<para>for each file.
</para>
<para>For example:</para>
<para>
<userinput moreinfo="none">echo ;st509tjjm[4t#~{sa{)8EHjhjOSFOhoij > rand1.txt
</userinput>
</para>
<para>These files will be used, together with the random data file $HOME/.rnd, to generate the key pair.
</para>
</listitem>
<listitem>
<para>Type
</para>
<para>
<userinput moreinfo="none">openssl genrsa -rand <replaceable>random_data_files</replaceable> -out <replaceable>output_file -storage_encryption_algorithm</replaceable> -passout <replaceable>password_source</replaceable>
</userinput>
</para>
<variablelist>
<title>Notes:
</title>
<varlistentry>
<term><userinput><replaceable>random_data_file:</replaceable></userinput></term>
<listitem>
<para>the file names should be separated by colons :.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><userinput><replaceable>output_file:</replaceable></userinput></term>
<listitem>
<para>the name of the file to which the public and private keys will be output. Conventionally, the file name should have a <filename>.pem</filename> extension.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><userinput><replaceable>-storage_encryption_algorithm:</replaceable></userinput></term>
<listitem>
<para>the symmetric algorithm used to encrypt the key file. Possible values are <userinput>-des, -des3</userinput> and <userinput>-idea</userinput>. This parameter is nominally optional, but should always be used except for testing.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><userinput><replaceable>password_source:</replaceable> </userinput></term>
<listitem>
<para>the source of the password that will be used to decrypt the key file. This parameter is formatted as follows:
</para>
<variablelist>
<varlistentry>
<term><userinput>pass:<replaceable>password</replaceable>
</userinput></term>
<listitem>
<para><replaceable>password</replaceable> is the password. Avoid except for testing, as Linux utilities such as <command>ps</command> can see the password.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><userinput>env:environment_variable
</userinput></term>
<listitem>
<para>The denoted environment variable's value is the password.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><userinput>file:<replaceable>file_name</replaceable>
</userinput></term>
<listitem>
<para>The first line of the denoted file is the password. Ensure that the file's read permissions are limited to those who will need the password.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><userinput>fd:<replaceable>file_descriptor_number</replaceable>
</userinput></term>
<listitem>
<para>The password is read from the denoted file descriptor.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><userinput>stdin</userinput></term>
<listitem>
<para>The password is read from the standard input.
</para>
</listitem>
</varlistentry>
</variablelist>
<para>Example key generation command:
</para>
<para>
<userinput moreinfo="none">openssl genrsa -rand rand1:rand2:rand3 -out abigailskeys.pem -des3 -passout file:/var/keypass
</userinput>
</para>
</listitem>
</varlistentry>
</variablelist>
</listitem>
<listitem>
<para>Delete the files of random data that you created in Step 1.
</para>
</listitem>
<listitem>
<para>To generate a file containing just the public key, type
</para>
<para>
<userinput moreinfo="none">openssl rsa -in <replaceable>source_file</replaceable> -out <replaceable>output_file</replaceable> -pubout
</userinput>
</para>
<para>For example:
</para>
<para>
<userinput moreinfo="none">openssl rsa -in abigailskeys.pem -out abipub.pem -pubout
</userinput>
</para>
</listitem>
</orderedlist>
</para>
</formalpara>
</section>
</chapter>
</book>
|