我遇到了条带问题。我无法将我的Javascript代码添加到json_decode,因为我相信斜杠正在侵入。
这就是我所拥有的:
$str = stripslashes ($_POST['setImage']);
$setImage = mysql_escape_string($str);
if(json_decode($str) == NULL)
{
echo("not valid json!");
}else{
$imageUrls = json_decode($setImage);
}
从这里抓取信息:
<img src="<?php echo $photo['picurl']; ?>" onclick='javascript: setCoverForSet(
{"photo_id": "<?php echo $photo['photo_id']; ?>",
"original": "<?php echo $photo['piclink']; ?>",
"thumbnail": "<?php echo $photo['picurl']; ?>"});'/>
<input type="text" value='{"photo_id": <?php echo $photo['photo_id']; ?>, "original": <?php echo $photo['piclink']; ?>, "thumbnail": <?php echo $photo['picurl']; ?>}' name="photos[]" />
这是我打印时输出的内容
{\"photo_id\": \"2\", \"original\": \"content/employees/1/1363556600bsmiles.jpg\", \"thumbnail\": \"content/employees/thumbs/1/thumb_1363556600bsmiles.jpg\"}
引号必须在输入中,否则无效。
感谢您的帮助。
更新时间:美国东部时间下午7点58分
我最终将它发送到数据库中的表。
这是整个声明:
$str = stripslashes ($_POST['setImage']);
$setImage = mysql_escape_string($str);
if(json_decode($str) == NULL)
{
echo("not valid json!");
}else{
$imageUrls = json_decode($setImage);
}
$photos = mysql_escape_string($_POST[photos]);
$piclink = print $imageUrls->{'thumbnail'};
$piclurl = print $imageUrls->{'original'};
$title = mysql_escape_string($_POST[title]);
$firstname = mysql_escape_string($_POST[firstname]);
$lastname = mysql_escape_string($_POST[lastname]);
$todaysdate = date("Y-m-d");
mysql_query("UPDATE staff SET title = '".$title."', staff_firstname = '".$firstname."',
staff_lastname = '".$lastname."',
piclink = '".$piclink."',
picurl = '".$picurl."',
last_update = '".$todaysdate."' WHERE staff_id = $EID") or die(mysql_error());
我唯一能想到的是额外的斜杠干扰了json_decode。 我只把echo语句放入,以便我能看到帖子后传递的内容。
我在做mysql_escape_string时尝试使用striplashes:
$setImage = mysql_escape_string(stripslashes ($_POST['setImage']));
但给出了同样的结果。
答案 0 :(得分:0)
如果有人对此感兴趣,我想出来了。
我摆脱了mysql_escape_string并消除了斜杠。仍然使用条形斜线。
我还从解码区删除了print语句。现在一切正常,它将字符串转换到应该是的数据库中。
这是新代码:
$setImage = stripslashes ($_POST['setImage']);
if(json_decode($setImage) == NULL)
{
echo("not valid json!");
}else{
$imageUrls = json_decode($setImage);
}
$photos = mysql_escape_string($_POST[photos]);
$piclink = $imageUrls->{'thumbnail'};
$picurl = $imageUrls->{'original'};
$title = mysql_escape_string($_POST[title]);
$firstname = mysql_escape_string($_POST[firstname]);
$lastname = mysql_escape_string($_POST[lastname]);
$todaysdate = date("Y-m-d");
mysql_query("UPDATE staff SET title = '".$title."', staff_firstname = '".$firstname."',
staff_lastname = '".$lastname."',
piclink = '".$piclink."',
picurl = '".$picurl."',
last_update = '".$todaysdate."' WHERE staff_id = $EID") or die(mysql_error());
echo "<b><font color='#999999'> Staff edit succeeded</font></b><br />";
答案 1 :(得分:-1)
简单地使用正则表达式并删除不需要的所有符号,效率更高