Spring Boot + Vue3 前后端分离 实战wiki知识库系统完结

  

 

download:Spring Boot + Vue3 前后端分离 实战wiki知识库系统

 

 


  软件包com.DMS;

  导入Java.IO  .缓冲读取器;

  导入日本文件;

  导入Java.io  .文件输出流;

  导入Java.IO执行;

  输入流读取器;

  输入Java.io  .输出串流程式;

  import  Java.io  .打印机;

  import  Java.net  .服务器插座;

  导入Java.net  .套接字;

  导入Java.UTIL.Hashmap;

  导入Java.util  .列表;

  汇入Java.util  .地图;

  导入Java.util.concurrent  .块队列;

  导入Java.util.concurrent  .执行服务;

  导入Java.util.concurrent  .执行程序;

  导入Java.util.concurrent  .链接块队列;

  导入org.Dom4j  .文档;

  导入Org.Dom4j.Element;

  import  org.dom4j.io.SAXReader;

  /**

  * * *用于接收来自DMS服务器端、各客户端的发送

  * *将日志配对保存到本地文件

  * * @自动管理员

  *

  */

  公共类DMS服务器{

  //属性定义

  //用于接收客户端连接的服务器端servlet

  专用服务器套接字服务器

  //管理处理客户端请求的线程的线程池

  私有EXECutorservicethreadpool;

  /保存所有客户端发送来的配对文件

  专用文件服务器日志文件;

  //消息队列

  privateblockingqueuemessagequeue=newlinkedblockingqueue  ();公共DMS服务器() throws执行{

  特里

  System.out.println  ('服务器正在初始化.');

  /1分析配置文件server-config.xml

  地图配置=载入配置();

  /2根据配置文件的内容初始化属性

  init  (配置);

  System.out.println  ('服务器端初始化完成.')

  缓存(执行) {

  System.out.println  ('服务器端初始化失败!' 说。

  旋转e;

  }

  }

  /**

  * * *在初始化构建方法的第一步,分析配置文件

  * @return返回的Map包含配置文件中的

  所有内容。 key:标记的名称

  * value是标签的中间文本

  * * @ throws执行

  */

  私有地图加载配置() throws执行{ }

  特里

  sa  xreader读取器=新的sa  xreader  ();

  文档文档文档

  =reader.read  (新文件('服务器-配置. XML  ' ) :

  Element  root=doc.getRootElement  ();

  地图配置

  =新哈斯图();

  /*

  * *获取标签中的所有子标签

  每个子标签的名称为key,中间的* *文本作为值存储在映射集合中

  */

  列表=根.元素();

  for  (元素e  :列表) {

  字符串密钥=e.getname  ();

  字符串值=e.gettext  trim  ();

  config.put  (密钥、值);

  }

  返回配置;

  缓存(执行) {

  System.out.println  ('解决配置文件异常!' 说。

  e  .打印堆栈跟踪();

  旋转e;

  }

  }

  /**

  * * *构造方法初始化第二个步骤,然后根据设置项目初始化属性

  * * @ param配置

  * * @ throws执行

  */

  私有语音初始化(地图配置)吞吐量执行{

  /*

  * * *配置文件初始化属性:服务器日志文件

  * * *配置文件初始化属性:使用threadPool创建固定大小的线程池。 该值为线程池线程数

  * * *配置文件初始化属性:服务器,在此使用服务器套接字的服务端口

  */

  this.server=新服务器套接字(

  integer.parseint  (配置. get  ('服务器端口' ) )

  说。

  this  .服务器日志文件=新文件(

  config.get  ('日志文件' )说。

  this.thread  pool=executors.newfixedthreadpool  (

  integer.parseint  (config.get  (' threadsum  ' ) )

  说。

  }

  /**

  服务端开始工作的方法

  * * @ throws执行

  */

  公共语音开始() throws执行{

  /*

  * *实现要求:

  * *首先,分别启动要运行SaveLogHandler的线程

  此任务的目的是保存所有配对日志

  * * *然后,客户端连接后,服务器端端口开始循环

  实例化客户端处理程序并将该任务传递给线程池

  * *分配线程以处理与客户端的交互。

  *

  */

  特里

  System.out.println  ('服务器端开始工作.');

  saveloghandlerslh=newsaveloghandler  ();

  新读(slh  ).start  ()

  while  (真) {

  套接字套接字=服务器. accept  ();

  thread  pool.execute  (新客户端处理程序(套接字) )

  }

  缓存(执行) {

  e  .打印堆栈跟踪();

  旋转e;

  }

  }

  publicstaticvoidmain  (字符串[ ]数组) {

  特里DMS服务器=新的DMS服务器()

相关文章