A directory
What’s the difference between a free front end and a salted fish
directory |
---|
A directory |
The preface |
Chapter III History of HTTP |
HTTP / 0.9 3.1 |
HTTP / 1.0 3.2 |
HTTP / 1.1 3.3 |
HTTP / 2.0 3.4 |
HTTP / 3.0 3.5 |
Four HTTP |
4.1 Request Method |
4.2 the advantages and disadvantages |
4.3 Differences between GET and POST |
4.3.1 【 error 】 The length of the parameter to be transmitted in the GET request is limited |
4.3.2 【 error 】 The POST method is more secure than the GET method |
4.4 keep-alive |
4.5 Differences between HTTP and TCP |
5 HTTP status code |
5.1 1 xx |
5.2 2 xx |
5.3 3 xx |
5.4 4 xx |
5.5 5 xx |
Solve communication security problems |
6.1 Symmetric Encryption |
6.2 Asymmetric Encryption |
6.3 Symmetric Encryption + Asymmetric Encryption |
6.4 Third-party Authentication |
6.5 Third-party Authentication Security |
Seven HTTPS |
7.1 Working Principles |
7.2 the advantages |
7.3 disadvantages |
7.4 Comparison between HTTP and HTTPS |
Eight HTTP / 2 |
8.1 Header Compression |
8.2 Multiplexing |
Nine digressions: MD5 |
X References |
10.1 the MD5 |
The preface
HTTP Sometimes interviewers will ask questions about simple things like HTTP status codes, GET and POST.
Here is a summary of HTTP related information.
At the same time, because it is the information found on the Internet, there will be omissions, mistakes, welcome correction.
And because Jsliang is lazy, some of the images are copied from some excellent reference articles, if infringement, immediately delete and redraw, thank you for your support.
Chapter III History of HTTP
HTTP / 0.9 3.1
Transfer very small files, no HTTP request header and request body, and the server does not return header information.
Jsliang description:
HTTP/0.9 is not designed to be too complex and is only used to transfer very small files.
HTTP / 1.0 3.2
The core appeal is to support multiple types of file download. Add request headers and response headers to support many different types of data. Status codes, Cache mechanisms, user agents, etc.
Jsliang description:
- To deal with
HTTP / 0.9
The problems have been optimized to support multi-type file downloads and other content. HTTP / 1.0
Three request methods are defined:GET
.POST
和HEAD
Methods.
HTTP / 1.1 3.3
- To improve the
HTTP / 1.0
Version every timeHTTP
Communication needs to be establishedTCP
Connection, transmissionHTTP
Data redisconnectionTCP
Connection awkward situation, support continuous connection. As long as the browser or server is not explicitly disconnected, theTCP
The connection will always remain (enabled by defaultkeep-alive
). - if
TCP
For some reason, a request in the channel does not return in time and blocks all subsequent requests (queue header blocking), soHTTP / 1.1
To solve the problem of queue head blocking by pipelining. HTTP / 1.0
Each domain name binding is uniqueIP
Address, a server can only support one domain name.HTTP / 1.1
Request header incrementHost
Field that represents the current domain name address that the server can vary based onHost
Values do different processing. In this way, a physical host can be bound to multiple virtual hosts, each virtual host has its own separate domain name.HTTP / 1.0
You need to set the full data size in the response header to receive the data, but as the server evolves, many pages are generated dynamically without knowing the final size of the transferred data.HTTP / 1.1
The introduction ofChunk transfer
To solve this problem, the server splits the data into arbitrary blocks, sends each block with the length of the previous block, and finally uses a zero-length block as a signal that the data has been sent, thus enabling dynamic content.- The client
Cookie
Safety mechanism.
Jsliang description:
HTTP / 1.1
The default openConnection: keep-alive
And make oneTCP
Connections can be sent/received multiple timesHTTP
The request.HTTP / 1.1
Six request methods have been added:OPTIONS
,PUT
,PATCH
,DELETE
,TRACE
和CONNECT
Methods.
HTTP / 2.0 3.4
- Use only one domain name
TCP
Long connections and eliminates queue head blocking issues - Once a
TCP
Once the connection is established, it’s sending data, just startTCP
The protocol sends data at a very slow speed and then speeds it up slowly until it reaches an ideal speed, a process we call slow start.HTTP / 2.0
Implement a domain name to use only oneTCP
Long connections to transfer data, so that the entire page resource download process requires only one slow start, while avoiding multipleTCP
Problems with competing bandwidth connections. - Queue head blocking problem, waiting for the request to complete before going to the next resource, this way is undoubtedly the slowest, so
HTTP/2
Parallel requests for resources need to be implemented, meaning that requests can be sent to the server at any time, without waiting for other requests to complete, and the server can then return the processed resources to the browser at any time.
Jsliang description:
- The head of compression:
HTTP/2
Compressing the message header reduces the size of the transmitted data - multiplexing: Indicates that multiple requests pass through one
TCP
The connection completes concurrently - Server push: The server can actively push resources to the client
HTTP / 3.0 3.5
Jsliang description:
- Implements something like
TCP
The function of flow control and transmission reliability. - Integrated with
TLS
Encryption. - To achieve the
HTTP/2
Multiplexing in. - Realize the quick handshake function.
Four HTTP
The Web uses a Protocol named HTTP (HyperText Transfer Protocol) as a specification to complete a series of operations from the client to the server. An agreement is a stipulation of rules. It can be said that the Web is built on the HTTP protocol for communication.
HTTP was originally intended to allow researchers to share knowledge and information, so its main function is document transfer, which is a protocol for document transfer.
4.1 Request Method
- GET: Obtains resources
- HEAD: obtains the meta information of the resource
- POST: submits or uploads data
- PUT: Modifies data
- DELETE: Deletes a resource (hardly needed)
- CONNECT: Establishes the connection channel for the proxy server
- OPTIONS: Lists the request methods that can be applied to the resource for cross-domain requests
- TRACE: Traces the transmission path of the request and response
4.2 the advantages and disadvantages
Advantages:
- Flexible and extensible, mainly reflected in two aspects. One is semantically free, specifying only basic formats, such as separating words with Spaces and separating fields with newlines, while other parts have no strict syntactic restrictions. Another is the variety of transmission forms, not only can transmit text, but also can transmit pictures, videos and other arbitrary data, very convenient.
- Reliable transport.
HTTP
Based on theTCP/IP
“, thus inheriting this feature. This belongs toTCP
The features of the. - Request-reply. Of course, the requester and the responder are not only between the client and the server. If a server acts as a proxy to connect to the server at the back end, the server will also act as the requester.
- stateless. The state here refers to the context information of the communication process, while each time
HTTP
Requests are independent and irrelevant and do not need to retain status information by default.
Disadvantages:
- stateless. Stateless is the case in scenarios where long connections are required and a large amount of context information needs to be saved to avoid transferring a large amount of repeated information
HTTP
The shortcomings of the. - Plaintext transmission. Packets (mainly headers) in the protocol do not use binary data, but text.
- Queue head congestion problem. when
HTTP
When the long connection is enabled, the same one is usedTCP
The connection can only process one request at a time, so if the current request takes too long, other requests can only be blocked.
4.3 Differences between GET and POST
There is no difference between THE GET and POST methods, but the packet formats are different.
GET and POST are only two request modes in THE HTTP protocol, which is an application layer protocol based on TCP/IP.
Both GET and POST use the same transport layer protocol, so there is no difference in transport.
GET
Access to resources;POST
Submit/upload data.GET
The request length is limited in the browser, whilePOST
Don’t.GET
Requests are actively retained by the browser (history), whilePOST
Not by default.
4.3.1 【 error 】 The length of the parameter to be transmitted in the GET request is limited
We often say that the size of GET request parameters is limited, while the size of POST request parameters is unlimited.
There is a problem with this, as the HTTP protocol never actually sets a limit on the length of GET/POST requests.
Restrictions on GET request parameters come from browsers or Web servers that limit the length.
The maximum length varies from browser to browser and Web server to Web server.
4.3.2 【 error 】 The POST method is more secure than the GET method
【 正 】POST is safer than GET because the data is not visible in the URL of the address bar.
In terms of transmission, HTTP is transmitted in plain text on the network, which can be completely obtained through packet capture tools.
If you want to be secure, use HTTPS.
4.4 keep-alive
HTTP keep-alive is also called an HTTP long connection.
It reduces the overhead of creating/closing multiple TCP connections by reusing a SINGLE TCP connection to send/receive multiple HTTP requests.
In HTTP/1.0, if the request header contains:
Connection: keep-alive
Copy the code
Keep-alive is enabled, and the same content is contained in the packet header returned by the server.
In HTTP/1.1, keep-alive is turned on by default unless it is explicitly turned off:
Connection: close
Copy the code
Of course, in addition, we can also set the disconnect time and so on:
Keep-Alive: timeout=5, max=100
Copy the code
This means that the TCP channel can hold for 5 seconds, and Max =100 means that the long connection will be disconnected after receiving 100 requests at most.
4.5 Differences between HTTP and TCP
HTTP is an application layer protocol, which defines the transmission of data content specifications; TCP is the underlying communication protocol, which defines the specification of data transmission and connection mode.
HTTP data is transmitted using TCP, so HTTP support must also support TCP.
5 HTTP status code
The HTTP status code has three digits and is classified into five classes:
- 1XX: indicates that the protocol processing is in the intermediate state and subsequent operations are required.
- 2XX: indicates that the status is successful.
- 3XX: Indicates the redirection status. The location of resources changes and a request needs to be made again.
- 4XX: The request packet is incorrect.
- 5XX: An error occurs on the server.
5.1 1 xx
- 101 Switching Protocols: Upgrade to HTTP
WebSocket
If the server agrees to the change, it sends a status code of 101.
5.2 2 xx
- 200 OK: indicates the status code of the request success. The response body contains data.
- 204 No Content: Indicates the same meaning as 200, but the response packet does not contain the body of the entity.
- 206 Partial Content: indicates that some content requests are successful. Use scenarios for HTTP block download and breakpoint continuation, of course, with the corresponding response header field
Content-Range
.
5.3 3 xx
- 301 Move Permanently: Permanently redirects. HTTP upgrade HTTPS, before the site is no longer used, that is 301.
- 302 Found: Temporary redirection. The current site is temporarily unavailable, that is 302, may be switched back later.
- 304 Not Modified: This status code is returned when the negotiated cache is hit.
5.4 4 xx
- 400 Bad Request: The Request is invalid. Usually, the data format of the front and back ends is inconsistent or other reasons.
- 403 Forbidden: The server receives requests but refuses to execute them. For example, the server does not have permissions or is prohibited by laws.
- 404 Not Found: The resource is Not Found.
5.5 5 xx
- 500 Internal Server Error: The Server has reported an Error. Sometimes you can see the Error information of back-end PHP and other technologies in Response.
- 502 Bad Gateway: The server is running properly, but an access error occurs.
- 503 Service Unavailable: The server is busy or down for maintenance, and cannot process requests temporarily.
Solve communication security problems
6.1 Symmetric Encryption
Symmetric encryption can be understood as a reversible transformation of the original data. For example, Hello can be converted to Ifmmp, and the rule is that each letter becomes the letter after it in the alphabet. The secret key here is 1, and the other party can restore the original message Hello by taking Ifmmp.
Symmetric encryption is introduced, adding two steps to the HTTPS handshake process:
- Client: Hello, I need to initiate an HTTPS request
- Server: Hello, your secret key is 1
But the network is not secure. If the symmetric key is intercepted at the time of transmission, the message can be accessed and tampered with by middlemen.
6.2 Asymmetric Encryption
Asymmetric encryption has two secret keys: a public key and a private key.
Public and private keys come in pairs. Each user has a different set of public and private keys.
The server keeps the private key, which is not made public, and then makes the public key known to everyone.
That is, only the private key can decrypt the content encrypted by the public key (the server retains privacy), and the public key can decrypt the content encrypted by the private key (the public has the right to decrypt).
- Client: Hello, I need to initiate
HTTPS
request - Server :(generating public and private keys), hello, here’s public key 1
- Client: Hello, the information I want to tell you after the public key encryption is
XXX
- Server: decrypts data through the private key
YYY
. The next time you send data, it’s encrypted with a private key.
Because the client and server use two different secret keys, this algorithm is called asymmetric encryption.
Of course, the result is still vulnerable to man-in-the-middle attacks:
Generally speaking, symmetric encryption is faster than asymmetric encryption, and the computing pressure on the server is much less.
6.3 Symmetric Encryption + Asymmetric Encryption
The advantage of using symmetric keys is that the decryption efficiency is faster. The disadvantage is that the symmetric encryption method on the client side is known, and the server side is also known.
The advantage of using asymmetric keys is that the transmitted content cannot be cracked, but the disadvantage is that asymmetric encryption takes more time.
Then we will be symmetric encryption and asymmetric encryption together, take full advantage of their respective advantages.
Asymmetric encryption is used in the key exchange and symmetric encryption is used in the subsequent stage of establishing communication exchange messages.
- Client: The party sending the ciphertext encrypts the other party’s public key to form a “symmetric secret key”.
- Server: decrypt with its own private key to get the “symmetric secret key”, and then communicate with the “symmetric secret key” encryption, and send to the client
- Communication process: Symmetric encryption is used to communicate with each other on the premise that the exchanged keys are secure
In a nutshell:
- The server sends the public key
key2
Send to the client - The client wants you to use it
key3
As a symmetric secret key, so will containkey3
Is usedkey2
After encryption, the encryption is sent to the server - The server receives encrypted packets from the client using the private key
key1
Decrypt it and getkey3
Symmetric secret key of - Then both sides use it
key3
Encrypts and decrypts sent and received packets
HTTPS is a hybrid encryption mechanism that uses both symmetric and asymmetric encryption.
However, this hybrid encryption still does not guarantee the integrity and security of the data, and the key exchange process (before the data is stable communication) can be replaced, so to be perfect, a digital signature (third-party authentication) is required.
6.4 Third-party Authentication
The public key is swapped because the client cannot tell whether a middleman or a server is returning the public key, which is also an authentication problem in cryptography.
In HTTPS, to solve the problem of not being able to verify the correctness of a public key, use a digital certificate Authority (CA) and the digital certificates it issues to solve the problem.
Assume that the encryption mode is MD5. After the website information is encrypted, the private key of a third-party organization is used to encrypt it again to generate a digital signature.
Use MD5 to encrypt the website information and get the content called message digest
- Digital certificate = website information + digital signature
If the middleman intercepts and replaces the server’s public key with his own public key, the existence of digital signature will cause the client verification signature mismatch, thus preventing the problem of the middleman replacing the public key.
The public keys of authoritative third-party certification bodies such as VeriSign, Symantec, and GlobalSign are built into the browser installation.
During signature verification, the client directly obtains the public key of the third-party institution from the local PC and decrypts the encrypted digital signature of the private key to obtain the real signature. Then, the client generates the signature using the signature generation rule to check whether the two signatures match. If the matching authentication succeeds but the certificate fails to be obtained if they do not match.
In order to make it easier to understand, the last final comb:
- CA service process: A server applies to a CA for public key authentication and registers its own public key. After identifying the server, the CA digitally signs the public key and encrypts the digital certificate with its own private key. Digital certificate = website information + digital signature
- The client receives the message: The server sends its certificate and public key to the client when communicating with the client. The client uses the CA’s public key to decrypt the certificate and obtain digital signature A. Then, the client generates the signature according to the CA’s signature generation rules to obtain digital signature B. If they do not match, the request fails; otherwise, the request succeeds.
- The client sends information: this link with mixed encryption (symmetric encryption and asymmetric encryption) subsequent transmission link is consistent, namely: the client to generate a random number, and then through the public key encryption, the encrypted data sent to the server, the server through the private key to decrypt, and then the two sides with a random number corresponding symmetric encryption for data exchange.
- Secure: Operating systems and browsers maintain a list of authoritative third-party certification bodies (including their public keys).
In fact, this comb contains the behind HTTPS works, so you continue to read ~
6.5 Third-party Authentication Security
- Could a middleman tamper with a certificate?
Suppose the middleman tampered with the certificate sent by the server to the client. Since he does not have the CA’s private key, he cannot get the encrypted signature and cannot tamper with the corresponding signature.
After receiving the certificate, the browser uses the CA’s public key to decrypt the certificate and obtain digital signature A. Then, the browser generates the signature according to the CA’s signature generation rules to obtain digital signature B. If they do not match, the request fails.
This terminates the transfer of information to the server.
- Could a middleman swap certificates?
If the middleman sets up another website, also gets the CA certificate, intercepts the original server to send, and sends his certificate to the client, can it succeed?
The answer is no. Because the certificate contains the information (domain name, etc.) of the website corresponding to the original server, the browser compares the domain name in the certificate with the requested domain name to know whether there is a switch.
Seven HTTPS
You can’t talk about HTTPS without talking about its opposite, HTTP.
HTTP is characterized by plaintext transmission, so data may be stolen or tampered with by a third party at every step of transmission.
Specifically, HTTP data passes through the TCP layer and then through WIFI routers, carriers, and target servers, all of which can be picked up and tampered with by middlemen, often referred to as man-in-the-middle attacks.
To protect against such attacks, we had to introduce a new encryption scheme, HTTPS.
To put it simply, HTTPS is a network protocol constructed by HTTP and SSL to encrypt transmission and authenticate identity. It is more secure than HTTP.
The last letter S refers to SSL/TLS, which is located between HTTP and TCP/IP.
7.1 Working Principles
- Browser request
URL
Find the server and send the request to the server. The server returns its certificate (including the server’s public key), the type of symmetric encryption algorithm, and other relevant information to the browser. - Browser check
CA
Check whether the certificate is reliable and valid. - If not, send a warning to the server asking if it can continue to use.
- If so, the browser uses the public key to encrypt a random symmetric secret key containing the encrypted
URL
Send it to the server together. - The server decrypts the key sent by the browser with its own private key, and then gives the symmetrically encrypted key to the browser request
URL
Connection decryption. - The server encrypts the requested web page with a symmetric key sent by the browser, which decrypts the page using the same key.
7.2 the advantages
- use
HTTPS
The protocol authenticates users and servers to ensure that data is sent to the correct client and server. HTTPS
Agreement is madeSSL + HTTP
Protocol a network protocol built to encrypt transmission and authenticate identityHTTP
Protocol security prevents data from being stolen or changed during transmission and ensures data integrity.HTTPS
Is the most secure solution under the current architecture, although not absolutely secure, but it significantly increases the cost of man-in-the-middle attacks.- In August 2014, Google changed its search engine algorithm, saying, “It is better than the same
HTTP
Website, usingHTTPS
Encrypted sites will rank higher in search results.
7.3 disadvantages
HTTPS
The handshake phase is time-consuming and can lead to longer page load times50%
, an increase of10% ~ 20%
The power consumption.HTTPS
The cache is better thanHTTP
High efficiency, increase data overhead.SSL
Certificates also cost money, and more powerful certificates cost more.SSL
Certificates need to be boundIP
Can’t be in the sameIP
IPV4 resources cannot support this consumption.
7.4 Comparison between HTTP and HTTPS
- Concept contrast.
HTTP
It’s hypertext transfer protocol, information is in clear text,HTTPS
It is safeSSL
Encrypted transport protocol. - Cost comparison.
HTTPS
Agreement needs to beCA
Certificate, higher cost. - Connection mode and port. Use different connection methods, different ports, and generally speaking,
HTTP
The protocol port is80
.HTTPS
The port is443
. - Safety comparison.
HTTP
Is simple and stateless;HTTPS
Agreement is madeSSL + HTTP
Protocol a network protocol built for encrypted transmission and identity authenticationHTTP
Protocol security.
Eight HTTP / 2
Since HTTPS is already so good at security, the focus of HTTP improvements is on performance. For HTTP/2, there are two main performance improvements:
- Header compression:
HTTP/2
Compressing the message header reduces the size of the transmitted data - Multiplexing: The simultaneous completion of multiple requests over a SINGLE TCP connection
Of course, there are some disruptive feature implementations:
- Set the request priority
- Server push: The server can actively push resources to the client
8.1 Header Compression
In HTTP/1.1 and prior eras, the request body would typically have a compressed Encoding of the response, specified by the Content-Encoding header field.
However, when the request fields are very complex, especially for GET requests, the request messages are almost all request headers, there is still a lot of room for optimization.
HTTP/2 also uses the corresponding compression algorithm – HPACK for the header field to compress the request header.
8.2 Multiplexing
HTTP queue header blocking problem, its root cause is HTTP based on the request-response model, in the same TCP long connection, the previous request does not get a response, the subsequent request will be blocked.
HTTP/2 addresses header blocking from the HTTP protocol itself, where multiple requests are completed concurrently over a single TCP connection.
Nine digressions: MD5
At least is the university of the time to participate in the network attack and defense course of the people, see symmetric encryption, asymmetric encryption, think of an algorithm used before: MD5.
MD5 encryption can be done in JavaScript by referring to the class library:
<script src="https://cdn.bootcss.com/blueimp-md5/2.10.0/js/md5.min.js"></script>
Copy the code
Then you can directly use:
<script>
window.onload = function () {
const password = md5('jsliang');
console.log(password); // efadd62708ee4cc610691cd1bb9cf381
};
</script>
Copy the code
Then, when doing database security, the back-end may encrypt the plaintext password by MD5, and then save the encrypted hash string into the database.
When a user logs in, the user obtains the password, encrypts it with MD5, and compares it with the database. The user logs in only when the result is consistent.
In this way, if the database is stolen, it is difficult to obtain the actual password of the user.
Of course, cyber attack and defense, more interesting:
- Users should know if they are transferring passwords directly
HTTP
It’s in clear text, so the hacker uses a packet capture toolWireshark
We’ll just have to look it up. - User if yes
md5
After encrypting, it is transmitted to the back end. In fact, the hacker can intercept the request, forge the client, and implement the man-in-the-middle attack.
Is the priest a foot higher than the devil ten feet higher?
No, then there is the need for HTTP to upgrade HTTPS.
Sure, HTTPS is absolutely safe, right? Not necessarily. However, during the university teacher teaching is a simple level of network security attack and defense, modern content jsliang is not to learn ~
In addition, it is worth mentioning that MD5 encryption is essentially a hash function (also called hash function), but compared with one-way cipher constitution, MD5 is an irreversible mapping from plaintext to ciphertext, only the encryption process without the decryption process.
However, it has drawbacks:
- Hash mapping means that it is possible for two different things to map to the same hash
MD5
It has been cracked by the big guys using the collision decryption algorithm, and many decrypts are now cracked by brute force (MD5
The encryption method is public)
So this topic on the topic here, just see symmetric encryption, asymmetric encryption, suddenly consumptive want to talk about it.
X References
- Interview with you: this is a comprehensive overview of the basics of computer networking[Reading Suggestions: 1H]
- Look at the picture to learn HTTPS[Recommended Reading: 30min]
- You know, does HTTPS use symmetric encryption or asymmetric encryption?[Recommended Reading: 30min]
- | MDN HTTP response code【 Reading Suggestions: 20min】
- HTTP infrastructure【 Reading Suggestions: 5min】
- The HTTP status code【 Reading Suggestions: 5min】
- HTTP protocol for front-end basics[Recommended Reading: 30min]
- It’s 9102 years ago and you’re asking the difference between GET and POST【 Reading Suggestions: 20min】
- How to understand the status code of an HTTP response?【 Reading Suggestions: 20min】
- You know the 3XX status code【 Reading Suggestions: 10min】
- HTTP headers and keep-alive modes are explained in detail【 Reading Suggestions: 10min】
- HTTP keep-alive two or three things【 Reading Suggestions: 10min】
- The front end you should know about — caching【 Reading Suggestions: 10min】
- HTTP caching mechanism one two three【 Reading Suggestions: 10min】
- Perform various operations using HTTP headers【 Reading Suggestions: 10min】
- Nine questions from getting started to getting familiar with HTTPS【 Reading Suggestions: 20min】
- Talk about the HTTPS【 Reading Suggestions: 20min】
- Little brother, little sister, I have a TCP, HTTP interview guide do you want?【 Reading Suggestions: 20min】
- A minute to understand HTTPS【 Reading Suggestions: 10min】
- HTTP2 Basic concepts study notes【 Reading Suggestions: 10min】
- In-depth understanding of HOW HTTPS works【 Reading Suggestions: 20min】
- New features for decrypting HTTP/2 and HTTP/3【 Reading Suggestions: 10min】
- HTTP/2 Server Push【 Reading Suggestions: 10min】
- HTTPS (ii) : Hybrid encryption【 Reading Suggestions: 10min】
- HTTPS (3) : digital certificates【 Reading Suggestions: 10min】
- Understand HTTPS encryption thoroughly【 Reading Suggestions: 20min】
- “99% of people GET the difference between GET and POST in HTTP wrong”?[Reading Suggestions: Controversial articles]
- If you dare to make trouble for me on post and get, don’t blame me for pretending to be a pussy[Reading Suggestions: Controversial articles]
10.1 the MD5
- Md5 encryption and decryption[Recommended Reading: 30min]
- C# : use MD5 to encrypt and decrypt user passwords【 Reading Suggestions: 10min】
- Is it possible to repeat MD5?
Jsliang’s document library is licensed by Junrong Liang under the Creative Commons Attribution – Non-commercial – Share alike 4.0 International License. Based on the github.com/LiangJunron… On the creation of works. Outside of this license agreement authorized access can be from creativecommons.org/licenses/by… Obtained.