1、首先用webStorm提供的模板创建服务端框架 file -> New -> Project
2.创建Node.js服务端框架
3、其他的文件都不需要改动,搭建自己的服务端需要创建自己的应用框架如user.js(名称自己随便写)
4、创建好自己的js文件后需要在app.js里引入和设置自己的模块
5、还需要解决跨域访问的问题,同样在app.js里设置
var app = express(); //解决跨域问题 app.all("*",function (req,res,next) { res.header("Access-Control-Allow-Origin","*"); res.header("Content-Type", "application/json;charset=utf-8"); next(); });注意:一定是在express()创建Express对象之后引入 解决跨域问题代码为固定写法,直接引入即可
6、在node_modules文件夹内创建mysql模块
可以直接打开webStorm的Terminal输入npm i mysql安装
7、安装好mysql模块后,ok,可以开始在user.js里书写自己的服务端了
//首先需要导入mysql模块,前两句为固定写法 var mysql=require('mysql'); var router = require('express').Router(); //必须传入一个对象类型 var sqlConfig={ //数据库的地址 host:'localhost', //数据库的用户名,默认用户名是root user:'root', //数据库的名字 database:'sharetime' //如果有密码还需要些数据库密码password }; //用createConnection方法创建连接数据库的对象 var connection = mysql.createConnection(sqlConfig); //connect方法连接数据库 connection.connect(function (error) { if (error){ //如果连接错误 重新连接数据库 connection = mysql.createConnection(connection.config); connection.connect(); } }); //使用post方法传输 router.post('/register',function (req,res) { console.log(req.body); var info={"message":"asd"}; res.send(info); //接收客户端传过来的参数,所有的增删该查都是调用query方法执行对应的sql语句 //注意username,password,phone要和客户端传过来的顺序一致 connection.query("INSERT INTO `time` (`id`, `username`, `password`, `phone`) VALUES (NULL, '"+req.body.username+"', '"+req.body.password+"', '"+req.body.phone+"')",function (err,result,f) { //检测是否出错 console.log(err); console.log(result) }); }) //导出自己创建好的模块,也是固定写法 module.exports = router;框架参考mysql文档
8、搭建好服务端现在去写客户端 创建一个工程: HTML:
<!DOCTYPE html> <html lang="en" ng-app="app"> <head> <meta charset="UTF-8"> <title>Title</title> <!--用angular的方式创建客户端,先引用angular文档,也可以用Ajax的方式书写--> <script src="angular.min.js"></script> </head> <body ng-controller="controller"> <button ng-click="toRegister()">注册</button> <script src="app.js"></script> </body> </html>app.js文件:
angular.module("app",[]) .controller("controller",function ($scope,$http,$httpParamSerializerJQLike) { $scope.toRegister = function () { $http({ url:"http://localhost:3000/user/register", method:"POST", //$httpParamSerializerJQLike:将客户端数据序列化,如果使用Ajax书写序列化方法为serialize() //但是用户提交的的内容必须要在form表单中提交 data:$httpParamSerializerJQLike({ //写死的数据内容 username:"xiaoming", password:'123123', phone:'111' }), //请求头固定书写格式 headers:{ "content-type":"application/x-www-form-urlencoded" } //调用then方法检测结果 }).then(function (result) { console.log(result); //catch方法检测错误 }).catch(function (err) { console.log(err) }) }; });9、创建好客户端之后,运行服务端
10、在客户端点击注册打开F12出现注册好的数据类型
11、在结合上篇文章数据库相关操作中XAMPP的数据库中可以查看到客户端所提交的数据内容
ok了,简单的服务端和客户端的交互就完成了 拜拜!