“Protect” text box value from input (HTML form)

2019-02-17 17:56发布

问题:

I was wondering whether it is possible to assign a value to an HTML text box and protect it.

What I mean is make it´s content unmodifiable, so that when the form gets submitted im "sure" it was this value which was submitted.

BTW I realize the easier way would be not to "listen" fot this input and just assign it but it would come in handy to be able to do what´s stated above.

I hope the question is clear enough, please ask for any needed clarification.

Thanks in advance!

EDIT: I was definitely not clear enough but I tried to express that i should hold the value after submitted (not modifiable in client side)

回答1:

No, it's not. You should never trust user input, which includes form submissions.

The other answers tell you how to mark the field as read-only. This is useful if you want to display a particular value, while showing that it's not intended to edited.

However, it can still be modified with Firebug, DOM Inspector, etc. Or, they can just submit a HTTP request without using the browser at all.

I would recommend storing the value in a session instead.



回答2:

Set the readonly property of the input element:

<input type="text" readonly="readonly" />

This will prevent any modification (except if the user edits with a DOM Inspector). Always validate input on the server. If you do not want any changes made, don't allow the user to edit it.

http://www.w3schools.com/tags/att_input_readonly.asp



回答3:

Just do this

<input type="text" value="VALUE" readonly />

Then itll be read only :)



回答4:

<input type="text" readonly="readonly"/>. But: Never be sure, and validate data on the server side. It is very easy to request GET/POST with invalid data.



回答5:

Form inputs have a 'disabled' and 'readonly' attributes you can set to make them un-editable.

http://htmlhelp.com/reference/html40/forms/input.html

Though you can never be 100% sure what is getting sent from the client side. The entire DOM is editable by the client.