我正在尝试使用我的PHP shoutbox和使用AJAX查询,以便页面不必重新加载以发布呼喊。任何帮助将不胜感激!
我被困 - 我一直收到一个解析错误:
18:47:27.216 Details: parsererror
Error:SyntaxError: JSON.parse: unexpected character at line 1 column 1 of the JSON data 1 index.php:100:4
我有shoutBox.php,它包含HTML和AJAX:
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
</head>
<script type="text/javascript">
function sendChatMessage(msg)
{
$.ajax({
type: "POST",
url: "login/postData.php",
data: {
thisPost: msg
},
dataType: "json",
success: function(data)
{
if (data.error === false)
{
$("#aData").text(data);
console.log("Post submitted.");
ajax.reload();
}
else
{
console.log("Post was not submitted.");
}
},
error: function(xhr, desc, err)
{
console.log(xhr);
console.log("Details: " + desc + "\nError:" + err);
}
});
}
</script>
<div class="shoutbox">
<h1 class="panel-heading"><strong>Federal</strong> Communications Array</h1>
<hr>
<ul class="shoutbox-content"></ul>
<div class="panel">
<form method="post">
<p>
<table border="0" align="center" style="height: auto;" width="90%">
<tbody>
<tr>
<td><a></a></td>
<td>
<div class="input-group">
<span class="input-group-addon">Say:</span>
<input class="form-control" id="aData" name="post" maxlength='255' placeholder="Enter a message..."></input>
<div class="input-group-btn">
<button class="btn btn-success" onClick="sendChatMessage(document.getElementById('aData').value); return false;">Send</button>
</div>
</div>
</td>
<td></td>
</tr>
</tbody>
</table>
<p>
</form>
</div>
<div class="panel">
<table class="table table-striped">
<thead>
<tr>
<th width="100px">Timestamp</th>
<th width="120px">Username</th>
<th width="980px">Message</th>
<th></th>
</tr>
</thead>
</table>
</div>
</div>
和postData.php,它(应该)执行查询。
<?php
ini_set('display_errors', 'On');
error_reporting(E_ALL | E_STRICT);
echo('Script begin.');
require "dbconf.php"; // db details
$connect = mysql_connect($host,$username,$password);
mysql_select_db($db_name,$connect);
$post = '';
if(empty($_POST['aData']))
{
exit(json_encode([
'error' => 'You must enter a message!',
]));
} else {
$post = trim($_POST['aData']);
$playerUsername = $_SESSION['username'];
$idQuery = "SELECT `id` FROM `members` WHERE `username`='$playerUsername'";
$playeridQuery = mysql_query($idQuery);
$playerID = mysql_result($playeridQuery, 0);
mysql_query("INSERT INTO `shoutboxPosts` SET `id`='$playerID', `username`='$playerUsername', `post`='$post'");
}
exit(json_encode([
'error' => false,
]));
?>
答案 0 :(得分:0)
删除一行
<?php
ini_set('display_errors', 'On');
error_reporting(E_ALL | E_STRICT);
//echo('Script begin.'); Remove this line. It's violating JSON format
require "dbconf.php"; // db details
$connect = mysql_connect($host,$username,$password);
mysql_select_db($db_name,$connect);
$post = '';
if(empty($_POST['aData']))
{
exit(json_encode([
'error' => 'You must enter a message!',
]));
} else {
$post = trim($_POST['aData']);
$playerUsername = $_SESSION['username'];
$idQuery = "SELECT `id` FROM `members` WHERE `username`='$playerUsername'";
$playeridQuery = mysql_query($idQuery);
$playerID = mysql_result($playeridQuery, 0);
mysql_query("INSERT INTO `shoutboxPosts` SET `id`='$playerID', `username`='$playerUsername', `post`='$post'");
}
exit(json_encode([
'error' => false,
]));
?>
答案 1 :(得分:0)
您的解析错误来自此行:
$( “#ADATA”)文本(数据);
您无法将Json编码数据发送到DOM中的id。你想看到数据的价值,试试这个:
警报(JSON.stringify(数据));
其他的事情,在你的php中,避免退出,忘记if和else。
正确的方法是尝试,抓住。如果发生错误,请尝试捕获异常。
将一个全局变量放在你的函数之外并将awswer放在里面。
之后:
echo json_encode($ aswer); $ connect = null; //总是关闭你的连接。
我希望它会对你有所帮助。