The invention relates to data management, and in particular to a method and system for network security management.
Virtual private networks (VPN) utilize the public networks to replace local area networks of enterprises for lower cost and higher expandability. Virtual private networks comprise Customer Premises Equipment-based (CPE-based) VPNs and network-based VPNs. The most popular VPN solution is that the CPE-based VPN creates a virtual private tunnel over the public network to remote CPE-based VPN devices using a Layer 2 Tunneling Protocol (L2TP) or an IP Security Protocol (IPSec).
IPSec is-an encryption method widely used in network communication applications, with maintaining network security to establish a VPN. Security services provided by a VPN using IPSec comprise data confidentiality, content integrity, and data authentication. To achieve the described security services, IPSec uses encryption methods, such as DES, 3DES, and AES, and hash functions, such as MD5 and SHA-1, to provide different security protocols (AH or ESP) or packet modes (Transport mode or Tunnel mode) according to user requirements.
IPSec enables users to share secret data using “shared secret”. Users, however, share the only key, the system can just verify the key with single password, such that users cannot login a system with individual username and password, resulting in difficult in system security management.
Accordingly, an object of the present invention is to provide a method for data security management, enabling identity verification for individual user using a pre-shared key.
According to the object described, the present invention provides a method for network security management.
A user database is first established, comprising usernames and passwords for all users. A pre-shared key is divided into both username (UN) and password (PW) parts, indicating pre_share_secret=(UN|PW). Next, a first key is derived according to a secret key algorithm and the shared key, which is generated by a pseudo random function (PRF) referring to a HMAC-MD5 algorithm, indicating SKEYID=HMAC-MD5[(UN|PW), (NI|NR)]. Next, the value of the first key is inserted into a message 5, and the message is transferred to the responder.
Next, the responder calculates key values of all users stored in the user database that is represented as HASH_I(UN1, PW1), HASH_I(UN2, PW2), . . . , HASH_I(UNN, PWn), and restores the calculating result to the database. When receiving the first key value (HMAC_I) embedded in the message 5 from the initiator, the responder compares the first key value with the key values stored in the database. The responder calculates a key value thereof (HMAC_R) according to the comparing result and transfers the key value to the initiator. If the username and password embedded in the first key has been registered to the responder, the responder connects to the initiator, or refuses the connection.
The present invention further provides a system for network security management.
The system comprises a client, including an analysis unit, and a server, including a calculation unit, a comparison unit, and a user database comprising usernames and passwords of all users registered thereto, which indicates (UN1, PW1), (UN2, PW2), . . . , (UNn, PWn).
The analysis unit embeds a username and password of a user into a shared key, represented as pre_share_secret=(UN|PW), and derives a first key according to IKE definition and the shared key using a HMAC-MD5 algorithm, in which the first key indicates SKEYID=HMAC-MD5[(UN|PW), (NI|NR)]. Next, the analysis unit insets a value of the first key into a message 5 and the client transfers the message to the server. The message 5 is an encryption message for identification protection to the client in IKE negotiation phase 1.
The calculation unit calculates key values of all users stored in the database that is represented as HASH_I(UN1, PW1), HASH_I(UN2, PW2), . . . , HASH_I(UNN, PWn), and restores the calculating result to the user database. When the server receives the first key value (HMAC_I) embedded in the message 5 from the client, the comparison unit compares the first key value with key values of all user stored in the user database, and the calculation unit calculates a key value of the server (HMAC_R). If the username and password embedded in the first key has been registered to the server, the server connects to the initiator, or refuses the connection.
The method enables identity verification for individual user using a pre-shared key, enhancing protection of personal secret data and performance of system security management.
A detailed description is given in the following embodiments with reference to the accompanying drawings.
The present invention can be more fully understood by reading the subsequent detailed description and examples with references made to the accompanying drawings, wherein:
The present invention discloses a method and system for network security management.
For being unable to verifying the username and password simultaneously, the method of the invention embeds a username and password into a pre-shared key and uses Internet Key Exchange (IKE) from Internet Engineering Task Force (IETF) and a private key algorithm for identify verification, in which the algorithm is Hass Message Authentication Code (HMAC).
IKE is a protocol for automatically creating, negotiating, modifying, and deleting security association (SA) between two hosts in the Internet. Information included in SA is used for creating a security tunnel between both sides in the Internet during data transmission, in which the information comprises. algorithms and keys for packet encryption or verification, life cycles of keys and SA, and serial numbers for avoiding duplicate attacking. IKE is performed based on Internet Security Association and Key Management Protocol (ISAKMP), and the ISAKMP structure supports Oakley and SKEME (Secure Key Exchange Mechanism for Internet) protocols. IPSec can manage, verify, and exchange SA safely based on IKE and provides verification of IPSec groups, IPSec key negotiation, and IPSec SA creation. Definitions of IPSec and IKE can be referenced in RFC (Request for Comments) 2401˜2409.
A user database is first established, comprising usernames and passwords for all users (step S1).
A pre-shared key is divided into both username (UN) and password (PW) parts (step S2), indicating pre_share_secret=(UN|PW). Next, a first key is derived according to a secret key algorithm and the shared key (step S3), which is generated by a pseudo random function (PRF) referring to a HMAC-MD5 algorithm, indicating SKEYID=HMAC-MD5[(UN|PW), (NI|NR)].
IKE adopts a main mode for user identify protection in negotiation phase 1, in which the main mode comprises six messages transferred between an initiator and a responder, which each sends three messages. Messages 1 and 2 refer to proposal and selection of an encryption method relating to the initiator and responder separately, and messages 3 and 4 refer to random numbers (NI and NR) of the initiator and responder separately, in which length of the numbers are from 64 to 2048 bits. Messages 5 and 6 encrypt identification data of the initiator and responder separately using the encryption method from the messages 1 and 2. The method of the invention inserts the value of the first key, combining username and password of a user, into the message 5, and transfers the message to the responder (step S4).
The user database comprises identification data (usernames and passwords) of all users registered to the responder, in which the data is represented as (UN1, PW1), (UN2, PW2), . . . , (UNn, PWn). Next, the responder calculates key values of all users stored in the user database that is represented as HASH_I(UN1,PW1), HASH_I(UN2, PW2), . . . , HASH_I(UNn, PWn), and restores the calculating result to the database (step S5). When receiving the first key value (HMAC_I) embedded in the message 5 from the initiator, the responder compares the first key value with the key values stored in the database (step S6). Next, the responder calculates a key value thereof (HMAC_R) according to the comparing result and transfers the key value to the initiator (step S7). If the username and password embedded in the first key has been registered to the responder, the responder connects to the initiator, or refuses the connection.
The system comprises a client 100, including an analysis unit 110, and a server 200, including a calculation unit 210, a comparison unit 230, and a user database 250 comprising usernames and passwords of all users registered thereto, which indicates (UN1, PW1), (UN2, PW2), . . . , (UNn, PWn).
Analysis unit 110 embeds a username and password of a user into a shared key, represented as pre_share_secret=(UN|PW), and derives a first key according to IKE definition and the shared key using a HMAC-MD5 algorithm, in which the first key indicates SKEYID=HMAC-MD5[(UN|PW), (NI|NR)]. Next, Analysis unit 110 insets a value of the first key into a message 5 and client 100 transfers the message to server 200. The message 5 is an encryption message for identification protection to client 100 in IKE negotiation phase 1.
Calculation unit 210 calculates key values of all users stored in the database that is represented as HASH_I(UN1, PW1), HASH_I(UN2, PW2), . . . , HASH_I(UNn, PWn), and restores the calculating result to user database 250. When server 200 receives the first key value (HMAC_I) embedded in the message 5 from client 100, comparison unit 230 compares the first key value with key values of all user stored in user database 250, and calculation unit 210 calculates a key value of server 200 (HMAC_R) If the username and password embedded in the first key has been registered to server 200, server 200 connects to the initiator, or refuses the connection.
The method of the present invention enables identity verification for individual user using a pre-shared key, enhancing protection of personal secret data and performance of system security management.
While the invention has been described by way of example and in terms of the preferred embodiments, it is to be understood that the invention is not limited to the disclosed embodiments. To the contrary, it is intended to cover various modifications and similar arrangements (as would be apparent to those skilled in the art). Therefore, the scope of the appended claims should be accorded the broadest interpretation so as to encompass all such modifications and similar arrangements.
| Number | Date | Country | Kind |
|---|---|---|---|
| 93122258 | Jul 2004 | TW | national |