mySQLエスケープ文字列YouTube埋め込みコードが機能していません
-
01-10-2019 - |
質問
私は一つのことと一つのことだけをしようとしています。
$embedCode = mysql_real_escape_string('<object width="270" height="227"><param name="movie" value="http://www.youtube.com/v/pz-VWi5-tGA?fs=1&hl=en_US&rel=0"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/pz-VWi5-tGA?fs=1&hl=en_US&rel=0" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="270" height="227"></embed></object>');
今私が書いたら...
echo 'CODE = ' . $embedCode;
わかります...
CODE =
nothin ...
考え?
編集:
わかりましたので、私の意図は$ embedCodeだけを印刷することではなく、データベースに挿入することですが、null値を取得しています。私はスマートなお尻になると思いました、そしてそれはここで私の単純なアプローチで裏目に出ました。とにかく、ポイントは、MySQLクエリを通過していないということです。
編集2:WordPress '$ WPDBオブジェクトを使用しています
function insert_video(){
global $wpdb;
$wpdb->show_errors();
$table_name = $wpdb->prefix . "video_manager";
$embedCode = mysql_real_escape_string('<object width="270" height="227"><param name="movie" value="http://www.youtube.com/v/pz-VWi5-tGA?fs=1&hl=en_US&rel=0"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/pz-VWi5-tGA?fs=1&hl=en_US&rel=0" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="270" height="227"></embed></object>');
$title = 'this is my title';
$description = 'this is my description';
$wpdb->insert( $table_name, array( 'title' => mysql_real_escape_string($title), 'embed_code' => $embedCode, 'description' => mysql_real_escape_string($description) ) );
}
function get_video_block($id){
insert_video();
global $wpdb;
$wpdb->show_errors();
$table_name = $wpdb->prefix . "video_manager";
$query = "SELECT * FROM " . $table_name . " WHERE `index` = '$id'";
$results = $wpdb->get_results($query, ARRAY_A);
$results = $results[0];
$returnString = $results['title'] . '<br>';
$returnString .= $results['embed_code'] . '<br>';
$returnString .= $results['description'] . '<br>';
return $returnString;
}
結果を取得します:
this is my title<br><br>this is my description<br>
解決
あなたはあなたのHTMLを大丈夫印刷しています。右クリックして、そこにあるはずのソースを見てください。
mysql_real_escape_string HTMLを逃れるためのものではありません。
PHPMyAdminを使用してテーブルの実際のデータを見るとどうなりますか?そこにない場合、問題はそのデータを入力するときです。
テーブルに書きながらそれを逃がしているので、他の何かを使ってそのデータをサニタイズしていますか^ sprip_tagsのようなものですか? Strip_TagsはすべてのHTMLを取り出します。
WPDB_CLASSがHTMLをクリーニングしている可能性はありますか?
ええ、codex.wordpress.org/function_reference/wpdb_classを見ると、$ wpdb-> query( 'query')を実行してクエリを実行できますので、挿入してください。それが動作する場合、あなたは修正されています。
所属していません StackOverflow