#php editor Baicao sometimes encounters a common error message during network development: "Error: Unencrypted data received after SSL request." This error message usually appears when using the HTTPS protocol for data transmission, indicating that the data is not encrypted. This issue could lead to data leakage or tampering, so it needs to be addressed promptly. In this article, we will introduce the cause and solution of this error in detail to help developers solve this problem smoothly.
Question content
I have opened a tcp connection to the database server using the following method:
conn, err := net.dial("tcp", "localhost:5432")
I succeeded after running this code:
_, err = conn.Write([]byte(query)) if err != nil { fmt.Printf("Query failed: %v\n", err) return // Read the response and print the result in table view buf := make([]byte, 50000) n, err := conn.Read(buf) if err != nil { fmt.Printf("Failed to read response: %v\n", err) return } fmt.Printf("Response received: %s\n", string(buf[:n]))
It prints: Reply received: n
The server’s log file shows:
2023-02-22 22:59:49.834 pkt [54802] fatal: Unencrypted data received after ssl request
2023-02-22 22:59:49.834 pkt [54802] Details: This may be evidence of a client software bug or an attempted man-in-the-middle attack.
Workaround
By default, the postgresql server requires all of its clients to use ssl encrypted connections, so it will always reject your request.
For testing/development purposes and realizing that your connection will not be secure, there are a few tricks you can use to work around this:
- Create a connection to the tls package and allow it to skip certificate verification.
tlsconfig := &tls.config{ insecureskipverify: true, } conn, err := tls.dial("tcp", "localhost:5432", tlsconfig)
- If you can, always use the
database/sql
package, which abstracts all these database vendor specifics for you. Setsslmode
to disabled.
connstr := "user=myuser password=mypassword dbname=mydb host=localhost sslmode=disable" db, err := sql.open("postgres", connstr) if err != nil { fmt.printf("failed to connect to server: %v\n", err) return } defer db.close()
- Locate the
pg_hba.conf
file in the postgresql installationdata
directory and add the following line to always trust your localhost:
host postgres postgres 127.0.0.1/32 trust
Assume the username is postgres
- Find the
postgres.conf
file in the postgresql installationdata
directory, and set thessl
parameter tooff
.
Keep in mind that all of these configurations will still make your connection insecure and vulnerable to attack.
To create a ssl connection correctly, you need to set up a certificate. This gist should help.
The above is the detailed content of Error: Unencrypted data received after SSL request. For more information, please follow other related articles on the PHP Chinese website!

The article explains how to use the pprof tool for analyzing Go performance, including enabling profiling, collecting data, and identifying common bottlenecks like CPU and memory issues.Character count: 159

The article discusses writing unit tests in Go, covering best practices, mocking techniques, and tools for efficient test management.

This article demonstrates creating mocks and stubs in Go for unit testing. It emphasizes using interfaces, provides examples of mock implementations, and discusses best practices like keeping mocks focused and using assertion libraries. The articl

This article explores Go's custom type constraints for generics. It details how interfaces define minimum type requirements for generic functions, improving type safety and code reusability. The article also discusses limitations and best practices

This article explores using tracing tools to analyze Go application execution flow. It discusses manual and automatic instrumentation techniques, comparing tools like Jaeger, Zipkin, and OpenTelemetry, and highlighting effective data visualization

The article discusses Go's reflect package, used for runtime manipulation of code, beneficial for serialization, generic programming, and more. It warns of performance costs like slower execution and higher memory use, advising judicious use and best

The article discusses using table-driven tests in Go, a method that uses a table of test cases to test functions with multiple inputs and outcomes. It highlights benefits like improved readability, reduced duplication, scalability, consistency, and a

The article discusses managing Go module dependencies via go.mod, covering specification, updates, and conflict resolution. It emphasizes best practices like semantic versioning and regular updates.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Zend Studio 13.0.1
Powerful PHP integrated development environment

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.
