- js mysql 搭建_通过node-mysql搭建Windows+Node.js+MySQL环境的教程
weixin_39916758
jsmysql搭建
前言MySQL是一款常用的开源数据库产品,通常也是免费数据库的首选。查了一下NPM列表,发现Nodejs有13库可以访问MySQL,felixge/node-mysql似乎是最受关注项目,我也决定尝试用一下。要注意名字,”felixge/node-mysql”非”node-mysql”,安装部分会介绍这个小插曲!目录node-mysql介绍建立MySQL测试库node-mysql安装node-my
- windows nodejs mysql_通过node-mysql搭建Windows+Node.js+MySQL环境的教程_node.js
Z-JO
windowsnodejsmysql
前言MySQL是一款常用的开源数据库产品,通常也是免费数据库的首选。查了一下NPM列表,发现Nodejs有13库可以访问MySQL,felixge/node-mysql似乎是最受关注项目,我也决定尝试用一下。要注意名字,”felixge/node-mysql”非”node-mysql”,安装部分会介绍这个小插曲!目录node-mysql介绍建立MySQL测试库node-mysql安装node-my
- Error: ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by serv
畱䶒
errormysql
1、错误起因使用vscode连接本机mysql的时候,报了这个错误。Error:ER_NOT_SUPPORTED_AUTH_MODE:Clientdoesnotsupportauthenticationprotocolrequestedbyserver;considerupgradingMySQLclient2、错误原因查找晚上的资料,说的是目前的数据库连接使用的node-mysql模块不符合新版
- Node.js如何使用MySQL的连接池实例
刘佳季
Nodejs如何使用MySQLNodejs要连接MySQL,可以使用Nodejs的MysQL驱动来实现。比如,我们这里使用“node-mysql”连接数据库。我们使用下面的方式来连接数据库:首先,我们需要使用nodejs的包管理工具(npm)安装mysql的驱动。命令行如下:npminstallmusql现在,要在js文件中使用mysql,添加下面的代码到你的文件中:varmysql=requir
- express.js如何做mysql注入与node-mysql中防止SQL注入方法解析
大家都知道SQL注入对于网站或者服务器来讲都是一个非常危险的问题,如果这一方面没处理好的话网站可能随时给注入了,所以这篇文章就给大家总结了node-mysql中防止SQL注入的几种常用做法,有需要的朋友们可以参考借鉴。SQL注入简介SQL注入是比较常见的网络攻击方式之一,它不是利用操作系统的BUG来实现攻击,而是针对程序员编程时的疏忽,通过SQL语句,实现无帐号登录,甚至篡改数据库。node-my
- mysql econnreset_MySQL在node.js服务器上的空闲时间后给出“ read ECONNRESET”错误
weixin_39605894
mysqleconnreset
我正在运行通过node-mysql模块连接到MySQL的Node服务器。连接和查询MySQL最初运行良好,没有任何错误,但是,将Node服务器闲置几个小时后的第一个查询会导致错误。错误是熟悉的readECONNRESET,来自node-mysql模块的内部。堆栈跟踪(请注意,跟踪的三个条目属于我的应用程序的错误报告代码):Erroratexports.Error.utils.createClass
- node-Mysql数据库
前端切图仔
目标mysql数据库基础知识总结一、基础常用命令1.创建命令createuser‘用户名’@‘ip’identifiedby‘密码’;创建数据库用户dropuser用户名@ip删除用户showdatabases;查数据库showtables;看表createdatabase数据库名defaultcharsetutf8;创建数据库createtable表名(列名数据类型约束···,列名数据类型约束·
- Nodejs远程连接MySQL数据库
wswenyue
客户机系统环境win764bitNodejs:V0.10.5npm:1.4.28安装Nodejs的MySQL驱动(这里我使用felixge/node-mysql)felixge/node-mysql是一个纯nodejs的用javascript实现的一个MySQL客户端程序。felixge/node-mysql封装了Nodejs对MySQL的基本操作,100%MIT公共许可证。项目地址:https:
- node-mysql连接mysql失败Error: ER_NOT_SUPPORTED_AUTH_MODE
vieber
jsnodemysql
报错信息{Error:ER_NOT_SUPPORTED_AUTH_MODE:Clientdoesnotsupportauthenticationprotocolrequestedbyserver;considerupgradingMySQLclient这是自己在我的linux机器上,安装了mysqlVer8.0.12forLinuxonx86_64(MySQLCommunityServer-GPL
- Node.js下MySQL的使用实例
Easion.Y
nodejsmysqlnodejsmysql
Nodejs如何使用MySQLNodejs要连接MySQL,可以使用Nodejs的MysQL驱动来实现。比如,我们这里使用“node-mysql”连接数据库。我们使用下面的方式来连接数据库:首先,我们需要使用nodejs的包管理工具(npm)安装mysql的驱动。命令行如下:npminstallmysql现在,要在js文件中使用mysql,添加下面的代码到你的文件中:varmysql= requi
- Nodejs mysql 数据库增、删、改、查 操作
weixin_30878501
Nodejsmysql的增、删、改、查操作Nodejs连接mysql的增、删、改、查操作(转载自:http://blog.sina.com.cn/s/blog_5a6efa330102vctw.html)一、准备nodejs的教程,大多以操作mongodb为示例。但是mongodb有一些局限性,具体官网上有说。我打算用MySQL,因为多少还有点使用经验。先以研究为主。node-mysql,是目前最
- 关于nodejs使用sql时候出现的connect ECONNREFUSED
jianhua623
问题是node-mysql找不到sock的路径,所以在createConnection里指定一个socketPath到正确的sock路径
- node连接--MySQL
weixin_30888027
MySQL驱动器:node-mysql;MySQL对象关系映射器:node-sequelize;例子:package.json:{"name":"shopping-cart-example","version":"0.0.1","dependencies":{"express":"2.5.2","jade":"0.19.0","mysql":"0.9.5"}}config.json:{"host"
- Mysql修改root用户密码 For Mac
wujr5
mysql
背景最近做的一个项目是对某教学系统进行重构。开发团队中我负责的任务是web服务部分,主要是前端,服务端某些逻辑也要参与编程。开发团队决定使用Mysql作为我们的数据库。Nodejs作为服务端语言,然后使用package:node-mysql链接Mysql。我使用的机器是macbookpro,为了驱动项目和做相应的前端后端编程,在本地安装一个Mysql数据库进行调试无疑要比使用远程的数据库进行调试要
- Node服务端渲染+处理文件+操作mysql数据库(纯前端)
@baby张
后端技术
前段时间写了一篇简单的项目Node环境搭建,对路由和文件的处理,今天给大家带来的是,原生Node端渲染+处理文件+操作mysql,一个简单的小全栈demo。原生node+mysql+模板引擎art-template,服务端处理文件渲染,数据库增删demogithubdemo地址链接:https://github.com/babybrotherzb/node-mysql一、本地需要准备的东西1.本地
- node mysql增删改查
网络中迷茫
稳定版:npminstallmysql--save安装最新版本:npminstallfelixge/node-mysql连接数据库varmysql=require("mysql");varconnection=mysql.createConnection({host:'localhost',user:'root',password:'pwd',port:3306,//端口database:'数据库
- Node.js,Express :一个很赞的MySQL操作包,node-mysql-promise
Jacky张
前端前端
node-mysql-promiseInstall$npminstallnode-mysql-promise说明nodemysql操作封装类,基于promise,借鉴75team开源项目thinkjs中model操作,数据库连接使用node-mysql的连接池。使用示例varMysql=require('node-mysql-promise');varmysql=Mysql.createConne
- Node + MongoDB实现
Tony_HQ
很久没更新,今天看到有人评论说很希望能更新下去,最近工作事物繁多,主要又在写C#+Webapi这一块。近来用node+mongoDB写了个微信小程序服务端,就贴在这里替代一下node-mysql这个模块。从应用上来说,mongodb比mysql对中小公司更加友好!尤其是公司里没有对性能追求到极致。简单的贴一点代码和相应配置。添加package.json里dependencies"mongoose"
- 选用更加易懂的设计模式封装node-mysql
雀雨墨
52nodejs设计模式
js的三大特性之一封装性相信大家都是知道的。可是封装函数应该如何选用合理的设计模式呢。比如我们在用axios的发送ajax的时候可以写成axios.post().then().catch()的写法。这种链式的写法,让语句变得更加清晰明了。同样的我们队node-mysql的语句封装也可以模仿这种设计模式(称为构造模式)varmysql=require('mysql');functionconnect
- nod.js&mysql
GBBand乖宝宝
”自然界最有灵性的是人,人却要用石头祈福,不奇怪么?与其在石头上刻字祈求苍生,不如求自己努力坚定。”“正因人不够坚定,才想从更坚定的东西里寻求慰藉。因为最有灵性的是人,最无定性的,也是人。”一、准备:用MySQL,因为多少还有点使用经验。先以研究为主。node-mysql,是目前最火的node下的mysql驱动。因为nodejs本身不能管理数据库。二、数据库相关介绍:数据库(database)有好
- Node代码片段
宫若石
Node与Mysql交互采用node-mysql开源项目作为Node框架的MySQL扩展库包括以下方面:1.连接MySQL数据库操作2.查询MySQL数据库操作3.修改MySQL数据库操作4.插入MySQL数据库操作5.删除MySQL数据库操作6.MySQL数据库连接池连接MySQL数据库操作console.info("------mysqlconnetion()------");console.
- node-mysql
wjing
1、bulkinsert:碰到自增的主键,需要列出插入的column,为了去除主键普通insert,碰到自增的主键,不用列出column也行。insertintoset为mysql的扩展语法,适合插入单行insertintovalue为标准SQL语法,能一次插入多行数据示例1:tablename??varrow1=[1,2];varrow2=[3,4];varset=[row1,row2];var
- 12-廖雪峰-node-mysql
_panda
我们需要一个mysql直接官网下载安装一路安装下去就是安装完毕,我们要使用mysql自带的cmdps注意命令行要带“;”来实现。下面是MySql的几个重要的点1ORM如果直接使用mysql包提供的接口,我们编写的代码就比较底层,例如,查询代码:connection.query('SELECT*FROMusersWHEREid=?',['123'],function(err,rows){if(err
- 解析Node.js使用MySQL连接池
玲儿珑
这篇文章主要介绍了Node.js使用MySQL连接池的方法,结合具体实例形式分析了nodejs操作mysql连接池的相关模块安装、连接、查询等使用技巧,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。Nodejs如何使用MySQLNodejs要连接MySQL,可以使用Nodejs的MysQL驱动来实现。比如,我们这里使用"node-mysql"连
- node-mysql文档翻译
明明三省
模块Github地址安装npminstallmysql如果需要以前的版本0.9.x系列的文档,请访问v0.9branch.有时你可以从github中安装最新版本的node-mysql,具体怎么做请参考下面的示例:npminstallfelixge/node-mysql介绍这是一个node.Js的mysql驱动程序。这个驱动完全是用javascript写的,不需要任何编译工作。完全的遵守MIT开源协
- node+mysql2模块使用
独自迈向前方
前言文中仅根据个人理解列出一些常用功能node-mysql2英文原版node-mysql2与node-mysql的区别没有详细比对(我个人认为mysql2比较人性化)node-mysql2模块是node-mysql模块的一个扩展安装npminstall--savemysql2快速入门//引入constmysql=require('mysql2');//创建数据库连接constconnection=
- 记 node-mysql 掉进 mysql 的 wait_timeout 参数的坑
zvving
TMS公司tms(Node.js+Python开发的上线工具)碰到神奇的问题,『使用一段时间后』,express.js还正常跑着,却打不开需要数据库查询的页面,过30s后转到nginx的报错页。tms-web-prd-1(err):Error:readETIMEDOUTtms-web-prd-1(err):atexports._errnoException(util.js:949:11)tms-w
- [转载] nodejs连接MySQL备忘
Utopi_a
Nodejs连接mysql的增、删、改、查操作一、准备nodejs的教程,大多以操作mongodb为示例。但是mongodb有一些局限性,具体官网上有说。我打算用MySQL,因为多少还有点使用经验。先以研究为主。node-mysql,是目前最火的node下的mysql驱动。初步了用了一下,因为异步回调的这种方式,果然好多坑。下面这个项目的packagename是mysql,版本是
[email protected]
- node-mysql 连接池
俊滔_b059
前言具体代码发布在github了,不同分支代表在不同阶段的版本我的githubcreateConnectionvscreatePoolcreateConnection方法创建连接对象正式的说法是使用createConnection方法创建一个表示与mysql数据库服务器之间连接的connection对象createPool连接池在开发web应用程序时,连接池是一个很重要的概念。建立一个数据库连接所
- node-mysql实现异步操作(下)
Ezio
node.jsmysql异步编程
关于上篇文章node-mysql实现异步操作(上)介绍了如何进行异步操作,这篇文章就主要介绍如何封装node-mysql这个库的基本使用mysql库下载https://github.com/mysqljs/mysqlnpminstallmysql--save基本使用这是来自官方github上的例子//连接配置varmysql=require('mysql');varconnection=mysql
- jQuery 键盘事件keydown ,keypress ,keyup介绍
107x
jsjquerykeydownkeypresskeyup
本文章总结了下些关于jQuery 键盘事件keydown ,keypress ,keyup介绍,有需要了解的朋友可参考。
一、首先需要知道的是: 1、keydown() keydown事件会在键盘按下时触发. 2、keyup() 代码如下 复制代码
$('input').keyup(funciton(){  
- AngularJS中的Promise
bijian1013
JavaScriptAngularJSPromise
一.Promise
Promise是一个接口,它用来处理的对象具有这样的特点:在未来某一时刻(主要是异步调用)会从服务端返回或者被填充属性。其核心是,promise是一个带有then()函数的对象。
为了展示它的优点,下面来看一个例子,其中需要获取用户当前的配置文件:
var cu
- c++ 用数组实现栈类
CrazyMizzz
数据结构C++
#include<iostream>
#include<cassert>
using namespace std;
template<class T, int SIZE = 50>
class Stack{
private:
T list[SIZE];//数组存放栈的元素
int top;//栈顶位置
public:
Stack(
- java和c语言的雷同
麦田的设计者
java递归scaner
软件启动时的初始化代码,加载用户信息2015年5月27号
从头学java二
1、语言的三种基本结构:顺序、选择、循环。废话不多说,需要指出一下几点:
a、return语句的功能除了作为函数返回值以外,还起到结束本函数的功能,return后的语句
不会再继续执行。
b、for循环相比于whi
- LINUX环境并发服务器的三种实现模型
被触发
linux
服务器设计技术有很多,按使用的协议来分有TCP服务器和UDP服务器。按处理方式来分有循环服务器和并发服务器。
1 循环服务器与并发服务器模型
在网络程序里面,一般来说都是许多客户对应一个服务器,为了处理客户的请求,对服务端的程序就提出了特殊的要求。
目前最常用的服务器模型有:
·循环服务器:服务器在同一时刻只能响应一个客户端的请求
·并发服务器:服
- Oracle数据库查询指令
肆无忌惮_
oracle数据库
20140920
单表查询
-- 查询************************************************************************************************************
-- 使用scott用户登录
-- 查看emp表
desc emp
- ext右下角浮动窗口
知了ing
JavaScriptext
第一种
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/
- 浅谈REDIS数据库的键值设计
矮蛋蛋
redis
http://www.cnblogs.com/aidandan/
原文地址:http://www.hoterran.info/redis_kv_design
丰富的数据结构使得redis的设计非常的有趣。不像关系型数据库那样,DEV和DBA需要深度沟通,review每行sql语句,也不像memcached那样,不需要DBA的参与。redis的DBA需要熟悉数据结构,并能了解使用场景。
- maven编译可执行jar包
alleni123
maven
http://stackoverflow.com/questions/574594/how-can-i-create-an-executable-jar-with-dependencies-using-maven
<build>
<plugins>
<plugin>
<artifactId>maven-asse
- 人力资源在现代企业中的作用
百合不是茶
HR 企业管理
//人力资源在在企业中的作用人力资源为什么会存在,人力资源究竟是干什么的 人力资源管理是对管理模式一次大的创新,人力资源兴起的原因有以下点: 工业时代的国际化竞争,现代市场的风险管控等等。所以人力资源 在现代经济竞争中的优势明显的存在,人力资源在集团类公司中存在着 明显的优势(鸿海集团),有一次笔者亲自去体验过红海集团的招聘,只 知道人力资源是管理企业招聘的 当时我被招聘上了,当时给我们培训 的人
- Linux自启动设置详解
bijian1013
linux
linux有自己一套完整的启动体系,抓住了linux启动的脉络,linux的启动过程将不再神秘。
阅读之前建议先看一下附图。
本文中假设inittab中设置的init tree为:
/etc/rc.d/rc0.d
/etc/rc.d/rc1.d
/etc/rc.d/rc2.d
/etc/rc.d/rc3.d
/etc/rc.d/rc4.d
/etc/rc.d/rc5.d
/etc
- Spring Aop Schema实现
bijian1013
javaspringAOP
本例使用的是Spring2.5
1.Aop配置文件spring-aop.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmln
- 【Gson七】Gson预定义类型适配器
bit1129
gson
Gson提供了丰富的预定义类型适配器,在对象和JSON串之间进行序列化和反序列化时,指定对象和字符串之间的转换方式,
DateTypeAdapter
public final class DateTypeAdapter extends TypeAdapter<Date> {
public static final TypeAdapterFacto
- 【Spark八十八】Spark Streaming累加器操作(updateStateByKey)
bit1129
update
在实时计算的实际应用中,有时除了需要关心一个时间间隔内的数据,有时还可能会对整个实时计算的所有时间间隔内产生的相关数据进行统计。
比如: 对Nginx的access.log实时监控请求404时,有时除了需要统计某个时间间隔内出现的次数,有时还需要统计一整天出现了多少次404,也就是说404监控横跨多个时间间隔。
Spark Streaming的解决方案是累加器,工作原理是,定义
- linux系统下通过shell脚本快速找到哪个进程在写文件
ronin47
一个文件正在被进程写 我想查看这个进程 文件一直在增大 找不到谁在写 使用lsof也没找到
这个问题挺有普遍性的,解决方法应该很多,这里我给大家提个比较直观的方法。
linux下每个文件都会在某个块设备上存放,当然也都有相应的inode, 那么透过vfs.write我们就可以知道谁在不停的写入特定的设备上的inode。
幸运的是systemtap的安装包里带了inodewatch.stp,位
- java-两种方法求第一个最长的可重复子串
bylijinnan
java算法
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
public class MaxPrefix {
public static void main(String[] args) {
String str="abbdabcdabcx";
- Netty源码学习-ServerBootstrap启动及事件处理过程
bylijinnan
javanetty
Netty是采用了Reactor模式的多线程版本,建议先看下面这篇文章了解一下Reactor模式:
http://bylijinnan.iteye.com/blog/1992325
Netty的启动及事件处理的流程,基本上是按照上面这篇文章来走的
文章里面提到的操作,每一步都能在Netty里面找到对应的代码
其中Reactor里面的Acceptor就对应Netty的ServerBo
- servelt filter listener 的生命周期
cngolon
filterlistenerservelt生命周期
1. servlet 当第一次请求一个servlet资源时,servlet容器创建这个servlet实例,并调用他的 init(ServletConfig config)做一些初始化的工作,然后调用它的service方法处理请求。当第二次请求这个servlet资源时,servlet容器就不在创建实例,而是直接调用它的service方法处理请求,也就是说
- jmpopups获取input元素值
ctrain
JavaScript
jmpopups 获取弹出层form表单
首先,我有一个div,里面包含了一个表单,默认是隐藏的,使用jmpopups时,会弹出这个隐藏的div,其实jmpopups是将我们的代码生成一份拷贝。
当我直接获取这个form表单中的文本框时,使用方法:$('#form input[name=test1]').val();这样是获取不到的。
我们必须到jmpopups生成的代码中去查找这个值,$(
- vi查找替换命令详解
daizj
linux正则表达式替换查找vim
一、查找
查找命令
/pattern<Enter> :向下查找pattern匹配字符串
?pattern<Enter>:向上查找pattern匹配字符串
使用了查找命令之后,使用如下两个键快速查找:
n:按照同一方向继续查找
N:按照反方向查找
字符串匹配
pattern是需要匹配的字符串,例如:
1: /abc<En
- 对网站中的js,css文件进行打包
dcj3sjt126com
PHP打包
一,为什么要用smarty进行打包
apache中也有给js,css这样的静态文件进行打包压缩的模块,但是本文所说的不是以这种方式进行的打包,而是和smarty结合的方式来把网站中的js,css文件进行打包。
为什么要进行打包呢,主要目的是为了合理的管理自己的代码 。现在有好多网站,你查看一下网站的源码的话,你会发现网站的头部有大量的JS文件和CSS文件,网站的尾部也有可能有大量的J
- php Yii: 出现undefined offset 或者 undefined index解决方案
dcj3sjt126com
undefined
在开发Yii 时,在程序中定义了如下方式:
if($this->menuoption[2] === 'test'),那么在运行程序时会报:undefined offset:2,这样的错误主要是由于php.ini 里的错误等级太高了,在windows下错误等级
- linux 文件格式(1) sed工具
eksliang
linuxlinux sed工具sed工具linux sed详解
转载请出自出处:
http://eksliang.iteye.com/blog/2106082
简介
sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾
- Android应用程序获取系统权限
gqdy365
android
引用
如何使Android应用程序获取系统权限
第一个方法简单点,不过需要在Android系统源码的环境下用make来编译:
1. 在应用程序的AndroidManifest.xml中的manifest节点
- HoverTree开发日志之验证码
hvt
.netC#asp.nethovertreewebform
HoverTree是一个ASP.NET的开源CMS,目前包含文章系统,图库和留言板功能。代码完全开放,文章内容页生成了静态的HTM页面,留言板提供留言审核功能,文章可以发布HTML源代码,图片上传同时生成高品质缩略图。推出之后得到许多网友的支持,再此表示感谢!留言板不断收到许多有益留言,但同时也有不少广告,因此决定在提交留言页面增加验证码功能。ASP.NET验证码在网上找,如果不是很多,就是特别多
- JSON API:用 JSON 构建 API 的标准指南中文版
justjavac
json
译文地址:https://github.com/justjavac/json-api-zh_CN
如果你和你的团队曾经争论过使用什么方式构建合理 JSON 响应格式, 那么 JSON API 就是你的 anti-bikeshedding 武器。
通过遵循共同的约定,可以提高开发效率,利用更普遍的工具,可以是你更加专注于开发重点:你的程序。
基于 JSON API 的客户端还能够充分利用缓存,
- 数据结构随记_2
lx.asymmetric
数据结构笔记
第三章 栈与队列
一.简答题
1. 在一个循环队列中,队首指针指向队首元素的 前一个 位置。
2.在具有n个单元的循环队列中,队满时共有 n-1 个元素。
3. 向栈中压入元素的操作是先 移动栈顶指针&n
- Linux下的监控工具dstat
网络接口
linux
1) 工具说明dstat是一个用来替换 vmstat,iostat netstat,nfsstat和ifstat这些命令的工具, 是一个全能系统信息统计工具. 与sysstat相比, dstat拥有一个彩色的界面, 在手动观察性能状况时, 数据比较显眼容易观察; 而且dstat支持即时刷新, 譬如输入dstat 3, 即每三秒收集一次, 但最新的数据都会每秒刷新显示. 和sysstat相同的是,
- C 语言初级入门--二维数组和指针
1140566087
二维数组c/c++指针
/*
二维数组的定义和二维数组元素的引用
二维数组的定义:
当数组中的每个元素带有两个下标时,称这样的数组为二维数组;
(逻辑上把数组看成一个具有行和列的表格或一个矩阵);
语法:
类型名 数组名[常量表达式1][常量表达式2]
二维数组的引用:
引用二维数组元素时必须带有两个下标,引用形式如下:
例如:
int a[3][4]; 引用:
- 10点睛Spring4.1-Application Event
wiselyman
application
10.1 Application Event
Spring使用Application Event给bean之间的消息通讯提供了手段
应按照如下部分实现bean之间的消息通讯
继承ApplicationEvent类实现自己的事件
实现继承ApplicationListener接口实现监听事件
使用ApplicationContext发布消息