node模擬後臺返回json書寫格式報錯--Unexpected token ' in JSON at position 1

最近在學習Node的知識,就嘗試寫了一個註冊登錄的簡單功能,可是本身在模擬後臺返回值的時候,老是報錯Unexpected token ' in JSON at position 1,查找緣由以後,是由於個人返回data是這樣定義的,res.write("{'ok':false,'msg':'用戶名或者密碼錯誤!'}"),因此會報錯,正確寫法是res.write('{"ok":false,"msg":"用戶名或者密碼錯誤!"}'),裏面必須用雙引號括住,。html

 

代碼以下:jquery

服務器端代碼:ajax

var http = require('http');
var fs = require('fs');
var urlLib = require('url');
var querystring = require('querystring');
var users = {};
var server = http.createServer((req,res) => {
var str = '';
req.on('data',(data) => {
str += data
});
req.on('end',() => {
var obj = urlLib.parse(req.url,true);
var url = obj.pathname;
var GET = obj.query;
var POST = querystring.parse(str);
if(url == '/user') {
switch (GET.act) {
case 'login':
if(users[GET.user] == null) {
res.write('{"ok":false,"msg":"該用戶不存在!"}')
}else if(GET.pass != users[GET.user]) {
res.write('{"ok":false,"msg":"用戶名或者密碼錯誤!"}')
}else {
res.write('{"ok":true,"msg":"登陸成功!"}')
}
break;
case 'reg':
if(users[GET.user]) {
res.write('{"ok":false,"msg":"該用戶已存在!"}')
}else {
users[GET.user] = GET.pass
res.write('{"ok":true,"msg":"註冊成功!"}')
}
break;
default:
res.write('{"ok":false,"msg":"未知的act!"}')
};
res.end()
}else {
var file_url = './' + url;
fs.readFile(file_url,(err,data) => {
if(err) {
res.write('404')
}else {
res.write(data)
};
res.end()
})
}
})
}).listen(8080,() => {
console.log('啓動了!')
})服務器

 

客戶端代碼:學習

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
</head>
<script>
$(document).ready(function() {
var oUser = $('#user');
var oPass = $('#pass');
var oRegBtn = $('#regBtn');
var oLoginBtn = $('#LoginBtn');
//登錄
oLoginBtn.on('click',() => {
$.ajax({
url: '/user',
data: {act:'login',user:oUser.val(),pass:oPass.val()},
type: 'get',
success: function(data) {
var ok = JSON.parse(data).ok;
if(ok) {
alert('登陸成功!')
}else {
alert('登陸失敗 '+ JSON.parse(data).msg)
}
},
error: function() {
alert('通訊失敗!')
}
})
})
//註冊
oRegBtn.on('click',() => {
$.ajax({
url: '/user',
data: {act:'reg',user:oUser.val(),pass:oPass.val()},
type: 'get',
success: function(data) {
var ok = JSON.parse(data).ok;
if(ok) {
alert('註冊成功!')
}else {
alert('註冊失敗 '+ JSON.parse(data).msg)
}
},
error: function() {
alert('通訊失敗!')
}
})
})
})
</script>
<body>
用戶名:<input type="text" id="user" value=""><br />
密碼:<input type="password" id="pass" value=""><br />
<input type="button" id="regBtn" value="註冊">
<input type="button" id="LoginBtn" value="登陸">
</body>
</html>ui

 

注:在這裏對於提交一些沒有作一些嚴格的驗證,只是作一個簡單的邏輯處理,你們能夠根據本身的狀況去完善,一塊兒交流!url

相關文章
相關標籤/搜索