2017-02-22 14:30:10 +08:00
|
|
|
|
using System;
|
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
using System.ComponentModel;
|
|
|
|
|
|
using System.Data;
|
|
|
|
|
|
using System.Drawing;
|
|
|
|
|
|
using System.Linq;
|
|
|
|
|
|
using System.Text;
|
|
|
|
|
|
using System.Windows.Forms;
|
2017-04-23 18:05:12 +08:00
|
|
|
|
using HslCommunication.Enthernet;
|
2017-02-22 14:30:10 +08:00
|
|
|
|
using System.Threading;
|
|
|
|
|
|
using CommonLibrary;
|
2017-04-06 16:18:46 +08:00
|
|
|
|
using Newtonsoft.Json.Linq;
|
2017-05-04 11:43:50 +08:00
|
|
|
|
using HslCommunication.BasicFramework;
|
2017-02-22 14:30:10 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
2017-05-18 18:09:49 +08:00
|
|
|
|
// 模版日期 2017-05-18
|
2017-02-22 14:30:10 +08:00
|
|
|
|
// 创建人 胡少林
|
|
|
|
|
|
// 版权所有 胡少林
|
|
|
|
|
|
// 授权说明 模版仅授权个人使用,如需商用,请联系hsl200909@163.com洽谈
|
|
|
|
|
|
// 说明 JSON组件引用自james newton-king,遵循MIT授权协议
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
|
//
|
|
|
|
|
|
// 注意:本代码的相关操作未作密码验证,如有需要,请自行完成
|
2017-05-17 22:20:52 +08:00
|
|
|
|
// 示例:具体示例参照本页面Form1_FormClosing(object sender, FormClosingEventArgs e)方法
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
|
//
|
2017-05-18 18:09:49 +08:00
|
|
|
|
// 本项目模版不包含 《软件自动更新.exe》
|
2017-05-17 22:20:52 +08:00
|
|
|
|
// 如需支持部署环境的自动升级 请联系hsl200909@163.com获取
|
2017-05-18 18:09:49 +08:00
|
|
|
|
// 软件自动更新.exe 将绑定IP,端口和软件名称后授权销售,30元人民币一组,永久使用
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace 软件系统服务端模版
|
|
|
|
|
|
{
|
|
|
|
|
|
public partial class Form1 : Form
|
|
|
|
|
|
{
|
|
|
|
|
|
public Form1()
|
|
|
|
|
|
{
|
|
|
|
|
|
InitializeComponent();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#region 窗口属性+窗口方法
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 指示窗口是否处于显示中
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private bool IsWindowShow { get; set; } = false;
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 指示系统是否启动
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private bool IsSystemStart { get; set; } = false;
|
|
|
|
|
|
|
|
|
|
|
|
private void Form1_Load(object sender, EventArgs e)
|
|
|
|
|
|
{
|
2017-05-04 15:27:14 +08:00
|
|
|
|
//初始化日志工具
|
2017-05-19 10:20:10 +08:00
|
|
|
|
RuntimeLogHelper = new SoftLogHelper()
|
2017-05-04 15:27:14 +08:00
|
|
|
|
{
|
|
|
|
|
|
LogSaveFileName = Application.StartupPath + @"\log.txt",
|
|
|
|
|
|
};
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//保存路径初始化
|
|
|
|
|
|
UserServer.ServerSettings.FileSavePath = Application.StartupPath + @"\settings.txt";
|
|
|
|
|
|
//加载参数
|
|
|
|
|
|
UserServer.ServerSettings.LoadByFile();
|
|
|
|
|
|
toolStripStatusLabel_version.Text = UserServer.ServerSettings.SystemVersion.ToString();
|
2017-03-08 18:46:28 +08:00
|
|
|
|
toolStripStatusLabel1.Text = $"本软件著作权归{Resource.StringResouce.SoftCopyRight}所有";
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//加载账户信息
|
2017-03-06 21:10:38 +08:00
|
|
|
|
UserServer.ServerAccounts.FileSavePath = Application.StartupPath + @"\accounts.txt";
|
2017-02-22 14:30:10 +08:00
|
|
|
|
UserServer.ServerAccounts.LoadByFile();
|
2017-05-19 10:20:10 +08:00
|
|
|
|
UserServer.ServerAccounts.LogHelper = RuntimeLogHelper;
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
private void Form1_FormClosing(object sender, FormClosingEventArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
//密码验证的示例,此处关闭窗口验证
|
2017-05-04 15:27:14 +08:00
|
|
|
|
using (FormPasswordCheck fpc = new FormPasswordCheck("123456"))
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-05-04 15:27:14 +08:00
|
|
|
|
if (fpc.ShowDialog() == DialogResult.OK)
|
|
|
|
|
|
{
|
|
|
|
|
|
IsWindowShow = false;
|
|
|
|
|
|
Thread.Sleep(20);
|
2017-05-05 23:07:44 +08:00
|
|
|
|
//关闭网络引擎
|
|
|
|
|
|
net_socket_server.ServerClose();
|
2017-05-06 12:54:57 +08:00
|
|
|
|
net_simplify_server.ServerClose();
|
2017-05-04 15:27:14 +08:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
//取消关闭
|
|
|
|
|
|
e.Cancel = true;
|
|
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
//紧急数据的保存已经放置到dispose方法中,即时发生BUG或直接关机,也能存储数据
|
|
|
|
|
|
}
|
|
|
|
|
|
private void Form1_Shown(object sender, EventArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
IsWindowShow = true;
|
2017-03-06 21:10:38 +08:00
|
|
|
|
//维护初始化
|
2017-02-22 14:30:10 +08:00
|
|
|
|
MaintenanceInitialization();
|
2017-03-06 21:10:38 +08:00
|
|
|
|
//时间引擎初始化
|
|
|
|
|
|
TimeTickInitilization();
|
2017-02-22 14:30:10 +08:00
|
|
|
|
Refresh();
|
|
|
|
|
|
启动服务器ToolStripMenuItem.PerformClick();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
#region 菜单逻辑块
|
|
|
|
|
|
private void 启动服务器ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (!IsSystemStart)
|
|
|
|
|
|
{
|
|
|
|
|
|
Net_Simplify_Server_Initialization();
|
|
|
|
|
|
Net_Socket_Server_Initialization();
|
|
|
|
|
|
Net_SoftUpdate_Server_Initialization();
|
|
|
|
|
|
Net_File_Update_Initialization();
|
2017-04-06 16:18:46 +08:00
|
|
|
|
Simple_File_Initiaization();
|
2017-02-22 14:30:10 +08:00
|
|
|
|
启动服务器ToolStripMenuItem.Text = "已启动";
|
|
|
|
|
|
启动服务器ToolStripMenuItem.BackColor = Color.LimeGreen;
|
|
|
|
|
|
IsSystemStart = true;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void 版本控制ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
2017-05-04 15:27:14 +08:00
|
|
|
|
using (FormVersionControl fvc = new FormVersionControl(UserServer.ServerSettings))
|
|
|
|
|
|
{
|
|
|
|
|
|
fvc.ShowDialog();
|
|
|
|
|
|
toolStripStatusLabel_version.Text = UserServer.ServerSettings.SystemVersion.ToString();
|
|
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void 维护切换ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
2017-05-04 15:27:14 +08:00
|
|
|
|
using (FormMaintenance fm = new FormMaintenance(UserServer.ServerSettings))
|
|
|
|
|
|
{
|
|
|
|
|
|
fm.ShowDialog();
|
|
|
|
|
|
MaintenanceInitialization();
|
|
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-03-06 21:10:38 +08:00
|
|
|
|
|
2017-02-22 14:30:10 +08:00
|
|
|
|
|
|
|
|
|
|
private void 消息发送ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
2017-03-04 17:07:26 +08:00
|
|
|
|
//测试发送字节数据
|
|
|
|
|
|
//net_socket_server.SendAllClients(BitConverter.GetBytes(12345678));
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//将消息群发给所有的客户端,并使用消息弹窗的方式显示
|
2017-05-04 15:27:14 +08:00
|
|
|
|
using (FormInputAndAction fiaa = new FormInputAndAction(
|
|
|
|
|
|
m =>
|
|
|
|
|
|
{
|
|
|
|
|
|
net_socket_server.SendAllClients(CommonHeadCode.MultiNetHeadCode.弹窗消息 + m); return true;
|
|
|
|
|
|
}))
|
2017-03-04 17:07:26 +08:00
|
|
|
|
{
|
2017-05-04 15:27:14 +08:00
|
|
|
|
fiaa.ShowDialog();
|
|
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void 一键断开ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
//关闭信号发送至所有在线客户端
|
|
|
|
|
|
net_socket_server.SendAllClients(CommonHeadCode.MultiNetHeadCode.关闭所有客户端);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void 关于软件ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
2017-05-04 15:27:14 +08:00
|
|
|
|
using (FormAbout fm = new FormAbout(
|
2017-05-04 11:43:50 +08:00
|
|
|
|
Resource.StringResouce.SoftName, UserServer.ServerSettings.SystemVersion,
|
2017-05-04 15:27:14 +08:00
|
|
|
|
2017, Resource.StringResouce.SoftCopyRight))
|
|
|
|
|
|
{
|
|
|
|
|
|
fm.ShowDialog();
|
|
|
|
|
|
}
|
2017-05-20 09:41:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
private void 框架作者ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
using (FormAuthorAdvertisement faa = new FormAuthorAdvertisement())
|
|
|
|
|
|
{
|
|
|
|
|
|
faa.ShowDialog();
|
|
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
private void 账户管理ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
|
|
|
|
|
//该部分比较复杂,需要对委托,匿名委托概念比较清晰
|
2017-05-04 15:27:14 +08:00
|
|
|
|
using (FormAccountManage fam = new FormAccountManage(() => UserServer.ServerAccounts.GetAllAccountsJson(),
|
|
|
|
|
|
m => { UserServer.ServerAccounts.LoadAllAccountsJson(m); return true; }))
|
|
|
|
|
|
{
|
|
|
|
|
|
fam.ShowDialog();
|
|
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void 版本号说明ToolStripMenuItem_Click(object sender, EventArgs e)
|
|
|
|
|
|
{
|
2017-05-04 15:27:14 +08:00
|
|
|
|
using (FormAboutVersion fav = new FormAboutVersion(UserServer.ServerSettings.SystemVersion))
|
|
|
|
|
|
{
|
|
|
|
|
|
fav.ShowDialog();
|
|
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
private void MaintenanceInitialization()
|
|
|
|
|
|
{
|
|
|
|
|
|
//维护状态变更
|
|
|
|
|
|
if (UserServer.ServerSettings.Can_Account_Login)
|
|
|
|
|
|
{
|
|
|
|
|
|
label3.Text = "可登录";
|
|
|
|
|
|
label3.BackColor = Color.LimeGreen;
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
label3.Text = "维护中";
|
|
|
|
|
|
label3.BackColor = Color.Tomato;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
#region 软件更新服务引擎
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 支持软件自动更新的后台服务引擎
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private Net_SoftUpdate_Server net_soft_update_Server = new Net_SoftUpdate_Server();
|
|
|
|
|
|
private void Net_SoftUpdate_Server_Initialization()
|
|
|
|
|
|
{
|
|
|
|
|
|
try
|
|
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_soft_update_Server.LogHelper.LogSaveFileName = Application.StartupPath + @"\update_log.txt";
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//在服务器的这个路径下,放置客户端运行的所有文件,不要包含settings文件,不要从此处运行
|
|
|
|
|
|
//只放置exe和dll组件,必须放置:软件自动更新.exe
|
2017-03-14 10:14:12 +08:00
|
|
|
|
net_soft_update_Server.KeyToken = CommonHeadCode.KeyToken;
|
2017-05-06 12:54:57 +08:00
|
|
|
|
net_soft_update_Server.FileUpdatePath = Application.StartupPath + @"\ClientFiles";
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_soft_update_Server.ServerStart(CommonLibrary.CommonLibrary.Port_Update_Net);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
|
{
|
2017-05-04 11:43:50 +08:00
|
|
|
|
SoftBasic.ShowExceptionMessage(ex);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
#region 软件异地更新文件传送引擎
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 用于局域网异地更新服务器的客户端程序的引擎,仅限客户端
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private Net_File_Server net_file_update = new Net_File_Server();
|
|
|
|
|
|
/// <summary>
|
2017-05-04 15:27:14 +08:00
|
|
|
|
/// 软件异地更新的初始化,如不需要可以不启动,该功能支持发送客户端文件至服务器实现覆盖更新
|
2017-02-22 14:30:10 +08:00
|
|
|
|
/// </summary>
|
|
|
|
|
|
private void Net_File_Update_Initialization()
|
|
|
|
|
|
{
|
|
|
|
|
|
try
|
|
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_file_update.FilesPath = Application.StartupPath + @"\ClientFiles";//服务器客户端需要更新的路径,与上述一致
|
|
|
|
|
|
net_file_update.LogHelper.LogSaveFileName = Application.StartupPath + @"\update_file_log.txt";
|
2017-03-14 10:14:12 +08:00
|
|
|
|
net_file_update.KeyToken = CommonHeadCode.KeyToken;
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_file_update.ServerStart(CommonLibrary.CommonLibrary.Port_Update_Remote);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
|
{
|
2017-05-04 11:43:50 +08:00
|
|
|
|
SoftBasic.ShowExceptionMessage(ex);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
#region 同步数据传送引擎
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 用户同步数据传送的引擎
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private Net_Simplify_Server net_simplify_server = new Net_Simplify_Server();
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 同步传送数据的初始化
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private void Net_Simplify_Server_Initialization()
|
|
|
|
|
|
{
|
|
|
|
|
|
try
|
|
|
|
|
|
{
|
2017-03-05 18:32:55 +08:00
|
|
|
|
net_simplify_server.KeyToken = CommonHeadCode.KeyToken;//设置身份令牌
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_simplify_server.LogHelper.LogSaveFileName = Application.StartupPath + @"\simplify_log.txt";
|
2017-02-22 14:30:10 +08:00
|
|
|
|
net_simplify_server.ReceiveStringEvent += Net_simplify_server_ReceiveStringEvent;
|
|
|
|
|
|
net_simplify_server.ReceivedBytesEvent += Net_simplify_server_ReceivedBytesEvent;
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_simplify_server.ServerStart(CommonLibrary.CommonLibrary.Port_Second_Net);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
|
{
|
2017-05-04 11:43:50 +08:00
|
|
|
|
SoftBasic.ShowExceptionMessage(ex);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 接收来自客户端的字节数据
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="object1">客户端的地址</param>
|
|
|
|
|
|
/// <param name="object2">字节数据,根据实际情况选择是否使用</param>
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void Net_simplify_server_ReceivedBytesEvent(AsyncStateBase object1, byte[] object2)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, object2);
|
|
|
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 接收到来自客户端的数据,此处需要放置维护验证,更新验证等等操作
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="object1">客户端的地址</param>
|
|
|
|
|
|
/// <param name="object2">消息数据,应该使用指令头+数据组成</param>
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void Net_simplify_server_ReceiveStringEvent(AsyncStateBase object1, string object2)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
//必须返回结果,调用SendMessage(object1,[实际数据]);
|
2017-05-05 23:07:44 +08:00
|
|
|
|
if(object2.StartsWith("A"))
|
|
|
|
|
|
{
|
|
|
|
|
|
DataProcessingWithStartA(object1, object2);
|
|
|
|
|
|
}
|
|
|
|
|
|
else if(object2.StartsWith("B"))
|
|
|
|
|
|
{
|
|
|
|
|
|
DataProcessingWithStartB(object1, object2);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, object2);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/****************************************************************************************************
|
|
|
|
|
|
*
|
|
|
|
|
|
*
|
|
|
|
|
|
* 数据处理中心,同步信息中的所有的细节处理均要到此处来处理
|
|
|
|
|
|
*
|
|
|
|
|
|
*
|
|
|
|
|
|
****************************************************************************************************/
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// A指令块,处理系统基础运行的消息
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="object1"></param>
|
|
|
|
|
|
/// <param name="object2"></param>
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void DataProcessingWithStartA(AsyncStateBase object1, string object2)
|
2017-05-05 23:07:44 +08:00
|
|
|
|
{
|
|
|
|
|
|
string headCode = object2.Substring(0, 4);
|
|
|
|
|
|
if (headCode == CommonHeadCode.SimplifyHeadCode.维护检查)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, UserServer.ServerSettings.Can_Account_Login ? "1" : "0" +
|
|
|
|
|
|
UserServer.ServerSettings.Account_Forbidden_Reason);
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.更新检查)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, UserServer.ServerSettings.SystemVersion.ToString());
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.参数下载)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
Newtonsoft.Json.Linq.JObject json = new Newtonsoft.Json.Linq.JObject();
|
|
|
|
|
|
json.Add(nameof(UserServer.ServerSettings.Announcement), new Newtonsoft.Json.Linq.JValue(UserServer.ServerSettings.Announcement));
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, json.ToString());
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.账户检查)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
//此处使用的是组件自带的验证的方式,如果使用SQL数据库,另行验证
|
2017-05-04 11:43:50 +08:00
|
|
|
|
JObject json = JObject.Parse(object2.Substring(4));
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//提取账户,密码
|
|
|
|
|
|
string name = SoftBasic.GetValueFromJsonObject(json, UserAccount.UserNameText, "");
|
2017-03-06 21:10:38 +08:00
|
|
|
|
string password = SoftBasic.GetValueFromJsonObject(json, UserAccount.PasswordText, "");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, UserServer.ServerAccounts.CheckAccountJson(
|
2017-05-18 22:44:07 +08:00
|
|
|
|
name, password, object1.GetRemoteEndPoint().Address.ToString()));
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.更新公告)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
UserServer.ServerSettings.Announcement = object2.Substring(4);
|
|
|
|
|
|
//通知所有客户端更新公告
|
|
|
|
|
|
net_socket_server.SendAllClients(object2);
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, "成功");
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.获取账户信息)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
//返回服务器的账户信息
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, UserServer.ServerAccounts.GetAllAccountsJson());
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.更细账户信息)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
//更新服务器的账户信息
|
|
|
|
|
|
UserServer.ServerAccounts.LoadAllAccountsJson(object2.Substring(4));
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, "成功");
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.密码修改)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-05-18 17:13:42 +08:00
|
|
|
|
//更新服务器的账户密码,此处使用的是组件自带的验证的方式,如果使用SQL数据库,另行验证
|
|
|
|
|
|
JObject json = JObject.Parse(object2.Substring(4));
|
2017-02-22 14:30:10 +08:00
|
|
|
|
//提取账户,密码
|
|
|
|
|
|
string name = SoftBasic.GetValueFromJsonObject(json, UserAccount.UserNameText, "");
|
|
|
|
|
|
string password = SoftBasic.GetValueFromJsonObject(json, UserAccount.PasswordText, "");
|
|
|
|
|
|
UserServer.ServerAccounts.UpdatePassword(name, password);
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, "成功");
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.更新版本号)
|
2017-03-22 19:50:11 +08:00
|
|
|
|
{
|
|
|
|
|
|
try
|
|
|
|
|
|
{
|
|
|
|
|
|
UserServer.ServerSettings.SystemVersion = new SystemVersion(object2.Substring(4));
|
|
|
|
|
|
UserServer.ServerSettings.SaveToFile();
|
2017-03-25 10:25:17 +08:00
|
|
|
|
toolStripStatusLabel_version.Text = UserServer.ServerSettings.SystemVersion.ToString();
|
2017-03-23 08:25:13 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, "1");
|
2017-03-22 19:50:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch
|
|
|
|
|
|
{
|
2017-03-23 08:25:13 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, "0");
|
2017-03-22 19:50:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.注册账号)
|
|
|
|
|
|
{
|
|
|
|
|
|
bool result = UserServer.ServerAccounts.AddNewAccount(object2.Substring(4));
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, result ? "1" : "0");
|
|
|
|
|
|
}
|
|
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.请求文件列表)
|
|
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, net_simple_file_server.ToJsonString());
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, object2);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// B指令块,处理日志相关的消息
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="object1"></param>
|
|
|
|
|
|
/// <param name="object2"></param>
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void DataProcessingWithStartB(AsyncStateBase object1, string object2)
|
2017-05-05 23:07:44 +08:00
|
|
|
|
{
|
|
|
|
|
|
string headCode = object2.Substring(0, 4);
|
|
|
|
|
|
if (headCode == CommonHeadCode.SimplifyHeadCode.网络日志查看)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, net_socket_server.LogHelper.GetLogText());
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveInformation("网络日志查看");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.网络日志清空)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_socket_server.LogHelper.ClearLogText();
|
2017-02-22 14:30:10 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, "成功");
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveWarnning("网络日志清空");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.同步日志查看)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, net_simplify_server.LogHelper.GetLogText());
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveInformation("同步日志查看");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.同步日志清空)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_simplify_server.LogHelper.ClearLogText();
|
2017-02-22 14:30:10 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, "成功");
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveWarnning("同步日志清空");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.更新日志查看)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, net_soft_update_Server.LogHelper.GetLogText());
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveInformation("更新日志查看");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.更新日志清空)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_soft_update_Server.LogHelper.ClearLogText();
|
2017-02-22 14:30:10 +08:00
|
|
|
|
net_simplify_server.SendMessage(object1, "成功");
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveWarnning("更新日志清空");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
2017-05-19 10:20:10 +08:00
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.运行日志查看)
|
|
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, RuntimeLogHelper.GetLogText());
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveInformation("运行日志查看");
|
2017-05-19 10:20:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
else if (headCode == CommonHeadCode.SimplifyHeadCode.运行日志清空)
|
|
|
|
|
|
{
|
|
|
|
|
|
RuntimeLogHelper.ClearLogText();
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, "成功");
|
2017-05-30 14:29:19 +08:00
|
|
|
|
RuntimeLogHelper.SaveInformation("运行日志清空");
|
2017-05-19 10:20:10 +08:00
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
net_simplify_server.SendMessage(object1, object2);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2017-05-05 23:07:44 +08:00
|
|
|
|
|
|
|
|
|
|
|
2017-05-17 22:20:52 +08:00
|
|
|
|
/****************************************************************************************************
|
|
|
|
|
|
*
|
|
|
|
|
|
*
|
|
|
|
|
|
* 您在下面可以自己扩展数据处理的方法,设计原则为运行速度尽可能的快,不要长时间阻塞
|
|
|
|
|
|
*
|
|
|
|
|
|
*
|
|
|
|
|
|
****************************************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-05-05 23:07:44 +08:00
|
|
|
|
|
|
|
|
|
|
|
2017-02-22 14:30:10 +08:00
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
#region 异步数据传送引擎
|
|
|
|
|
|
//异步客户端管理引擎
|
|
|
|
|
|
private Net_Socket_Server net_socket_server = new Net_Socket_Server();
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 异步传送数据的初始化
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private void Net_Socket_Server_Initialization()
|
|
|
|
|
|
{
|
|
|
|
|
|
try
|
|
|
|
|
|
{
|
2017-03-05 18:32:55 +08:00
|
|
|
|
net_socket_server.KeyToken = CommonHeadCode.KeyToken;//设置身份令牌
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_socket_server.LogHelper.LogSaveFileName = Application.StartupPath + @"\net_log.txt";
|
2017-03-16 20:13:46 +08:00
|
|
|
|
net_socket_server.FormatClientOnline = "#IP:{0} Name:{1}";//必须为#开头,具体格式可由自身需求确定
|
2017-02-22 14:30:10 +08:00
|
|
|
|
net_socket_server.IsSaveLogClientLineChange = true;
|
|
|
|
|
|
net_socket_server.ClientOnline += Net_socket_server_ClientOnline;
|
|
|
|
|
|
net_socket_server.ClientOffline += Net_socket_server_ClientOffline;
|
|
|
|
|
|
net_socket_server.MessageAlerts += Net_socket_server_MessageAlerts;
|
|
|
|
|
|
net_socket_server.AcceptByte += Net_socket_server_AcceptByte;
|
|
|
|
|
|
net_socket_server.AcceptString += Net_socket_server_AcceptString;
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_socket_server.ServerStart(CommonLibrary.CommonLibrary.Port_Main_Net);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
|
{
|
2017-05-04 11:43:50 +08:00
|
|
|
|
SoftBasic.ShowExceptionMessage(ex);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void Net_socket_server_AcceptString(AsyncStateOne object1, string object2)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
//如果此处充斥大量if语句,影响观感,则考虑进行指令头分类操作,客户端异步发送的字符串都会到此处处理
|
2017-05-17 22:20:52 +08:00
|
|
|
|
if (object2.StartsWith("H"))
|
|
|
|
|
|
{
|
|
|
|
|
|
//H类系统指令
|
|
|
|
|
|
DataProcessingWithStartH(object1, object2);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
2017-03-06 21:10:38 +08:00
|
|
|
|
|
2017-05-17 22:20:52 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// H开头的处理块
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="object1"></param>
|
|
|
|
|
|
/// <param name="headcode">指令头</param>
|
|
|
|
|
|
/// <param name="object2"></param>
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void DataProcessingWithStartH(AsyncStateOne object1, string object2)
|
2017-05-17 22:20:52 +08:00
|
|
|
|
{
|
|
|
|
|
|
string headCode = object2.Substring(0, 4);
|
|
|
|
|
|
if (headCode == CommonHeadCode.MultiNetHeadCode.留言消息)
|
|
|
|
|
|
{
|
2017-05-18 22:44:07 +08:00
|
|
|
|
string content = headCode + object1.LoginAlias + DateTime.Now.ToString(" yyyy-MM-dd HH:mm:ss") + Environment.NewLine + object2.Substring(4);
|
2017-05-18 17:13:42 +08:00
|
|
|
|
//转发所有的客户端,包括发送者
|
|
|
|
|
|
net_socket_server.SendAllClients(content);
|
2017-05-17 22:20:52 +08:00
|
|
|
|
}
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2017-05-17 22:20:52 +08:00
|
|
|
|
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void Net_socket_server_AcceptByte(AsyncStateOne object1, byte[] object2)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
//如果此处充斥大量if语句,影响观感,则考虑进行指令头分类操作,客户端异步发送的字节数组都会到此处处理
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void Net_socket_server_MessageAlerts(string object1)
|
|
|
|
|
|
{
|
|
|
|
|
|
//同上的方法,此处处理数据时处于后台线程
|
|
|
|
|
|
if (IsWindowShow && IsHandleCreated)
|
|
|
|
|
|
{
|
|
|
|
|
|
BeginInvoke(new Action(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
textBox1.AppendText(object1 + Environment.NewLine);
|
|
|
|
|
|
}));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void Net_socket_server_ClientOffline(AsyncStateOne object1, string object2)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
|
|
|
|
|
Net_socket_clients_change(DateTime.Now.ToString("MM-dd HH:mm:ss ") + object1._IpEnd_Point.Address.ToString() + ":" +
|
2017-05-18 22:44:07 +08:00
|
|
|
|
object1.LoginAlias + " " + object2);
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2017-05-18 22:44:07 +08:00
|
|
|
|
private void Net_socket_server_ClientOnline(AsyncStateOne object1)
|
2017-02-22 14:30:10 +08:00
|
|
|
|
{
|
2017-04-06 16:18:46 +08:00
|
|
|
|
//上线后回发一条数据初始化信息
|
|
|
|
|
|
JObject json = new JObject
|
|
|
|
|
|
{
|
|
|
|
|
|
{ "Time", new JValue(DateTime.Now) },
|
|
|
|
|
|
{ "FileCount", new JValue(net_simple_file_server.File_Count()) }
|
|
|
|
|
|
};
|
|
|
|
|
|
net_socket_server.Send(object1, CommonHeadCode.MultiNetHeadCode.初始化数据 + json.ToString());
|
2017-03-06 21:10:38 +08:00
|
|
|
|
//触发上下线功能
|
2017-02-22 14:30:10 +08:00
|
|
|
|
Net_socket_clients_change(DateTime.Now.ToString("MM-dd HH:mm:ss ") + object1._IpEnd_Point.Address.ToString() + ":" +
|
2017-05-18 22:44:07 +08:00
|
|
|
|
object1.LoginAlias + " 上线");
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void Net_socket_clients_change(string str)
|
|
|
|
|
|
{
|
|
|
|
|
|
if (IsWindowShow && IsHandleCreated)
|
|
|
|
|
|
{
|
|
|
|
|
|
BeginInvoke(new Action(() =>
|
|
|
|
|
|
{
|
|
|
|
|
|
textBox1.AppendText(str + Environment.NewLine);
|
|
|
|
|
|
listBox1.DataSource = net_socket_server.AllClients.Split('#');
|
|
|
|
|
|
label4.Text = net_socket_server.ClientCount.ToString();
|
|
|
|
|
|
//此处决定要不要将在线客户端的数据发送所有客户端
|
|
|
|
|
|
net_socket_server.SendAllClients(CommonHeadCode.MultiNetHeadCode.所有客户端在线信息 + net_socket_server.AllClients);
|
|
|
|
|
|
}));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
2017-03-06 21:10:38 +08:00
|
|
|
|
#region 后台计数线程
|
|
|
|
|
|
//=============================================================================
|
|
|
|
|
|
//后台计数的线程
|
|
|
|
|
|
|
|
|
|
|
|
public void TimeTickInitilization()
|
|
|
|
|
|
{
|
|
|
|
|
|
toolStripStatusLabel_time.Alignment = ToolStripItemAlignment.Right;
|
|
|
|
|
|
statusStrip1.LayoutStyle = ToolStripLayoutStyle.StackWithOverflow;
|
|
|
|
|
|
toolStripStatusLabel_time.ForeColor = Color.Purple;//紫色
|
|
|
|
|
|
|
|
|
|
|
|
Thread thread = new Thread(new ThreadStart(ThreadTimeTick));
|
|
|
|
|
|
thread.IsBackground = true;
|
|
|
|
|
|
thread.Start();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void ThreadTimeTick()
|
|
|
|
|
|
{
|
|
|
|
|
|
Thread.Sleep(300);//加一个微小的延时
|
|
|
|
|
|
int second = DateTime.Now.Second - 1;
|
|
|
|
|
|
Action DTimeShow = delegate
|
|
|
|
|
|
{
|
|
|
|
|
|
toolStripStatusLabel_time.Text = DateTime.Now.ToString();
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
while (IsWindowShow)
|
|
|
|
|
|
{
|
|
|
|
|
|
while (DateTime.Now.Second == second)
|
|
|
|
|
|
{
|
|
|
|
|
|
Thread.Sleep(20);
|
|
|
|
|
|
}
|
|
|
|
|
|
second = DateTime.Now.Second;
|
|
|
|
|
|
if (IsWindowShow && IsHandleCreated) Invoke(DTimeShow);
|
|
|
|
|
|
//每隔一分钟将时间发送给所有客户端,格式为标准时间
|
|
|
|
|
|
if (second == 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
net_socket_server.SendAllClients(CommonHeadCode.MultiNetHeadCode.时间推送 +
|
|
|
|
|
|
DateTime.Now.ToString("O"));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
2017-04-06 16:18:46 +08:00
|
|
|
|
#region 共享文件下载块
|
|
|
|
|
|
|
|
|
|
|
|
private SimpleShareFileServer net_simple_file_server { get; set; } = null;
|
|
|
|
|
|
|
|
|
|
|
|
private void Simple_File_Initiaization()
|
|
|
|
|
|
{
|
|
|
|
|
|
try
|
|
|
|
|
|
{
|
2017-05-20 09:04:12 +08:00
|
|
|
|
net_simple_file_server = new SimpleShareFileServer()
|
|
|
|
|
|
{
|
|
|
|
|
|
//文件信息存储路径
|
|
|
|
|
|
FileSavePath = Application.StartupPath + @"\files.txt"
|
|
|
|
|
|
};
|
2017-04-07 09:08:48 +08:00
|
|
|
|
net_simple_file_server.ReadFromFile();
|
2017-04-06 16:18:46 +08:00
|
|
|
|
//文件存储路径
|
|
|
|
|
|
net_simple_file_server.File_save_path = Application.StartupPath + @"\Files";
|
|
|
|
|
|
net_simple_file_server.FileChange += Net_simple_file_server_FileChange;
|
2017-04-23 18:05:12 +08:00
|
|
|
|
net_simple_file_server.ServerStart(CommonLibrary.CommonLibrary.Port_Share_File);
|
2017-04-06 16:18:46 +08:00
|
|
|
|
}
|
|
|
|
|
|
catch(Exception ex)
|
|
|
|
|
|
{
|
|
|
|
|
|
SoftBasic.ShowExceptionMessage(ex);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void Net_simple_file_server_FileChange()
|
|
|
|
|
|
{
|
|
|
|
|
|
//将文件数据发送给客户端
|
|
|
|
|
|
net_socket_server.SendAllClients(CommonHeadCode.MultiNetHeadCode.文件数量 + net_simple_file_server.File_Count());
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-05-19 18:28:04 +08:00
|
|
|
|
#region 访问PLC块示例代码
|
2017-05-18 18:32:45 +08:00
|
|
|
|
|
|
|
|
|
|
/*************************************************************************************************
|
|
|
|
|
|
*
|
|
|
|
|
|
* 以下展示一个高性能访问多台PLC数据的类,即使同时访问100台设备,性能也是非常高
|
|
|
|
|
|
*
|
|
|
|
|
|
* 该类没有仔细的在现场环境测试过,不保证完全可用
|
|
|
|
|
|
*
|
|
|
|
|
|
*************************************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
HslCommunication.Profinet.MelsecNetMultiAsync MelsecMulti { get; set; }
|
|
|
|
|
|
|
|
|
|
|
|
private void MelsecNetMultiInnitialization()
|
|
|
|
|
|
{
|
2017-05-22 21:08:37 +08:00
|
|
|
|
List<System.Net.IPAddress> IpEndPoints = new List<System.Net.IPAddress>();
|
2017-05-18 18:32:45 +08:00
|
|
|
|
//增加100台需要访问的三菱设备,指定所有设备IP和端口,注意:顺序很重要
|
|
|
|
|
|
for (int i = 1; i < 100; i++)
|
|
|
|
|
|
{
|
2017-05-22 21:08:37 +08:00
|
|
|
|
IpEndPoints.Add(System.Net.IPAddress.Parse("192.168.10." + i));
|
2017-05-18 18:32:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2017-05-28 22:29:29 +08:00
|
|
|
|
//每隔1秒钟访问一次,读取的地址为D6000-D6019,超时时间为700毫秒,主端口为6000,备用端口为6001
|
2017-05-22 21:08:37 +08:00
|
|
|
|
MelsecMulti = new HslCommunication.Profinet.MelsecNetMultiAsync(0, 0, HslCommunication.Profinet.MelsecDataType.D, 6000, 20, 700, 1000, IpEndPoints.ToArray(), 6000, 6001);
|
2017-05-19 10:20:10 +08:00
|
|
|
|
MelsecMulti.OnReceivedData += MelsecMulti_OnReceivedData;//所有机台的数据都返回时触发
|
2017-05-18 18:32:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void MelsecMulti_OnReceivedData(byte[] object1)
|
|
|
|
|
|
{
|
|
|
|
|
|
/*********************************************************************************************
|
|
|
|
|
|
*
|
|
|
|
|
|
* 正常情况下,一秒触发一次,object1包含了所有机台读取到的数据
|
|
|
|
|
|
* 比如每台设备读取D6000开始20个D,如上述指令所示
|
|
|
|
|
|
* 那么每台设备数据长度为20*2+2=42个byte,100台设备就是4200字节长度
|
|
|
|
|
|
* 也就是说,object1的0-41字节是第一台设备的,以此类推
|
|
|
|
|
|
* 每台设备的前两个字节都为0才说明本次数据访问正常,为0x00,0x01说明连接失败,其他说明说明三菱本身的异常
|
|
|
|
|
|
*
|
|
|
|
|
|
********************************************************************************************/
|
2017-05-19 10:20:10 +08:00
|
|
|
|
for (int i = 0; i < 100; i++)
|
|
|
|
|
|
{
|
|
|
|
|
|
int startIndex = i * 42;
|
|
|
|
|
|
ushort netState = BitConverter.ToUInt16(object1, startIndex);//为0,说明数据正常,不为0说明网络访问失败或是指令出错
|
2017-05-18 18:32:45 +08:00
|
|
|
|
|
2017-05-19 10:20:10 +08:00
|
|
|
|
|
|
|
|
|
|
}
|
2017-05-18 18:32:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
2017-05-19 18:28:04 +08:00
|
|
|
|
#region 流水号生成示例代码
|
2017-05-18 18:32:45 +08:00
|
|
|
|
|
2017-05-19 18:28:04 +08:00
|
|
|
|
private SoftNumericalOrder OrderAutoCreate { get; set; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 流水号初始化方法,如果需要可以放到窗口的load方法中
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private void OrderInitialization()
|
|
|
|
|
|
{
|
|
|
|
|
|
/*********************************************************************************************************
|
|
|
|
|
|
*
|
|
|
|
|
|
* 说明 此处的时间格式是年月日,7是指跟在时间后面的序号的位数,不够补零
|
|
|
|
|
|
* 示例1 调用 string str = OrderAutoCreate.GetNumericalOrder();//str为 AB201705190000001
|
|
|
|
|
|
* 示例2 调用 string str = OrderAutoCreate.GetNumericalOrder("KN");//str为 KN201705190000002
|
|
|
|
|
|
* 注意 默认计数不清空,后面的1,2会一值累加,可以调用900亿亿次,如果需要定期清空,请自行周期调用OrderAutoCreate.ClearNumericalOrder();
|
|
|
|
|
|
* 提示 如果需要定期清空,在本页面的ThreadTimeTick()方法中清空即可
|
|
|
|
|
|
* 性能 一秒钟可以响应请求100万次,并成功存储当前计数值
|
|
|
|
|
|
*
|
|
|
|
|
|
**********************************************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
OrderAutoCreate = new SoftNumericalOrder("AB", "yyyyMMdd", 7, Application.StartupPath + @"\order.txt");
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endregion
|
2017-05-18 18:32:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
2017-05-30 14:29:19 +08:00
|
|
|
|
/*********************************************************************************************************
|
|
|
|
|
|
*
|
|
|
|
|
|
* 说明 日志的使用方式分为4个等级,1.普通 2.信息 3.警告 4.错误 对应的调用方法不一致
|
|
|
|
|
|
* 具体 如果想要调用存储[信息]等级日志,调用 RuntimeLogHelper.SaveInformation("等待存储的信息")
|
|
|
|
|
|
* 大小 调用10000次存储信息后,日志文件大小在200K左右,需要手动进行情况日志
|
|
|
|
|
|
* 注意 在存储信息时不要带有'['和']'这两个字符,会影响日志筛选时的准确性
|
|
|
|
|
|
*
|
|
|
|
|
|
**********************************************************************************************************/
|
2017-05-18 18:32:45 +08:00
|
|
|
|
|
2017-03-22 19:50:11 +08:00
|
|
|
|
/// <summary>
|
2017-05-05 23:07:44 +08:00
|
|
|
|
/// 用来记录一般的事物日志
|
2017-03-22 19:50:11 +08:00
|
|
|
|
/// </summary>
|
2017-05-19 10:20:10 +08:00
|
|
|
|
private SoftLogHelper RuntimeLogHelper { get; set; }
|
2017-02-22 14:30:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|