本篇介绍下 Node.js post 请求

需求:

用户登录,前端界面输入用户名和密码,点击登录请求后台验证,根据后台反馈的信息做出响应

前端:

(1)使用form表单

(2)使用ajax异步请求

服务端:

(1)创建接口供前端请求

(2)获取数据并与固定数据 / 数据库进行对比验证,返回结果给前端

前端驱动后端,先贴前端代码

<form>
<label>
<span>用户名</span>
<input type="text" placeholder="用户名" id="userName">
</label>
<label>
<span>密码</span>
<input type="password" placeholder="密码" id="userPsw">
</label>
<input value="登录" id="btnPost" type="button">
</form>

css 样式(不好看就别用了,毕竟不是重点)

html{
font-size: 16px;
}
form {
position: absolute;
top: 30%;
left:;
right:;
display: block;
width: 25rem;
height: 25rem;
margin: 0 auto;
background: url("../img/icon-login.png") no-repeat ;
text-align: center;
font-size: 1.25rem;
box-shadow: 0 0 1.25rem #c5cace;
}
form label {
display: block;
width: 100%;
height: 8.75rem;
line-height: 8.75rem;
text-align: center;
vertical-align: middle;
}
label span {
display: inline-block;
width: 5rem;
text-align: right;
padding-right: 0.1rem;
}
label input {
height: 2.25rem;
border-radius: 0.1875rem;
border: none;
}
input[type=button],input[type=submit] {
color: #fff;
width: 3.75rem;
height: 2.5rem;
border: none;
border-radius:0.1875rem;
background: #4077bc;
cursor: pointer;
font-size: 1.25rem;
}

效果是这样的

(一)jQuery.ajax

$(function () {
var btnPost = $("#btnPost");
btnPost.click(function () {
$.ajax({
url:"http://localhost:8081",
type:"post",
data:{
name:$("#userName").val().trim(),
age:$("#userPsw").val().trim()
},
dataType:"json",
timeout:3000,
success: function (res) {
console.log(res);
},
error: function () {
alert("服务器连接失败!")
}
})
});
})

服务端代码

var http = require('http');
var qs = require('querystring'); http.createServer(function (req, res) {
var post = "";
req.on('data', function (chunk) {
post += chunk;
});
req.on('end', function () {
post = qs.parse(post);
console.log(post.name + "--" + post.age);
//res.end();
});
res.writeHead(200,{'Content-type':'text/plain;charset=utf-8'});
res.end("你好");
}).listen(8081);

运行服务端,点击登录,查看控制台会有输出

这个时候再看下浏览器控制台

这个是前端经常会遇到的跨域问题,很简单,使用 jsonp即可

ajax换成:

$.ajax({
url:"http://localhost:8081",
type:"post",
data:{
name:$("#userName").val().trim(),
age:$("#userPsw").val().trim()
},
dataType:"jsonp",
jsonpCallback:"callback",
timeout:3000,
success: function (res) {
console.log(res);
},
error: function () {
alert("服务器连接失败!")
}
})

服务端换成:

var http = require('http');
var qs = require('querystring');
var url = require('url');
http.createServer(function (req, res) {var parms = url.parse(req.url,true);
console.log(parms.query.userName + "<---||--->" + parms.query.userPsw);
res.writeHead(200,{'Content-type':'text/plain;charset=utf-8'});
res.end('callback(\'{\"status\": \"203\"}\')');
}).listen(8081);

前端控制台:

(二)表单

前端代码改变如下:

<form action="http://localhost:8081" method="POST" target="_blank">
<label>
<span>用户名</span>
<input type="text" placeholder="用户名" id="userName">
</label>
<label>
<span>密码</span>
<input type="password" placeholder="密码" id="userPsw">
</label>
<input value="登录" id="btnPost" type="submit">
</form>

服务端代码不变

点击登录效果如下:

这种情况界面的跳转是有后台指定的

学习阶段,不足之处请指教,谢谢!

Node.js基础学习二之POST请求的更多相关文章

  1. Node.js基础学习一之Get请求

    本人从事的是前端开发,这段时间公司开发项目比较少所以就想着学点东西,然后就想到了Node.js ,跟着菜鸟教程学了点,不过我觉得最好的学习方法是带着需求来学习. 其实和服务端打交道无非就是能有一个可以 ...

  2. 进击Node.js基础(二)

    一.一个牛逼闪闪的知识点Promise npm install bluebird 二.Promise实例 ball.html <!doctype> <!DOCTYPE html> ...

  3. Node.js基础学习四之注册功能

    前言:在Node.js学习(二)和(三)中介绍了如何在Node.js 中获取登录的用户名和密码与数据库进行验证并返回数据给客户端 需求:实现注册功能 为了区分登录和注册是两个不同的请求,在端口后面加上 ...

  4. Node.js基础学习三之登录功能

    本篇介绍Node.js访问数据库并返回数据给客户端 需求基于Node.js学习(二) 数据库请下载:user.sql 1.创建user 实体类(model-user.js) function User ...

  5. node.js 基础学习笔记3 -http

    http模块,其中封装了一个高效的HTTP服务器和一个建议的HTTP客户端 http.server是一个基于事件的HTTP服务器 http.request则是一个HTTP客户端工具,用户向服务器发送请 ...

  6. node.js 基础学习 express安装使用

    安装好nodeJs,我们需要使用命令行中安装express. 我这里默认将Node.js安装在C:\Program Files\nodCejs\盘中. 在保持联网的状态下,依次输入如下命令. npm ...

  7. node.js 基础学习笔记2

    Module和Package是Node.js最重要的支柱. Node.j 提供require函数来调用其他模块,而且模块都是基于文件.模块和包区别是透明的,因此常常不作区分. 1.模块和文件一一对应. ...

  8. node.js 基础学习笔记1

    1. node -v 查看版本 node -e --js代码 node --进入编辑模式 Ctrl+C 退出编译模式 var http=require('http') http.createServe ...

  9. node.js 基础学习

    node.js 是一个 javaScript 运行环境,可以让 js 运行在服务端. 在 nodejs 环境下,可以运行 javascript 基本语法,可以在nodejs 中执行一些无法在浏览器端执 ...

随机推荐

  1. JMeter参数化中存在逗号的解决方法

    在Jmeter中通过CSV Data Set Config进行参数化时,如果参数化数据中存在逗号(,)我们可以通过一下方式进行设置 如何存在中文乱码,可以设置file encoding:gb2312

  2. Selenium 3 学习小结

    4个类+常用的46个方法 从以下知识内容对selenium 3自动化框架进行初步学习: 1.安装selenium pip install selenium pip list 2.驱动.关闭浏览器 首先 ...

  3. 区块链侧链应用开发平台Asch节点安装及区块生产教程

    1 系统要求 必须是linux系统 必须有公网ip 建议使用ubuntu 14.04 64位 建议内存1G以上 建议带宽2Mb以上 2 安装 2.1 下载 wget https://www.asch. ...

  4. Java将Excel解析为数组集合

    Java将Excel解析为数组集合 相关 jar 包: jxl-2.6.jar jar 包下载:http://files.cnblogs.com/files/liaolongjun/excel-jar ...

  5. Redis主从复制详解

    1. 概述 主从复制:主节点负责写数据,从节点负责读数据,主节点定期把数据同步到从节点保证数据的一致性 2. 主从复制的相关操作 (1)配置文件:在从服务器的配置文件中加入 slaveof<ma ...

  6. mock server 实现get方法的接口(二)

    mock server 实现get方法的接口(二) 下面是实现查询品牌的接口demo: 1.当response数据量小的时候,可以直接使用json, mock会自动设置headers为applicat ...

  7. Mac mini 使用打印机

    扫描与打印机使用: 第一步:左上角黑苹果->系统偏好设置->打印机与扫描仪->设置打印机 第二步:Launchpad -> 预览 -> 文件 -> 从扫描仪导入-& ...

  8. eclipse安装使用fat打jar包

    在线安装步骤: eclipse菜单栏 help >software updates >Search for new features to install>new update si ...

  9. webservice学习教程(二)--理论

    一.WebService是什么? 1. 基于Web的服务:服务器端整出一些资源让客户端应用访问(获取数据) 2. 一个跨语言.跨平台的规范(抽象) 3. 多个跨平台.跨语言的应用间通信整合的方案(实际 ...

  10. Django系统

    #Django系统 -环境 - python3.6 - django1.8 -参考资料 - [django中文教程](http://python.usyiyi.cn) - django架站的16堂课 ...