内容简介:Elliptic curve cryptography is an efficient modern approach to public-key cryptosystems. In this introduction, our goal will be to focus on the high-level principles of what makes ECC work. We will omit implementation details and mathematical proofs, we ca
Elliptic curve cryptography is an efficient modern approach to public-key cryptosystems. In this introduction, our goal will be to focus on the high-level principles of what makes ECC work. We will omit implementation details and mathematical proofs, we can save those for another article.
What It’s For?
A common use of ECC is to encrypt data so that only authorized parties can decrypt it. This has several obvious use cases but is most often used to encrypt internet traffic. For example, we can use ECC to ensure that when we send an email, no one but the recipient can read the message.
ECC is public key cryptography
There are many types of public-key cryptography, and Elliptic Curve Cryptography is just one flavor. Other algorithms include RSA, Diffie-Helman, etc. I’m going to give a very simple background of public-key cryptography as a jumping-off point so that we can discuss ECC and build on top of these ideas. By all means, study more in-depth on public-key cryptography when you have the time.
Public-key cryptography allows the following to happen:
We create two keys, a public key, and a private key. The public key is given freely, and any party can encrypt data by using it. However, the private key is kept secret and only those who hold it will have the ability to decrypt data.
An Example of Public-Key-Cryptography
Let’s pretend that Facebook is going to receive a private post from Donald Trump. Facebook needs to be able to ensure that when the President sends his post over the internet, no one in the middle (Like the NSA, or internet service provider) can read the message. The entire exchange using Public Key Cryptography would go like this:
- Donald Trump Notifies Facebook that he wants to send them a private post
- Facebook sends Donald Trump their public key
- Donald Trump uses the public key to encrypt his post:
“I love Fox and Friends” + Public Key = “s80s1s9sadjds9s”
- Donald Trump sends only the encrypted message to Facebook
- Facebook uses its private key to decrypt the message:
“s80s1s9sadjds9s” + Private Key= “I love Fox and Friends”
As you can see this is a very useful concept. Here are some key points:
- The public key can be sent to anyone. It is public.
- The private key must be kept safe because if someone in the middle were to get the private key, they could decrypt messages.
- Computers can very quickly use the public key to encrypt a message, and the private key to decrypt a message.
- Computers require a very long time (millions of years) to derive the original data from the encrypted message if they don’t have the private key.
How it Works: The Trapdoor Function
The crux of all public-key cryptographic algorithms is that they each have their own unique trapdoor function . A trapdoor function is a function that can only be computed one way, or at least can only be computed one way easily (in less than millions of years using modern computers).
Not a trapdoor function: A + B = C
If I’m given A and B I can compute C. The problem is that if I’m given B and C I can also compute A. This is not a trapdoor function.
Trapdoor function:
“I love Fox and Friends” + Public Key –> “s80s1s9sadjds9s”
If given “I love Fox and Friends” and the public key, I can produce “s80s1s9sadjds9s” , but if given “s80s1s9sadjds9s” and the Public Key I can’t produce “I love Fox and Friends”
In RSA (Probably the most popular public-key system) the trapdoor function relies on how hard it is to factor large numbers into their prime factors.
Public Key: 944,871,836,856,449,473
Private Key: 961,748,941 and 982,451,653
In the example above the public key is a very large number, and the private key is the two prime factors of the public key. This is a good example of a Trapdoor Function because it is very easy to multiply the numbers in the private key together to get the public key, but if all you have is the public key it will take a very long time using a computer to re-create the private key.
Note: In real cryptography, the private key would need to be 200+ digits long to be considered secure.
What Makes Elliptic Curve Cryptography Different?
You would use ECC for the same reasons as RSA. ECC and RSA both generate a public and private key and allows two parties to communicate securely.
ECC allows resource-constrained systems like smartphones, embedded computers, and cryptocurrency networks to use 10% of the storage space and bandwidth required by RSA.
ECC’s Trapdoor Function
This is probably why most of you are here. The trapdoor function is what makes ECC special and different than RSA. The trapdoor function is similar to a mathematical game of pool. First, we start with a certain point on the curve. Next, we use a function (called the dot function) to find a new point. Finally, we keep repeating the dot function to hop around the curve until we finally end up at our last point. Lets walk through the algorithm.
- Starting at A:
- A dot B = -C (Draw a line from A to B and it intersects at -C)
- Reflect across the X axis from -C to C
- A dot C = -D (Draw a line from A to C and it intersects -D)
- Reflect across the X axis from -D to D
- A dot D = -E (Draw a line from A to D and it intersects -E)
- Reflect across the X axis from -E to E
This is a great trapdoor function because if you know where the starting point (A) is and how many hops are required to get to the ending point (E), it is very easy to find the ending point. On the other hand, if all you know is where the starting point and ending point are, it is nearly impossible to find how many hops it took to get there.
Public Key: Starting Point A, Ending Point E
Private Key: Number of hops from A to E
Questions?
Here are just a couple of questions I had when I first learned about ECC. Hopefully, I can address them properly.
How is the second point found? If the dot function is basically drawing a line between two points, don’t you need a second point to start with?
Answer: No. The second point (we will call it -R below) is actually the result of P dot P (let’s assume the first point is called P)
P dot P= -R
So what is P dot P? It is actually just the tangent line of P. See the graphic below:
What happens if the dot function produces a line that will go way off out to some extreme?
If the line doesn’t hit the curve close to the origin, we can actually define a maximum X value where the line will wrap back around and start from the beginning again. See the graphic below for an example.
I get the trapdoor function, but how are public and private keys created in practice? How are they used in conjunction with data to be encrypted?
This is a great question, but it requires a much more in-depth answer. I gave very hand-wavy explanations of both RSA and ECC in this article. However, there are plenty of more technical resources out there and I encourage you to look into them.
Who Cares?
ECC is used as the cryptographic key algorithm in Bitcoin because it potentially can save 90% of the resources used by a similar RSA system. It seems that each year we see more systems moving from a bloaty RSA system to a more modern elliptic curve approach. Hopefully, we’ve helped you gain a high-level understanding ECC and public-key cryptography.
Thanks For Reading!
Follow us on Twitter @q_vault if you have any questions or comments
Take game-like coding courses onQvault Classroom
Subscribe to our Newsletter for more educational articles
Related Articles
– Hashing Passwords – Python Cryptography Examples
很遗憾的说,推酷将在这个月底关闭。人生海海,几度秋凉,感谢那些有你的时光。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
The Web Application Hacker's Handbook
Dafydd Stuttard、Marcus Pinto / Wiley / 2011-9-27 / USD 50.00
The highly successful security book returns with a new edition, completely updated Web applications are the front door to most organizations, exposing them to attacks that may disclose personal infor......一起来看看 《The Web Application Hacker's Handbook》 这本书的介绍吧!
URL 编码/解码
URL 编码/解码
html转js在线工具
html转js在线工具