gpt4 book ai didi

javascript - Node.JS Express 到 HTML 数据传输

转载 作者:行者123 更新时间:2023-11-29 06:20:00 25 4
gpt4 key购买 nike

我正在使用 node.js 创建一个登录应用程序,我似乎在将字符串从服务器传输到 html 方面遇到了知识缺陷。

我在 jsfiddle 发布了我当前的代码.我的应用程序验证 mysql 表的凭据,然后生成一个包含用户名密码和用户 IP 地址的基本 token 。

在最后一段代码中,客户端 html 发送到服务器,我有两个部分,您可以看到发送到基本用户页面和发送到管理页面。我试图研究这个主题,但我没有得到任何与情况相关的信息。任何人都可以指导我在将用户发送到管理员或用户页面的同时发送 token 的正确方向吗?

还有express server如何向client发送数据,例如在页面上,我希望数据库保存有关用户的相关信息,如地址和电话号码。这些信息如何通过html从服务器传输到客户端?

app.post('/', urlencodedParser, function (req, res) {

var date = new Date();
con.query("SELECT * from users WHERE username=" + con.escape(req.body.username) + " AND password=" + con.escape(req.body.password), function (err, rows, fields) {
if (err) {
console.log(err);
} else {
var ip = req.headers['x-forwarded-for'] || req.connection.remoteAddress;
if (rows == '' && rows == '') {
console.log('User Failed to login to the server with @'.red + con.escape(req.body.username) + ':' + con.escape(req.body.password));
res.sendFile(__dirname + '/admin/failure.html');

} else {
var isadmin = rows[0].admin;
var cryptomap = [req.body.username + ',' + req.body.password + ',' + ip];
var strcryptomap = cryptomap.toString(); // convert array to string
var token = encrypt(strcryptomap);
console.log(token + ' SENT'.red);
var backto = decrypt(token); //decr
var arr = backto.toString().split(","); // SPLITTING STRING TO SATISFY /VERIFY *************************************************
console.log(arr[0] + ' has valid token, encryption succsessful'.green);
con.query('UPDATE users SET crypto=' + con.escape(token) + 'WHERE username=' + con.escape(req.body.username), function (err, rows, fields) {
if (err) {

res.send(500);


} else {

console.log('Updated Crypto for ' + req.body.username);
if (isadmin == 0) {
// send to basic user page
res.send('USER');
} else {

//send to admin user page
res.sendto('http://google.com/?' + token);
}
}
});
}
}



});
});

最佳答案

首先,我将回答您提出的实际问题。

我通常处理您想要完成的事情的方式是使用前端的 ajax POST 和用户凭据(当然是 https,永远不要使用 http 发送凭据),让服务器对用户进行身份验证,创建 token 并使用 token 响应 ajax 帖子。从这里开始,如果身份验证成功并且服务器响应了一个 token 以及您想要获得的任何其他信息,您有几个存储它的选项,我个人使用 cookie。存储 token 后,让前端处理重定向。

说了这么多,我肯定会阅读身份验证原则和您的系统可能受到攻击的不同方式。我看到一些危险信号涉及非常基本的身份验证想法/策略。

编辑:这是一个 AJAX 发送到登录 API 端点的示例,该端点使用 token 进行响应并将用户名和 token 保存到 cookie。显然,您在 success 函数中的结果数据的组织方式可能与我的不同,但可以通过相同的方式访问。您可以在此结果对象中发送任何您想要的数据并相应地重定向

var loginData = { 
username : $('#loginUsername').val(),
password : $('#loginPassword').val()
}


$.ajax({
type : "POST",
url : [your-endpoint-url],
data : loginData ,
success : function(result) {
setCookie('appUN', result.username);
setCookie('appTok', result.token);
location.href = '/dashboard';
},
error : function(result) {
location.href = '/login/Error';
}
});


function setCookie(cname, cvalue) {
var d = new Date();
d.setTime(d.getTime() + 10800000);
var expires = "expires="+d.toUTCString();
var path = "path=/";
document.cookie = cname + "=" + cvalue + "; " + expires + ";" + path;
}

要真正将数据从服务器发送回客户端,在您的 API 端点中,您将执行所有逻辑来检查用户凭据,如果他们的凭据有效,您可以创建一个 token 并返回类似

res.json({ 
username: username,
token: token
});

并且此 JSON 对象将在成功函数中可用,如上所示。

如果用户凭据无效,您可以返回类似的内容

res.status(400).json({Message : "The username or password is incorrect"});

并且由于 400 状态,它会被您的 AJAX 请求的错误函数捕获

关于javascript - Node.JS Express 到 HTML 数据传输,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33794376/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com