0.前言
  上一篇博客已经介绍了,阶段性小结。目前第一版的物联网平台已经趋于完成。框架基本不变了,剩下就是调整一些UI,还有配合硬件和市场那边,看看怎么推广这个平台。能不能挣点外快。第一版系统虽然简陋,但是对于整个物联网业务的了解还是有很大的帮助的。就像一个道理,吃10个包子,吃到最后一个饱了,但不能说前面9个没有用。不过硬件、市场、项目等等,这些是我不能控制的。但是平台的迭代和第二版规划不能停。第二版物联网平台,将采用现有的企业开发框架,并且是前后端分离,开始用上前端的Vue框架。
  前段时间,经人推荐一个企业级开发平台前后端脚手架。Bladex。官网【https://bladex.vip/#/】经测试,真的不错,该有的功能都有。比我自己写的好太多了。下面博客仅记录整个环境搭建和简单配置开发的流程。

1.授权
  这里还是推荐购买授权,也就3999,永久使用。对于一个公司来说,这个费用真的特别划算。下面介绍将以商业授权版本的Bladex-Boot作为介绍入门。获得授权后,对方会给一个私有git仓库的帐号密码,登陆后,下载源代码,前后端代码下载后,导入到IDE。

2.配置后端
  这里我是用2.1.0版本,IDE,我用的是Eclipse,需要安装lombok插件。至于数据库Postgresql、Redis,还有前端的NodeJS、VSCode这些自行安装。
  首先创建数据库,导入SQL脚本。这里我以postgresql为例。

  配置application-dev.yaml

  配置application.yml,注意修改端口,我这边改成8080

  以上配置后,就启动项目,启动后,由于前后端分离,我们还没有配置Saber,可以先访问http://127.0.0.1:8080/doc.html,确认BladeX是否正常启动。

3.配置前端
  我这里前后端是部署在不同的机器上。首先,下载代码,导入到VSCode上。
  修改vue.config.js的几个配置,target改为BladeX的访问地址和端口。devServer.port是BladeX的访问地址。

  配置后,运行命令启动服务

 yarn install
 yarn run serve

  访问:http://172.16.23.241:8080/

  点击登录后,到此,我们已经完成BladeX的环境安装和搭建了。

4.写个简单的Demo
  创建数据库表

 --测试表
 create table tb_wunaozai(
     id bigserial primary key,   --主键id,一般表格必须带上
     title ),         --自定义,标题
     content ),       --自定义,内容
     time timestamp,             --自定义,时间
     info ),          --自定义,备注
     tenant_id ),      --如果启用多租户,需要带上
     create_user bigint,         --必选,创建用户ID
     create_dept bigint,         --必选,创建部门ID
     create_time timestamp,      --必选,创建时间
     update_user bigint,         --必选,更新 用户ID
     update_time timestamp,      --必选,更新时间
     status int,                 --必选,状态
     is_deleted int              --必选,软删除
 );

  系统后台,配置数据源,然后自动生成代码


  数据源:在数据源管理中的配置,用于选择从对应的库获取数据
  模块名:用于指定配置的名称,对代码生成不产生实际效果
  服务名:生成后,controller对应的前缀,以及分割 - 符号后面的字符串作为前端的分包名
  表名:用于代码生成所对应的表名称
  表前缀:生成实体类的时候,忽略掉的前缀,若不配置,则 tb_wunaozai 表生成的实体为 TbWunaozai ,若配置了 tb_ 为前缀,则生成的实体为Wunaozai
  主键名:表的主键名称
  包名:生成后端代码所在的包
  基础业务:如果选择是,则实体会继承 BaseEntity ,带有上一章红框的基础业务字段
  包装器:在某些复杂的模块,会用到 VO 和 Wrapper ,如果选择是则会自行生成
  后端生成路径:后端工程的根目录
  前端生成路径:前端工程的根目录

  那个生成路径,可以直接写项目根目录,但是我觉得有点风险,还是保存到其他目录,然后根据实际拷贝过去。

  将对应的生成的前端代码放到Saber目录下。

5. 配置菜单、权限
  在生成的后端代码里面有生成菜单的SQL,直接执行数据库SQL即可。

 INSERT INTO blade_menu(id, parent_id, code, name, alias, path, source, sort, category, action, is_open, remark, is_deleted)
 , , , , , );
 INSERT INTO blade_menu(id, parent_id, code, name, alias, path, source, sort, category, action, is_open, remark, is_deleted)
 , , , , );
 INSERT INTO blade_menu(id, parent_id, code, name, alias, path, source, sort, category, action, is_open, remark, is_deleted)
 , , , , );
 INSERT INTO blade_menu(id, parent_id, code, name, alias, path, source, sort, category, action, is_open, remark, is_deleted)
 , , , , );
 INSERT INTO blade_menu(id, parent_id, code, name, alias, path, source, sort, category, action, is_open, remark, is_deleted)
 , , , , );

  执行后,刷新前端页面,然后需要简单编辑调整一下。这里我放到工作台的下级菜单


  重启BladeX和Saber,然后打开新增加的功能页。

6.修改、调整前端代码
  修改wunaozai.vue主键里面的data数据的option属性。

       option: {
           height:'auto',
           calcHeight: 350,
           tip: false,
           border: true,
           index: true,
           viewBtn: true,
           selection: true,
           column: [
             {
               label: "标题",
               prop: "title",
               span: 12,
               search: true,
               rules: [{
                 required: true,
                 message: "请输入",
                 trigger: "blur"
               }]
             },
             {
               label: "时间",
               prop: "time",
               span: 12,
               type: 'date',
               format: 'yyyy-MM-dd',
               valueFormat: 'yyyy-MM-dd 00:00:00',
               rules: [{
                 required: true,
                 message: "请输入",
                 trigger: "blur"
               }]
             },
             {
               label: "内容",
               prop: "content",
               span: 24,
               type: "textarea",
               minRows: 6,
               rules: [{
                 required: true,
                 message: "请输入",
                 trigger: "blur"
               }]
             },
             {
               label: "备注",
               prop: "info",
               span: 24,
               rules: [{
                 message: "请输入",
                 trigger: "blur"
               }]
             },
           ]
         }

  调整后,显示的效果。

  更多配置,请参考这个文档 https://avuejs.com/doc/crud/crud-doc
  那个刷新按钮没有响应事件需要增加
  @refresh-change="refreshChange"

       refreshChange(page){
         this.onLoad(this.page);
       }

  至于模糊查询,就需要写代码了。本次不详细说明。
  到此,简单的搭建环境和CURD功能已经完成,还是比较简单的,需要写代码的地方不多,简单配置一下,就是一个页面。

本文地址:https://www.cnblogs.com/wunaozai/p/11739874.html
个人主页:https://www.wunaozai.com/

物联网架构成长之路(39)-Bladex开发框架环境搭建的更多相关文章

  1. 物联网架构成长之路(40)-Bladex开发框架入门

    0. 前言 前一小节,讲了如何入门,这里就简单讲一下如何自定义查询和权限控制配置. 1. 配置多租户 如果要启用该表的多租户功能,需要在application.yml 这里配置. 2. 配置模糊匹配 ...

  2. 物联网架构成长之路(25)-Docker构建项目用到的镜像1

    0. 前言 现在项目处于初级阶段,按照规划,先构建几个以后可能会用到的Image,并上传到阿里云的Docker仓库.以后博客中用到的Image,大部分都会用到这几个基础的Image,构建一个简单的物联 ...

  3. 物联网架构成长之路(31)-EMQ基于HTTP权限验证

    看过之前的文章就知道,我之前是通过搞插件,或者通过里面的MongoDB来进行EMQ的鉴权登录和权限验证.但是前段时间发现,还是通过HTTP WebHook 方式来调用鉴权接口比较适合实际使用.还是实现 ...

  4. 物联网架构成长之路(16)-SpringCloud从入门到吹水

    1.前言 Spring Cloud 现在比较流行,版本更新也是蛮快的,网上资料也是很多.很多参考网上资料就可以学到了.这里给个 http://blog.csdn.net/forezp/article/ ...

  5. 物联网架构成长之路(24)-Docker练习之Compose容器编排

    0.前言 一开始学的之后,是想一步到位直接上Kubernetes(K8s)的,后面没想到,好像有点复杂,有些概念不是很懂.因此学习东西还是要循序渐进,慢慢来.先了解单机编排技术Docker Compo ...

  6. 物联网架构成长之路(35)-利用Netty解析物联网自定义协议

    一.前言 前面博客大部分介绍了基于EMQ中间件,通信协议使用的是MQTT,而传输的数据为纯文本数据,采用JSON格式.这种方式,大部分一看就知道是熟悉Web开发.软件开发的人喜欢用的方式.由于我也是做 ...

  7. 物联网架构成长之路(33)-EMQ数据存储到influxDB

    一.前言 时隔一年半,技术变化特别快,学习也要跟上才行.以前写过EMQ数据转存问题,当时用了比较笨的方法,通过写插件的方式,把MQTT里面的数据发送到数据库进行存储.当时也是为了学习erlang和em ...

  8. 物联网架构成长之路(29)-Jenkins环境搭建

    0. 说明 哈哈,前面中间插入了一篇Eclipse增加Git插件,在此之前真的没有用过GIT. 1. 运行Jenkins 这里为了方便,还是用Docker方式安装,由于这个是标准的war报,不对Doc ...

  9. 物联网架构成长之路(3)-EMQ消息服务器了解

    1. 了解 物联网最基础的就是通信了.通信协议,物联网协议好像有那么几个,以前各个协议都有优劣,最近一段时间,好像各大厂商都采用MQTT协议,所以我也不例外,不搞特殊,采用MQTT协议,选定了协议,接 ...

随机推荐

  1. Python连载50-贪婪匹配、XPath介绍

    一.贪婪和非贪婪 1.贪婪:尽可能多的匹配,(*)表示贪婪匹配 2.非贪婪:找到符合条件的最小内容即可,(?)表示非贪婪 3.正则默认使用贪婪匹配 import re title = u"& ...

  2. 【Linux命令】安装命令(yum,rpm)

    安装软件有三种方式,第一种是源码安装(源码安装需要手动安装软件,安装的目录,还需要进行编译之后才能安装),步骤比较繁琐.第二种是RPM安装,rpm安装有点像windows系统的面板,会建立统一的数据库 ...

  3. javascript 模块化 (切记:学习思想)

    模块化(切记:学习思想) 如果不用模块化编写代码,那么会具有以下问题: 代码杂乱无章,没有条理性,不便于维护,不便于复用 很多代码重复.逻辑重复 全局变量污染 不方便保护私有数据(闭包) 模块化的基本 ...

  4. python 实现自定义切片类

    import numbers class Group: #支持切片操作 def __init__(self, group_name, company_name, staffs): self.group ...

  5. PlayJava Day001

    今日所学: /* 2019.08.19开始学习,此为补档. */ 三目(元)运算符 格式:(表达式)? 表达式为true返回值A : 表达式为false返回值B 例: String s=2>3 ...

  6. 这可能最简单的一种PS图片特效,零基础小白教程

    不少小伙伴都想学习PS,可是又觉得PS很难,学了一段时间却还是做不出什么惊艳的效果,没关系!小编今天就来教大家做一个超级简单的图片特效,就算是小白也能轻松学会!我们先来看看图片效果~ 想知道怎么做吗? ...

  7. 简单文件传输协议TFTP分析还原

    - 协议介绍 TFTP有如下特征: 1.UDP承载,请求端口固定为69: 2.没有列出目录内容功能: 3.无验证和加密机制: 4.仅有读取或写入文件功能: 5.支持三种不同的传输模式:"ne ...

  8. Windows命令行打开文件夹图形界面

    1.打开当前目录 explorer . 2.打开上级目录 explorer .. 3.打开任意目录 explorer dirname

  9. swift个人总结

    最近iOS10 已经开始正式使用,研究使用了swift3.0,将一些总结记录于此,以便以后查阅.持续更新中. swift中一般将一些功能相近的方法写在同一个延展中,便于代码的规范,找起来也方便.区别o ...

  10. .net4.0使用Dapper操作MySql

    准备使用Dapper操作MySql,由于电脑只有vs2010,所以需要Dapper和MySql组件支持.net 4.0.经过一番测试,终于弄出一个DEMO. 1.操作MySql需要用MySql.Dat ...