Rumah > hujung hadapan web > tutorial js > Mengapa Saya Tidak Boleh Menetapkan Nilai Input Fail HTML Secara Terus?

Mengapa Saya Tidak Boleh Menetapkan Nilai Input Fail HTML Secara Terus?

Susan Sarandon
Lepaskan: 2024-12-27 11:56:15
asal
482 orang telah melayarinya

Why Can't I Directly Set the Value of an HTML File Input?

Cara Menetapkan Nilai pada Input Fail dalam HTML

Ramai pembangun telah menghadapi cabaran untuk menetapkan nilai kepada input fail dalam HTML. Walaupun ini mungkin kelihatan seperti tugas yang mudah, ia tidak boleh dilakukan kerana kebimbangan keselamatan.

Kebimbangan Keselamatan

Membenarkan tapak web menetapkan nilai input fail kepada laluan sistem fail cakera sisi klien akan menimbulkan risiko keselamatan yang ketara. Pertimbangkan senario hasad berikut:

<form name="foo" method="post" enctype="multipart/form-data">
    <input type="file" value="c:/passwords.txt">
</form>
<script>document.foo.submit();</script>
Salin selepas log masuk

Jika kod hasad ini dilaksanakan, tapak web akan dapat secara rahsia mendapatkan salinan kata laluan sensitif pengguna.

Pilihan Terhad

Semasa menetapkan nilai input fail ke laluan tertentu tidak boleh dilaksanakan, terdapat penyelesaian terhad: menetapkannya kepada sumber web yang boleh diakses secara umum. Walau bagaimanapun, pilihan ini adalah sedikit kegunaan praktikal dalam konteks mengurus fail setempat pada komputer pengguna.

Atas ialah kandungan terperinci Mengapa Saya Tidak Boleh Menetapkan Nilai Input Fail HTML Secara Terus?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan