零基础实现IEC61850(一)启动服务端

零基础实现IEC61850(一)启动服务端

不要重复造轮子

我们是要造一部豪车,但是我们不需要造轮子,开发IEC61850产品也是如此。所谓实现IEC61850并不是要开发IEC61850本身,而是要开发的智能产品具备IEC61850的功能,所以实现IEC61850只需要找到合适的轮子即可,本文以国产的YX-PIS协议栈为轮子,从零开始手把手指导如何实现IEC61850的功能。

如何拿到轮子

云行科技分享了一些工具在gitee上,地址如下:
https://gitee.com/yunxingtianxia/yx-tools
其中yx-pis-dll目录下分享了yx-pis产品的cms版和mms版的动态库文件,目前分享了windows 64位版本
在这里我们可以免费获得cms和mms版本的头文件,lib文件和dll文件。

开始让轮子转一转

新建工程

这里将采用VS2022进行讲解,由于是cmake工程,使用其他IDE也可以正常使用。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
本例采用纯c代码开发,所以要做一下更名,直接修改iec61850server.cpp文件名为iec61850server.c,CMakeList.txt文件中应该会自动同步。
在这里插入图片描述
删除iec61850server.c中的C++代码

using namespace std; 
cout << "Hello CMake." << endl;

删除iec61850server.h中的C++代码

#include <iostream>

编译一下,不报错就可以了,接下来我们开始IEC61850服务端的开发

首先添加头文件目录

在CMakeList.txt中增加

include_directories("yx-pis-dll/mms/include")

如果要开发CMS版本就用下面这句

include_directories("yx-pis-dll/cms/include")

添加lib库目录

link_directories(${CMAKE_SOURCE_DIR}/yx-pis-dll/mms)

同理,cms是如下:

link_directories(${CMAKE_SOURCE_DIR}/yx-pis-dll/cms)

链接动态库

target_link_libraries(iec61850server mms-ctk)

同理,cms是如下:

target_link_libraries(iec61850server cms-ctk)

精简CMakeList

最终效果如图:
在这里插入图片描述

开始代码

添加引用

添加YX-PIS提供的三个头文件

#include "IEC61850Types.h"
#include "IEC61850API.h"
#include "sysctype.h"
创建IEC61850对象

定义全局变量

IEC61850 g_iec61850;

使用YX-PIS提供的API接口IEC61850_Create创建,在IEC61850API.h中介绍了IEC61850_Create并提供了例程,我们参考后在main函数中添加如下代码

	IEC61850_ErrorCode error = S_OK;
	IEC61850_Parameters	param = { 0 }; // 参数结构体

	param.clientServerFlag = IEC61850_SERVER;		// 设置为服务端
	param.Ed1_Ed2_Flag = IEC61850_Edition2; 	// 设置为IEC61850第二版

	// 创建IEC61850对象
	g_iec61850 = IEC61850_Create(&param, &error);

	if (g_iec61850) {
		printf("Server success to create: %s (%u)\n", IEC61850_ErrorString(error), error);
	}

我们编译运行一下,如果打印了Server成功创建,证明对象的创建成功。
如果提示下图:
在这里插入图片描述
请将dll文件拷贝到编译的可执行文件目录

加载CID

准备CID

如果已经有CID文件,可以直接使用,如果没有可以手工创建一个,这里推荐使用建模工具创建
安装yx-tools下提供的yx-ied-designer
启动yx-ied-designer,直接新建,然后按照图片设置本机IP即可
在这里插入图片描述
将文件保存到可执行文件所在目录
在这里插入图片描述

加载CID

//加载CID模型
error = IEC61850_LoadSCLFile(g_iec61850, "testIED.cid");

if (error == S_OK) {
	printf("Server success to load cid file\n");
}

启动服务

	//启动服务
	if (error == S_OK) {
		error = IEC61850_Start(g_iec61850);
		if (error != S_OK) {
			printf("   Can't start server: %s (%i)\n", IEC61850_ErrorString(error), error);
		} else {
			printf("Server success to start\n");
		}
	}

启动后要让程序停下来,不然程序就会退出了,简单点增加一个getchar(),等待任意字符

服务的停止和释放

	printf("Stopping IEC61850 Server \n");
	error = IEC61850_Stop(g_iec61850);
	if (error != S_OK) {
		printf("   Can't stop server: %s (%i)\n", IEC61850_ErrorString(error), error);
	} else {
		printf("Freeing IEC61850 Server \n");
		error = IEC61850_Free(g_iec61850);  //Frees s_iec61850

		if (error == S_OK) {
			g_iec61850 = NULL;
		} else {
			printf("   Free IEC61850 Object has failed: %s (%i)\n", IEC61850_ErrorString(error), error);
		}
	}

看看运行效果

注意:在这之前需要安装winpcap4.1.3,或者安装wireshark抓包工具,会提示安装npcap或者winpcap
运行后如下图:
在这里插入图片描述
看到这样的效果就是启动成功了,对于mms版本可以使用iedscout尝试连接看看

在这里插入图片描述
可以正常访问并且获得模型
在这里插入图片描述
对于CMS版本的验证可以安装
yx-tools下提供的cms-test-tool,为绿色软件,直接运行IEC61850_GSP_Client_Test_Tool.exe即可
在这里插入图片描述
在这里插入图片描述
好了,今天的服务端启动工作就完成了,为了简单,本例子的全部代码都放在iec61850server.c中,全部内容如下:

#include "iec61850server.h"
#include "IEC61850Types.h"
#include "IEC61850API.h"
#include "sysctype.h"

IEC61850 g_iec61850;

int main()
{
	IEC61850_ErrorCode error = S_OK;
	IEC61850_Parameters	param = { 0 }; // 参数结构体

	param.clientServerFlag = IEC61850_SERVER;		// 设置为服务端
	param.Ed1_Ed2_Flag = IEC61850_Edition2; 	// 设置为IEC61850第二版

	// 创建IEC61850对象
	g_iec61850 = IEC61850_Create(&param, &error);

	if (g_iec61850) {
		printf("Server success to create: %s (%u)\n", IEC61850_ErrorString(error), error);
		//加载CID模型
		error = IEC61850_LoadSCLFile(g_iec61850, "testIED.cid");

		if (error == S_OK) {
			printf("Server success to load cid file\n");
		}
	}

	//启动服务
	if (error == S_OK) {
		error = IEC61850_Start(g_iec61850);
		if (error != S_OK) {
			printf("   Can't start server: %s (%i)\n", IEC61850_ErrorString(error), error);
		} else {
			printf("Server success to start\n");
		}

	}
	// 利用获取字符暂停
	getchar();

	//停止服务
	printf("Stopping IEC61850 Server \n");
	error = IEC61850_Stop(g_iec61850);
	if (error != S_OK) {
		printf("   Can't stop server: %s (%i)\n", IEC61850_ErrorString(error), error);
	} else {
		// 释放内存
		printf("Freeing IEC61850 Server \n");
		error = IEC61850_Free(g_iec61850);  //Frees s_iec61850

		if (error == S_OK) {
			g_iec61850 = NULL;
		} else {
			printf("   Free IEC61850 Object has failed: %s (%i)\n", IEC61850_ErrorString(error), error);
		}
	}
	return 0;
}

有任何疑问,欢迎访问 https://yunxing.tech/ 联系大连云行科技有限责任公司

非常感谢您的提问! 当使用IEC61850_IEC61850进行开发时,可以同时开发服务端和客户端应用程序。服务端应用程序负责提供数据给客户端,而客户端应用程序则负责请求并读取服务端提供的数据。 以下是一个简单的示例代码,演示如何使用IEC61850_IEC61850 API同时开发服务端和客户端应用程序: 服务端代码: ```java import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import ch.iec._61850._3._1.mms.server.MmsServer; import ch.iec._61850._3._1.mms.server.MmsServerHandler; public class IEC61850ServerExample { public static void main(String[] args) throws IOException { // 创建MmsServer对象并启动服务端 MmsServer server = new MmsServer(); server.start(); // 创建ServerSocket对象并监听客户端连接请求 ServerSocket socket = new ServerSocket(8080); ExecutorService executor = Executors.newFixedThreadPool(10); while (true) { Socket client = socket.accept(); executor.submit(new ClientHandler(server, client)); } } private static class ClientHandler implements Runnable { private final MmsServer server; private final Socket client; public ClientHandler(MmsServer server, Socket client) { this.server = server; this.client = client; } @Override public void run() { try { // 创建MmsServerHandler对象并处理客户端请求 MmsServerHandler handler = new MmsServerHandler(server); handler.handle(client.getInputStream(), client.getOutputStream()); client.close(); } catch (IOException e) { e.printStackTrace(); } } } } ``` 客户端代码: ```java import java.io.IOException; import java.net.Socket; import ch.iec._61850._3._1.mms.client.MmsConnection; import ch.iec._61850._3._1.mms.DataAttribute; import ch.iec._61850._3._1.mms.MmsValue; public class IEC61850ClientExample { public static void main(String[] args) throws IOException { // 创建Socket对象并连接到服务端 Socket socket = new Socket("localhost", 8080); // 创建MmsConnection对象并连接到服务端 MmsConnection connection = new MmsConnection(socket); // 读取服务端的某个数据属性 DataAttribute attribute = new DataAttribute("Device1/LLN0/DO1"); MmsValue value = connection.read(attribute); // 输出数据值 System.out.println("Value: " + value.getValue()); // 关闭连接 connection.close(); socket.close(); } } ``` 希望这个示例代码能够帮助您了解如何使用IEC61850_IEC61850进行服务端和客户端应用程序开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值