NEONecd999 Posted September 27, 2008 Share Posted September 27, 2008 Hi, I have a text area input that is submitted in a form. I had the issue that when someone submitted a ' (single quote) symbol in the text area, the php/mysql syntax would think that that was the closing quote of the text field (SET fieldname= 'John's pizzeria'), causing a syntax error. To fix this, i put an "htmlencode()" around the $_POST variable before running it in mySQL to update (a MEDIUMTEXT field). This worked well. Now I'd also like to preserve line breaks inputted into the text area. As it is now, if you include two line breaks, those line breaks seem to be preserved in the mysql field, but when you call the field and echo it into HTML, the line breaks are gone. What is the best way to encode my text area so that I don't have syntax problems (and risk mySQL injection attacks) as well as maintain formatting things like line breaks? Thanks. Link to comment https://forums.phpfreaks.com/topic/126108-html-encode-text-area/ Share on other sites More sharing options...
peranha Posted September 27, 2008 Share Posted September 27, 2008 for the line breaks, on your output use the following function. $string = nl2br($string); Link to comment https://forums.phpfreaks.com/topic/126108-html-encode-text-area/#findComment-652087 Share on other sites More sharing options...
NEONecd999 Posted September 27, 2008 Author Share Posted September 27, 2008 fantastic, thank you. Link to comment https://forums.phpfreaks.com/topic/126108-html-encode-text-area/#findComment-652088 Share on other sites More sharing options...
KrisNz Posted September 27, 2008 Share Posted September 27, 2008 escape it with mysql_real_escape_string() not htmlencode(). You shouldn't need to do anything else. Link to comment https://forums.phpfreaks.com/topic/126108-html-encode-text-area/#findComment-652090 Share on other sites More sharing options...
Recommended Posts
Archived
This topic is now archived and is closed to further replies.