基于mpvue的微信小程序全栈保姆式教程二

上一篇文章已经把服务器配置完毕,接下来就是把代码在本地跑起来,在开发环境跑起来,在生成环境跑起来,在自己配置的服务器跑起来。

微信小程序注册

前往https://mp.weixin.qq.com/wxopen/waregister?action=step1注册自己的小程序账号,按照提示即可,然后前往https://mp.weixin.qq.com/wxopen/initprofileaction=home&lang=zh_CN&token=406389460新建一个微信,接下来下载微信小程序开发工具https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html,选择适合自己电脑的版本。

让代码在本地跑起来

配置本地环境

安装MySQL,建议下载xampp,用xampp自带的MySQL,用起来比较方便。下载Navicat Premium,上篇文章已经给出下载破解地址。

下载代码并本地运行起来

https://github.com/FFGF/XCDHBook下载代码到本地,打开xampp,点击MySQL的start 启动本地MySQL, 通过Navicat创建一个本地连接,进入本地数据库,新建一个cAuth数据库,然后将下载的代码server/tools/cAuth.sql导入到cAuth数据库。右键cAuth选择运行SQL文件,然后选择cAuth.sql运行即可。

打开xampp

新建cAuth数据库

接下来需要修改配置文件,推荐使用vscode编辑器,修改/XCDHBook/project.config.json 把里面的appid换成你自己微信小程序的appid

{
    "description": "项目配置文件。",
    "setting": {
        "urlCheck": false,
        "es6": true,
        "postcss": true,
        "minified": true,
        "newFeature": true
    },
    "miniprogramRoot": "./dist/",
    "qcloudRoot": "./server/",
    "compileType": "miniprogram",
    "appid": "wx56f6f1c59845b222",
    "projectname": "book",
    "libVersion": "2.2.3",
    "condition": {
        "search": {
            "current": -1,
            "list": []
        },
        "conversation": {
            "current": -1,
            "list": []
        },
        "game": {
            "currentL": -1,
            "list": []
        },
        "miniprogram": {
            "current": -1,
            "list": []
        }
    }
}

修改/src/config.js为下面所示

// 配置项
const host = 'http://localhost:5757'
const config = {
  host,
  loginUrl: `${host}/weapp/login`,
  userUrl: `${host}/weapp/user`
}
export default config

修改/server/config.js代码为下面所示,可以把其中的qcloudAppIdqcloudSecretIdqcloudSecretKey修改成你自己的。

const CONF = {
    serverHost: 'localhost',
    tunnelServerUrl: '',
    tunnelSignatureKey: '27fb7d1c161b7ca52d73cce0f1d833f9f5b5ec89',
    // 腾讯云相关配置可以查看云 API 秘钥控制台:https://console.cloud.tencent.com/capi
    qcloudAppId: '1253824455',
    qcloudSecretId: 'AKIDYCtbPHAQ8W0SySxBCZ4lbbi4W7nitQII',
    qcloudSecretKey: 'AGJcqBb50nTCuaCi9f6Pal0Kh8c7ZyHX',
    wxMessageToken: 'weixinmsgtoken',
    networkTimeout: 30000,

    port: '5757',
    rootPathname: '',

    // 微信小程序 App ID
    appId: '',

    // 微信小程序 App Secret
    appSecret: '',

    // 是否使用腾讯云代理登录小程序
    useQcloudLogin: true,

    /**
     * MySQL 配置,用来存储 session 和用户信息
     * 若使用了腾讯云微信小程序解决方案
     * 开发环境下,MySQL 的初始密码为您的微信小程序 appid
     */
    mysql: {
        host: 'localhost',
        port: 3306,
        user: 'root',
        db: 'cAuth',
        pass: '',
        char: 'utf8mb4'
    },

    cos: {
        /**
         * 地区简称
         * @查看 https://cloud.tencent.com/document/product/436/6224
         */
        region: 'ap-guangzhou',
        // Bucket 名称
        fileBucket: 'qcloudtest',
        // 文件夹
        uploadFolder: ''
    },

    // 微信登录态有效期
    wxLoginExpires: 7200,
    wxMessageToken: 'abcdefgh'
}
module.exports = CONF

然后在cmd下面进入到/XCDHBook目录下运行 npm install 安装依赖,如果网速很慢建议换成淘宝的镜像npm install -g cnpm --registry=https://registry.npm.taobao.org 运行cnpm install进行依赖安装,然后cnpm run dev或者npm run dev 运行小程序。然后再打开一个cmd进入到/XCDHBook/server 和上面一样,运行小程序后端代码。安装依赖 cnpm install , 安装nodemon cnpm install -g nodemon,然后cnpm run dev 或者npm run dev运行起来,目前为止有两个cmd,一个是后端代码,一个是前端小程序代码。
打开微信小程序开发工具,记得勾选不校验合法域名、web-view(业务域名)、TLS 版本以及 HTTPS 证书,把项目目录定位到XCDHBook即可,打开后点击上面的编译,编译一下就行了。这个时候你就可以看到微信小程序已经跑起来了。

微信开发者工具

设置https

XCDHBook

注意这个时候还不能真机预览,你点击了预览按钮会生成一个二维码,扫描后并不能看到数据,因为手机无法找到电脑localhost的数据。接下来让小程序在开发环境跑起来,可以真机预览一下

开通开发环境,进行真机预览

https://mp.weixin.qq.com/wxopen/thirdtools?action=index&token=406389460&lang=zh_CN 选择开通腾讯云,进入后台开发环境

开通开发环境

后台管理

https://console.qcloud.com/lav2/dev,可以看到腾讯为你准备了一套的配套措施,其实就是上篇文章咱们配置的服务器。把二级域名复制粘贴一下,修改配置文件即可。
开发环境

先把数据库导入到开发环境点击phpMyAdmin按钮,账户是root,密码是你的appid,里面已经存在数据库cAuth,我们只要把我们的表导进去即可,如果导入过程中出现错误,也不怕,我们直接打开cAuth.sql,把里面的sql语句复制粘贴出来,然后点击SQL按钮,直接运行sql进行建表,然后插入数据即可。
导入mysql

运行sql

修改/XCDHBook/src/config.js,把host换成你自己的开发环境二级域名

// 配置项
const host = 'https://mxvlh6mn.qcloud.la'

const config = {
  host,
  loginUrl: `${host}/weapp/login`,
  userUrl: `${host}/weapp/user`
}
export default config

修改/XCDHBook/service/config.js,主要是就是注释掉为了本地开发而做的设置,然后把数据库密码修改成你的appid

const CONF = {
    // serverHost: 'localhost',
    // tunnelServerUrl: '',
    // tunnelSignatureKey: '27fb7d1c161b7ca52d73cce0f1d833f9f5b5ec89',
    // // 腾讯云相关配置可以查看云 API 秘钥控制台:https://console.cloud.tencent.com/capi
    // qcloudAppId: '1253824455',
    // qcloudSecretId: 'AKIDYCtbPHAQ8W0SySxBCZ4lbbi4W7nitQII',
    // qcloudSecretKey: 'AGJcqBb50nTCuaCi9f6Pal0Kh8c7ZyHX',
    // wxMessageToken: 'weixinmsgtoken',
    // networkTimeout: 30000,

    port: '5757',
    rootPathname: '',

    // 微信小程序 App ID
    appId: '',

    // 微信小程序 App Secret
    appSecret: '',

    // 是否使用腾讯云代理登录小程序
    useQcloudLogin: true,

    /**
     * MySQL 配置,用来存储 session 和用户信息
     * 若使用了腾讯云微信小程序解决方案
     * 开发环境下,MySQL 的初始密码为您的微信小程序 appid
     */
    mysql: {
        host: 'localhost',
        port: 3306,
        user: 'root',
        db: 'cAuth',
        pass: 'wx56f6f1c59845b222',
        char: 'utf8mb4'
    },

    cos: {
        /**
         * 地区简称
         * @查看 https://cloud.tencent.com/document/product/436/6224
         */
        region: 'ap-guangzhou',
        // Bucket 名称
        fileBucket: 'qcloudtest',
        // 文件夹
        uploadFolder: ''
    },

    // 微信登录态有效期
    wxLoginExpires: 7200,
    wxMessageToken: 'abcdefgh'
}
module.exports = CONF

上传代码到腾讯云开发环境,第一次上传采用模块上传,以后采用智能上传


上传开发环境代码

第一次上传

这个时候再进行编译,预览即可手机查看了。

开通生产环境,让小伙伴看一下

https://console.qcloud.com/lav2/production 选择nodejs环境即可,选择11块钱的.xyz域名,选择49块的服务器。支付60后,腾讯会帮你自动部署环境,安装依赖。和开哦听开发环境一样,把数据库导入进去,可以修改数据库的密码好记一点,比如修改成qwerabc。

修改数据库密码

开通后修改一下配置,主要是把/XCDHBook/src/config.js host换成你的生产环境的域名,修改/XCDHBook/service/config.js 里面把数据库密码修改成你的qwerabc,自己刚刚设定的密码。然后点击腾讯云上传正式代码,按照提示填写版本号和备注。
上传正式代码

然后回到https://console.qcloud.com/lav2/production生产环境,点击代码部署等候一会即可。这个时候就可以关闭本地服务器cmd了,因为用的是生产环境的数据库了。
然后点击编译,预览即可。如果想让小伙伴也看到你需要添加小伙伴为体验者
添加小伙伴

接下来就是正式上线,点击微信小程序的上传按钮,然后登录小程序管理后台,提交审核即可,前提是你的域名要备案成功,不然无法提交。
上传

审核

部署后台到自己搭建的服务器

如果你没有搭建服务器这一节可以跳过了,上一篇文章搭建了服务器,接下来我们要把代码部署到上面去。首先要修改/XCDHBook/src/config.js host换成你的生服务器域名,其次修改/XCDHBook/service/config.js 修改成下面所示。其中appId、appSecret修改成你自己的,数据库面修改成你自己的数据库密码,rootPathname修改成你自己代码存放的位置,放到/data/release/weapp即可了

const CONF = {
    // serverHost: 'localhost',
    // tunnelServerUrl: '',
    // tunnelSignatureKey: '27fb7d1c161b7ca52d73cce0f1d833f9f5b5ec89',
    // // 腾讯云相关配置可以查看云 API 秘钥控制台:https://console.cloud.tencent.com/capi
    // qcloudAppId: '1253824455',
    // qcloudSecretId: 'AKIDYCtbPHAQ8W0SySxBCZ4lbbi4W7nitQII',
    // qcloudSecretKey: 'AGJcqBb50nTCuaCi9f6Pal0Kh8c7ZyHX',
    // wxMessageToken: 'weixinmsgtoken',
    // networkTimeout: 30000,

    port: '5757',
    rootPathname: '/data/release/weapp',

    // 微信小程序 App ID
    appId: 'wx56f6f1c59845b222',

    // 微信小程序 App Secret
    appSecret: 'wx56f6f1c5984qefwrgefe',

    // 是否使用腾讯云代理登录小程序
    useQcloudLogin: true,

    /**
     * MySQL 配置,用来存储 session 和用户信息
     * 若使用了腾讯云微信小程序解决方案
     * 开发环境下,MySQL 的初始密码为您的微信小程序 appid
     */
    mysql: {
        host: 'localhost',
        port: 3306,
        user: 'root',
        db: 'cAuth',
        pass: 'wx56f6f1c59845b222',
        char: 'utf8mb4'
    },

    cos: {
        /**
         * 地区简称
         * @查看 https://cloud.tencent.com/document/product/436/6224
         */
        region: 'ap-guangzhou',
        // Bucket 名称
        fileBucket: 'qcloudtest',
        // 文件夹
        uploadFolder: ''
    },

    // 微信登录态有效期
    wxLoginExpires: 7200,
    wxMessageToken: 'abcdefgh'
}
module.exports = CONF

上传代码到服务器,把server目录下面除了node_modules之前的文件进行打包server.zip,然后通过xshell进入服务器
安装 apt-get install lrzsz
cd /data/release/weapp目录下,rz命令上传刚刚打包好的文件,上传完毕后通过
unzip server.zip解压。运行npm run install安装依赖,然后npm run dev运行起来即可,别忘了开启nginx,可以 通过命令service nginx restart 进行重启,这个时候在运行本地的微信小程序即可,可以通过微信开发者工具的调试器的Network看到数据是从自己的服务器获得的。但是一退出xshell就发现,就不能或者数据了,可以通过nohup num run dev命令在后台运行。下次通过xshell在登录服务器可以通过命令
netstat -apn | grep 5757找到对应的线程,然后通过kill -9 进程号 将其杀死,就可以再次启动服务了。
有个坑就是上一篇咱们的ssl是自己生成的,不是购买的,导致一个问题就是通过微信开发者工具可以请求到数据,但是预览的话就不行,ssl必须要是购买的,如果是自己做的,手机无法请求到。

总结

我github里面的html代码是用pug编写的,css是用stylus编写的,和视频里面稍微有点不一样,主要是我感觉缩进很好看。具体的代码编写可以查看视频跟着学习。

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

推荐阅读更多精彩内容