Pertama sekali, saya bukan pakar dalam subjek itu, saya sedang belajar dan berseronok menggunakan alatan AI.
Begitulah... Saya sedang membuat pembangunan untuk seorang rakan, dia mempunyai PDF dengan 100 helaian, dengan rekod transaksi bank. Anda perlu mempunyai rekod ini dalam excel untuk dapat memprosesnya kemudian.
Dengan penggunaan copilot Github, saya membuat skrip untuk pengekstrakan data menggunakan python dan beberapa perpustakaan... Tiga dorito kemudian... Dan sebagai sistem sarapan, makan tengah hari dan makan malam, saya membina pelayan kelalang, untuk menyajikan skrip melalui titik akhir di hadapan dengan html, css dan js tulen dan ringkas.
Semasa proses interaksi dengan Copilot, makluman telah dibangkitkan bahawa sebahagian daripada kod mempunyai kerentanan jenis "path injection". Makluman ini agak menarik :D
Dan kerana saya ingin mengetahui lebih lanjut tentang keselamatan komputer, di sini saya menulis blog untuk meninggalkan rekod perjalanan ini...
Di sini AI mula bercakap.
Penyerang boleh mengeksploitasi kelemahan suntikan laluan dengan memanipulasi input pengguna untuk mengakses fail atau direktori yang tidak dibenarkan pada sistem fail pelayan. Berikut ialah contoh cara anda boleh melakukannya:
Andaikan anda mempunyai laluan dalam aplikasi Flask anda yang membolehkan pengguna memuat naik fail dan menyimpannya ke pelayan. Jika anda tidak mengesahkan atau membersihkan nama fail, penyerang boleh menghantar nama fail berniat jahat untuk cuba mengakses fail sensitif pada sistem.
Kod Rentan
@app.route('/upload', methods=['POST']) def upload(): file = request.files['file'] filename = file.filename # Nombre del archivo proporcionado por el usuario save_path = os.path.join('uploads', filename) # Guardar el archivo sin validar el nombre del archivo with open(save_path, 'wb') as f: f.write(file.read()) return 'File uploaded successfully'
Serangan Suntikan Laluan
Penyerang boleh menghantar permintaan dengan nama fail berniat jahat seperti ../../etc/passwd. Ini boleh menyebabkan laluan berikut:
muat naik/../../etc/passwd
Jika pelayan tidak mengesahkan atau membersihkan nama fail, fail itu boleh disimpan ke lokasi yang tidak diingini, membenarkan penyerang menulis ganti fail sensitif pada sistem.
Penyelesaian: Sahkan dan Bersihkan Kemasukan
Untuk mengelakkan jenis serangan ini, anda mesti mengesahkan dan membersihkan nama fail sebelum menyimpannya. Berikut ialah versi selamat kod:
Kod Selamat
import os import re from flask import Flask, render_template, request, send_file import requests from datetime import datetime app = Flask(__name__) def sanitize_filename(filename): # Eliminar caracteres no permitidos del nombre del archivo return re.sub(r'[^a-zA-Z0-9_\-\.]', '', filename) @app.route('/') def index(): return render_template('index.html') @app.route('/upload', methods=['POST']) def upload(): file = request.files['file'] response = requests.post('http://127.0.0.1:5001/pdf-to-excel', files={'file': file}) # Obtener la fecha actual current_date = datetime.now().strftime("%Y%m%d") # Obtener el nombre original del archivo sin la extensión original_filename = os.path.splitext(file.filename)[0] # Sanitizar el nombre del archivo sanitized_filename = sanitize_filename(original_filename) # Crear el nuevo nombre del archivo con la fecha al final output_filename = f'{sanitized_filename}_{current_date}.xlsx' # Crear la ruta completa del archivo save_path = os.path.join('uploads', output_filename) # Asegurarse de que la ruta sea absoluta save_path = os.path.abspath(save_path) # Guardar el archivo Excel resultante localmente con el nuevo nombre with open(save_path, 'wb') as f: f.write(response.content) # Enviar el archivo Excel de vuelta al usuario con el nuevo nombre return send_file(save_path, as_attachment=True, download_name=output_filename) if __name__ == '__main__': app.run(port=5000, debug=True)
Penjelasan Kod Selamat
Sanitasi Nama Fail: Fungsi sanitize_filename mengalih keluar aksara haram daripada nama fail menggunakan ungkapan biasa.
Buat Laluan Fail Penuh: Fungsi os.path.join digunakan untuk mencipta laluan fail penuh, menggabungkan direktori destinasi (muat naik) dengan nama fail yang telah dibersihkan (output_filename).
Pastikan Path adalah Mutlak: Fungsi os.path.abspath menukar laluan kepada laluan mutlak untuk mengelakkan manipulasi dengan laluan relatif.
Simpan Fail: Akhirnya, fail disimpan ke laluan yang ditentukan.
Ringkasan
Suntikan Laluan: Penyerang boleh memanipulasi input pengguna untuk mengakses fail atau direktori yang tidak dibenarkan.
Pengesahan dan Sanitasi: Sentiasa sahkan dan bersihkan input pengguna untuk mengelakkan serangan suntikan laluan.
Laluan Mutlak: Gunakan laluan mutlak untuk mengelakkan manipulasi dengan laluan relatif.
Dengan mengikuti amalan ini, anda boleh melindungi aplikasi anda daripada serangan suntikan laluan dan meningkatkan keselamatan keseluruhan sistem anda.
Di sini saya bertanya kepadanya bagaimana untuk melakukan serangan. Selain itu, saya meninggalkan log yang didaftarkan untuk dapat menyahpepijat kes ini.
Untuk melindungi aplikasi anda daripada serangan suntikan laluan, adalah berguna untuk memahami cara serangan ini boleh dilakukan. Di sini saya menunjukkan kepada anda cara penyerang boleh cuba mengeksploitasi aplikasi anda dan cara anda boleh mengesan aktiviti ini dalam log.
Memanipulasi Borang HTML
Penyerang boleh memanipulasi borang HTML untuk menyerahkan nama fail berniat jahat.
Langkah demi Langkah:
@app.route('/upload', methods=['POST']) def upload(): file = request.files['file'] filename = file.filename # Nombre del archivo proporcionado por el usuario save_path = os.path.join('uploads', filename) # Guardar el archivo sin validar el nombre del archivo with open(save_path, 'wb') as f: f.write(file.read()) return 'File uploaded successfully'
Menghantar Permintaan HTTP Dimanipulasi
Penyerang boleh menggunakan Posman untuk menghantar permintaan HTTP yang dibuat terus ke pelayan.
Langkah demi Langkah:
Menggunakan Skrip Python
Penyerang boleh menggunakan skrip Python untuk menghantar permintaan HTTP yang berniat jahat.
Contoh Skrip Python:
import os import re from flask import Flask, render_template, request, send_file import requests from datetime import datetime app = Flask(__name__) def sanitize_filename(filename): # Eliminar caracteres no permitidos del nombre del archivo return re.sub(r'[^a-zA-Z0-9_\-\.]', '', filename) @app.route('/') def index(): return render_template('index.html') @app.route('/upload', methods=['POST']) def upload(): file = request.files['file'] response = requests.post('http://127.0.0.1:5001/pdf-to-excel', files={'file': file}) # Obtener la fecha actual current_date = datetime.now().strftime("%Y%m%d") # Obtener el nombre original del archivo sin la extensión original_filename = os.path.splitext(file.filename)[0] # Sanitizar el nombre del archivo sanitized_filename = sanitize_filename(original_filename) # Crear el nuevo nombre del archivo con la fecha al final output_filename = f'{sanitized_filename}_{current_date}.xlsx' # Crear la ruta completa del archivo save_path = os.path.join('uploads', output_filename) # Asegurarse de que la ruta sea absoluta save_path = os.path.abspath(save_path) # Guardar el archivo Excel resultante localmente con el nuevo nombre with open(save_path, 'wb') as f: f.write(response.content) # Enviar el archivo Excel de vuelta al usuario con el nuevo nombre return send_file(save_path, as_attachment=True, download_name=output_filename) if __name__ == '__main__': app.run(port=5000, debug=True)
Pengesanan dalam Log: Merekod nama fail yang diterima dalam log.
Pelaksanaan Log untuk Pengesanan
Berikut ialah pelaksanaan lengkap yang termasuk pengelogan untuk mengesan nama fail yang mencurigakan:
@app.route('/upload', methods=['POST']) def upload(): file = request.files['file'] filename = file.filename # Nombre del archivo proporcionado por el usuario save_path = os.path.join('uploads', filename) # Guardar el archivo sin validar el nombre del archivo with open(save_path, 'wb') as f: f.write(file.read()) return 'File uploaded successfully'
Ringkasan
Daripada Pelayar: Memanipulasi borang HTML atau menggunakan alatan pembangunan penyemak imbas.
Menggunakan Alat seperti Posmen: Menghantar permintaan HTTP yang dibuat terus ke pelayan.
Menggunakan Skrip Automatik: Menggunakan skrip dalam Python, Bash atau mana-mana bahasa lain untuk menghantar permintaan HTTP yang berniat jahat.
Pengesanan Log: Merekodkan nama fail yang diterima dan aktiviti mencurigakan lain dalam log untuk mengesan kemungkinan serangan.
Dengan melaksanakan langkah-langkah ini, anda boleh meningkatkan keselamatan aplikasi anda dan mengesan aktiviti mencurigakan yang boleh menunjukkan percubaan serangan.
Kesimpulan: Di bawah konteks pembelajaran dan pembangunan melakukan pengaturcaraan berpasangan dengan AI, saya dapati jenis makluman ini pada platform amat berguna untuk mengesan kelemahan. Hari ini saya bangun dengan fikir saya akan menggunakan Heroku kembali dan di sini saya mendapati diri saya menemui kelemahan yang berbeza :D
selamat pengekodan!
Atas ialah kandungan terperinci Cara Melakukan dan Mengesan Serangan Suntikan Laluan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!