web项目完整的基础入门级搭建(五):express+mysql+vue

mysql

1.连接数据库

https://jingyan.baidu.com/article/8065f87fa5917723312498c3.html

2. workbench工具建库、建表

  • 建立一张用户表,表内的字段有:主键、uid、姓名、性别、年龄、头像

注意头像avator类型 varchar(10000) 要设置大一点。图片地址很长,太小了,新增操作会失败。

image

express

  1. 本地用nodejs搭建express项目

    http://www.expressjs.com.cn/starter/installing.html

  2. 配置连接数据库

  • conf/db 数据库连接的配置
// MySQL数据库联接配置
module.exports = {
    mysql: {
        host: '139.199.198.182', 
        user: 'root',
        password: '123qwe',
        database:'mock', // 前面建的user表位于这个数据库中
        port: 3306
    }
};
  • crud/user 对表的增删改查的操作
// 实现与MySQL交互
var mysql = require('mysql');
var dbconf = require('../conf/db');
var _ = require('lodash');
var sql = require('../sql/user');
var utils = require('../public/javascripts/utils')

// 使用连接池,提升性能
var pool  = mysql.createPool(_.extend({}, dbconf.mysql));


module.exports = {
    add: function (param, res, next,callbackResponse) {
        pool.getConnection(function(err, connection) {
            var hash = utils.hash()
            // 建立连接,向表中插入值
            connection.query(sql.insert, [hash, param.name, param.sex, param.age, param.avator], function(err, result) {

                if(result) {
                    result = {
                        code: 200,
                        msg:'增加成功'
                    };    
                }
 
                // 以json形式,把操作结果返回给前台页面
                callbackResponse(res, result);
 
                // 释放连接 
                connection.release();
            });
        });
    }
}
  • sql/user 存放sql语句
var user = {
    insert:'INSERT INTO user(uid, name, sex, age, avator) VALUES(?,?,?,?,?)',
    update:'update user set name=?, age=? where id=?',
    delete: 'delete from user where id=?',
    queryById: 'select * from user where id=?',
    queryAll: 'select * from user'
};

module.exports = user;
  • 工具方法生成uid的hash
var crypto = require('crypto');

module.exports = {
    hash:function(){
        var data;
        if(arguments.length === 0){
            var current_date = (new Date()).valueOf().toString();
            var random = Math.random().toString();
            data = current_date + random;
        }else{
            data = arguments[0]
        }
        var current_date = (new Date()).valueOf().toString();
        var random = Math.random().toString();
        return crypto.createHash('sha1').update(data).digest('hex');
    }
    
}
image
  1. 路由接口
  • 接口目录用版本结构 api/v1/xxx
image
  • 接口编写api/vi/user.js
var express = require('express');
var router = express.Router();

var curdUser = require('../../crud/user');

/* */
router.post('/', function (req, res, next) {

    // 获取前台页面传过来的参数
    var param = req.body;

    // 向前台返回JSON方法的简单封装
    var jsonWrite = function (res, ret) {
        if(typeof ret === 'undefined') {
            res.json({
                code:'1',
                msg: '操作失败'
            });
        } else {
            res.json(ret);
        }
    };

    

    curdUser.add(param,res,next,jsonWrite)

});

module.exports = router;

6. 将上面的express项目上传到 github

https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

7. 在服务器clone 刚才上传的express项目

  • 生成ssh
https://www.cnblogs.com/horanly/p/6604104.html
  • 找到服务器上面的ssh的公钥
cd /root/.ssh

cat id_rsa.pub 
  • 复制公钥,去github设置里面,配置ssh
image
  • 拉取项目
git clone git@github.com:op-captain/mock.git
  • 进入mock安装依赖模块

    npm install

8. 安装pm2工具,管理nodejs服务

clone完成后安装工具

npm install -g pm2

9. 启动express

进入到项目根目录中,用pm2工具启动项目

pm2 start ./bin/www --watch
image
image

10 开启服务器安全组端口

由于我的腾讯云服务开启了安全组,所以要增加一个 3000端口的规则。

查看端口是否正常

netstat -tunlp 

11. 本地测试新增接口

  • 安装postman接口工具
  • 发送接口

post类型,接口参数和express里面一样,也是就是和刚才用户表一至

image

数据库成功新增一条数据

image

至此nodejs操作数据已全部完成和调通。

vue

最后一环,前端vue调用接口,通过nginx反向代理到express的接口。

接口请求不是nodejs服务端的3000端口,而是利用nginx的反向代理,请求的nginx静态资源地址

    //接口地址
     public url = "http://www.itokay.cn/api/v1/user";

整个测试请求的代码。vue+typescript的写法。用类的方式写的vue组件

    <template>
    <div>
    <h1>测试接口</h1>
    <input @click="addUser" type="button" v-bind:value="content">
    </div>
    </template>
    
    <script lang="ts">
    import { Component, Prop, Vue } from 'vue-property-decorator';
    
    @Component
    export default class HelloWorld extends Vue {
      //接口地址
      public url = "http://www.itokay.cn/api/v1/user";
    
      //接口需要的参数
      public params:object = {
        "name":"Jon",
        "sex":1,
        "age":8,
        "avator":"http://tx.haiqq.com/uploads/allimg/170506/0G9454641-12.jpg"
      }
    
      //fetch参数
      protected option:object = {
        method: 'POST',
        headers: {
          'Content-Type': 'application/json'
        },
        body: JSON.stringify(this.params)
      }
    
      //按钮文字
      protected content:string = "调用新增用户接口";
    
      //事件方法
      public async addUser(){
        let result = await fetch(this.url,this.option);
    
        result.json().then((data)=>{
          console.log(data);
        })
      }
    }
    </script>

线上项目成功调用接口

image

踩坑说明

数据格式

application/x-www-form-urlencoded,body需要是a=1&b=2&c=3 格式,无法传递复杂多层次的对象

//'Content-Type': 'application/json'

fetch('/test/post', {
    headers: {
       "Content-Type": "application/x-www-form-urlencoded" 
    },
    method: 'POST',
    body:  "a=1&b=2&c=3"
        })

通过使用application/json ,可以直接传递JSON字符串,post复杂类型

//"Content-Type": "application/json"

fetch('/test/post', {
        headers: { 
            "Content-Type": "application/json"
        },
        method: 'POST',
        body:  JSON.stringify({a:1,b:{c:2,d:3}})
    })

跨域问题

The 'Access-Control-Allow-Origin' header contains multiple values '*, *', but only one is allowed

原因是在nginx和express里面都设置了。去掉其中一个。我去掉的是nginx

// express
app.use(function(req, res, next) {
    res.header("Access-Control-Allow-Origin", "*");
    res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
    next();
});


//nginx
location / {
   add_header Access-Control-Allow-Origin *;
   add_header Access-Control-Allow-Headers X-Requested-With;
   add_header Access-Control-Allow-Methods GET,POST,PUT,DELETE,OPTIONS;
    
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354