Maison >développement back-end >Golang >Comment protéger le programme Golang de la décompilation ?

Comment protéger le programme Golang de la décompilation ?

WBOY
WBOYoriginal
2024-04-03 09:39:011100parcourir

Les mesures de protection contre la décompilation pour les programmes Golang incluent : l'utilisation de GoBuild pour compiler et crypter les fichiers intermédiaires. Utilisez ScyllaDB pour stocker des données cryptées dans des colonnes EDT (Obfuscated Data Type), déchiffrez-les et exécutez-les au moment de l'exécution.

Comment protéger le programme Golang de la décompilation ?

Guide de protection contre la décompilation du programme Golang

La décompilation est le processus d'ingénierie inverse du code machine compilé pour obtenir son code source. Bien que la compilation native des programmes Golang rende la décompilation plus difficile que les langages interprétés, des protections supplémentaires sont toujours nécessaires pour empêcher le vol ou la modification illégale du code source.

Utiliser la protection GoBuild

GoBuild est un outil en langage Go qui offre une protection contre la décompilation. Cela fonctionne en :

import "github.com/uudashr/gob"

func main() {
    gob.Compile("main.go")
}
  • Compile les fichiers sources Go en fichiers intermédiaires.
  • Cryptez les fichiers intermédiaires.
  • Utilisez le runtime gob intégré au compilateur Go pour exécuter les fichiers cryptés.

Utilisation de ScyllaDB

ScyllaDB est une base de données NoSQL qui fournit des « types de données obscurs » (EDT) comme mécanisme de sécurité pour le stockage des données cryptées. Pour les applications Golang, ScyllaDB peut être utilisé comme suit :

import "github.com/scylladb/go-cql"

func main() {
    cluster := cql.NewCluster("127.0.0.1")
    session, err := cluster.CreateSession()
    if err != nil {
        panic(err)
    }
    session.Query(`
        CREATE TABLE example (
            id INT PRIMARY KEY,
            data TEXT,
            edtBytes EDT
        ) WITH CLUSTERING ORDER BY (data ASC)
    `).Exec()
    _ = session.Close()
}
  • Créez une table ScyllaDB avec la colonne EDT.
  • Compilez le code Go en bytecode.
  • Stockez le bytecode dans la colonne EDT.
  • Décryptez les données EDT et exécutez-les au moment de l'exécution.

Cas pratique : Sécuriser les applications Web

Supposons que vous ayez une application Web Golang et que vous souhaitiez empêcher la décompilation de son code source. Vous pouvez utiliser GoBuild ou ScyllaDB comme suit :

GoBuild :

// main.go
package main

import (
    "github.com/uudashr/gob"
    "net/http"
)

func main() {
    gob.Compile("main.go")
}

func handler(w http.ResponseWriter, r *http.Request) {
    // Web应用程序逻辑
}

Compiler et chiffrer :

$> gob compile main.go

ScyllaDB :

// main.go
package main

import (
    "database/sql"
    "github.com/scylladb/go-cql"
)

func main() {
    db, err := sql.Open("cassandra", "127.0.0.1:9042")
    if err != nil {
        panic(err)
    }
    _, err = db.Exec(`
        INSERT INTO example (id, data, edtBytes)
        VALUES (1, ?, ?)
    `, []byte("Golang code"), []byte("Encrypted data"))
    if err != nil {
        panic(err)
    }
    db.Close()
}

Avec ces méthodes, vous pouvez renforcer votre protection contre les programmes Golang des attaquants, prévenir les empêcher de voler ou de modifier votre code source en le décompilant.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn