Saya ingin membuat skrip bash yang membaca "payload" data biner dari file eksternal dan memuntahkan skrip bash lain dengan data ini lolos dan dikemas dalam variabel string. Contoh:
- mydata.bin - Sumber data: file data biner yang akan dienkapsulasi
- myencoder.sh - Pelaku utama: skrip bash yang mengubah data biner menjadi skrip dengan variabel string
- mypayload.sh - Hasil akhirnya: skrip bash yang dihasilkan oleh myencoder.sh yang berisi data yang disandikan sebagai variabel string.
Untuk menggunakan ini saya akan menjalankan myscript.sh mydata.bin mypayload.sh
dan myscript.sh akan mengonversi / escape / wrap / apa pun file mydata.bin ke mypayload.sh
Setelah menjalankan perintah ini, the mypayload.sh
File akan terlihat seperti ini:
# Generated by myencoder.sh with data from mydata.bin
encoded_data="[...]ugly escaped string representation of the binary data found in mydata.bin[...]"
Masalah yang saya hadapi yang saya tidak yakin bagaimana menyelesaikannya adalah bagaimana data akan dikodekan dengan benar. Saya membaca bahwa printf "% q" dapat digunakan untuk keluar dari string, tetapi bagaimana memintanya pada data yang diambil dari file biner eksternal benar-benar menghindar dari saya.
Jadi tolong, setiap tusukan ini dan tips apapun dipersilakan!
PS: Saya tidak ingin memperkenalkan dependensi di luar bash jika memungkinkan. Tergantung pada bash 4.x fitur-fiturnya OK.
PPS: Encoding harus mendukung ukuran kecil dan kinerja encoding / decoding.
sumber
Jawaban:
Sangat sulit untuk menangani nol byte dari bash. Anda dapat menghasilkan byte nol dengan
tetapi Anda tidak dapat menyimpannya dalam variabel.
Jauh lebih mudah menggunakan alat eksternal:
sumber
Ini bukan solusi lengkap untuk masalah Anda; seperti yang orang lain sebutkan berurusan dengan NULLs di file input Anda sulit di bash, dan saya yakin potensi file input unicode dapat menyebabkan lebih banyak sakit kepala.
Tapi saya menaruh sedikit waktu untuk memikirkan bagaimana Anda dapat menggunakannya
printf %q
di bash untuk melakukan sesuatu yang mirip dengan saran Anda dan muncul dengan hack cepat ini:Saya yakin itu bisa pecah dalam banyak hal tapi mungkin itu bisa memuaskan rasa ingin tahu Anda.
sumber
Balasan ini tidak menjawab pertanyaan secara langsung karena tampaknya mengandung 0 byte dalam variabel bash tidak mungkin dan tampaknya tidak ada cara untuk melarikan mereka ke string yang dapat disimpan dengan aman di dalam variabel bash tanpa mengandalkan alat eksternal seperti xxd atau uuencode yang tidak tersedia secara default di platform tempat skrip saya akan dijalankan.
Namun ini adalah solusi yang akhirnya saya kejar karena memecahkan masalah saya yang paling dekat, yaitu membuat skrip yang menyimpan data biner acak sebagai muatan yang dapat ditangani oleh skrip yang memegangnya.
Saya menggunakan artikel ini sebagai sumber saya. Pada dasarnya pendekatan ini menggunakan string pemisah antara skrip dan data biner dan tidak pernah membiarkan bash interpreter mencapai bagian biner di bagian akhir.
sumber