tcp/ip网络通讯安全加密方法[通俗易懂]

tcp/ip网络通讯安全加密方法[通俗易懂]tcp/ip网络通讯安全是一个广受关注的话题,现在也有一些基于tcp/ip加密技术标准如SSL,TLS等。但很多时候编写一些简单的网络通讯把这标准加密应用添加进来乎一下子把程序变得复杂了,而实现自己的加密算法那就更加不可取;其实通过一些现有的加密的技术应用完全可以实现即简单又安全的网络通讯程序。首先保证网络通讯安全有两个方面,第一保证连接的有效性,其二就…

大家好,又见面了,我是你们的朋友全栈君。

tcp/ip网络通讯安全是一个广受关注的话题,现在也有一些基于tcp/ip加密技术标准如SSL,TLS等。但很多时候编写一些简单的网络通讯把这标准加密应用添加进来乎一下子把程序变得复杂了,而实现自己的加密算法那就更加不可取;其实通过一些现有的加密的技术应用完全可以实现即简单又安全的网络通讯程序。首先保证网络通讯安全有两个方面,第一保证连接的有效性,其二就是保证内容即使被人拦截也难以从内容得到相关信息。

连接有效性

平常写网络程序在允许一个连接接入操作的时候,我们一般要对它进行一个有效性验证,如提供用户名密码或签名。

签名:

通过用户提供一分数据和数据相关签名信息,对方进行一个有效性验证。那这个数据和签名数据怎么做呢,其实现有加密技术中已经有一种描述提供了这种解决方案那就是RSA(非对称加密)。可以通过 RSA 的持有privatekey和publickey方进行一个数据签名,对方通过publickey进行一个验证.如果publickey和privatekey是配对的情况,那持有publickey就能验证成功,否则就会验证失败。在连接进行操作前可以通过这种方式进行处理,签名有效允许连接操作,无效的话可以直接把连接关闭。

下面介绍通过c#如何实现这种签名:

1
2
3
4
5
6
RasCrypto pri =
new 
RasCrypto();
RasCrypto pub =
new 
RasCrypto();
pub.PublicKey = pri.PublicKey;
string 
name =
"henry"
;
string 
singdata = pri.Sign(name);
Console.WriteLine(pub.Verify(name, singdata));

RasCrypto是通过封装的类,源代码可以通过https://smarkdata.svn.codeplex.com/svn/Smark/Smark.Core/Smark.Core/RasCrypto.cs获取;在实际使用中最好是根据不同签名有不同的密对,这样即使某签名的密对被盗也不会影响其他用户的安全。

用户名密码:

基于用户名和密码验证是一种很常见的方式,但有个问题就是如何保证用户名和密码在通讯过程即使被截取了也难以得到用户名和密码呢?其实通过 RSA 也能够很好地解决这一问题。 RSA 提供public key加密而private key解密的方式,可以把public key提供给请求方就行了,private key保存在服务端;这样就可以保证加密的东西只有服务端才有解密,即使加密信息被其他人拦截也难以获取原有信息。

下面介绍通过c#使用ras进行加解密

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
RasCrypto server =
new 
RasCrypto();
RasCrypto client =
new 
RasCrypto();
client.PublicKey = server.PublicKey;
string 
name =
"henry"
;
string 
pwd =
"123456"
;
string 
ename = client.Encrypt(name);
string 
epwd = client.Encrypt(pwd);
string 
dname = server.Decrypt(ename);
string 
dpwd = server.Decrypt(epwd);
Console.WriteLine(
"name:{0}"
, name);
Console.WriteLine(
"pwd:{0}"
, pwd);
Console.WriteLine(
"-----------------------------------------------------------"
);
Console.WriteLine(
"ename:{0}"
, ename);
Console.WriteLine(
"epwd:{0}"
, epwd);
Console.WriteLine(
"-----------------------------------------------------------"
);
Console.WriteLine(
"dname:{0}"
, dname);
Console.WriteLine(
"dpwd:{0}"
, dpwd);
Console.WriteLine(
"-----------------------------------------------------------"
);

 

tcp/ip网络通讯安全加密方法[通俗易懂]

为了应用更安全,针对不同的连接生成不同的RSA密对,这样就能保证每个连接的各自安全性.

信息加密

前面提到的 RSA 可以进行数据加解密,其安全性也非常可靠;但有个缺点就是RSA对数据比多的时候加密比较慢,有些 RSA 加密的实现还有数据长度的限制。所以在很多情况下就要选择别的加密方式,这里介绍DES(对称加密)。不过对称加密有个缺点就是密对双方都必须一样,这样就会导致一个问题就从某一方获取密对就能对数据加密和解密工作。所以对称加的密对保护就显示非常重要的,这个工作可以交给 RSA 来做。

以下是c#运用 RSA +DES的加解密方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
RasCrypto server =
new 
RasCrypto();
 
RasCrypto client =
new 
RasCrypto();
 
client.PublicKey = server.PublicKey;
 
DESCrypto serverdes =
new 
DESCrypto();
 
DESCrypto clientdes =
new 
DESCrypto();
 
//获取没加密的key,iv
 
DESCrypto.DESInfo info = clientdes.KeyInfo;
 
Console.WriteLine(
"KEY: "
+Smark.Core.Functions.ToString(info.Key));
 
Console.WriteLine(
"IV: "
+Smark.Core.Functions.ToString(info.IV));
 
Console.WriteLine(
""
);
 
//设置相应的RSA信息
 
serverdes.PrivateRas = server;
 
clientdes.PublicRas = client;
 
//获取了设置RSA信息的key,iv
 
info = clientdes.KeyInfo;
 
Console.WriteLine(
"KEY: " 
+ Smark.Core.Functions.ToString(info.Key));
 
Console.WriteLine(
"IV: " 
+ Smark.Core.Functions.ToString(info.IV));
 
//数据加密
 
serverdes.KeyInfo = info;
 
string 
value =
"henryfan@msn.com"
, evalue =
null
, dvalue =
null
;
 
evalue = serverdes.Encrypt(value);
 
dvalue = clientdes.Decrypt(evalue);
 
Console.WriteLine(
"VALUE: " 
+ value);
 
Console.WriteLine(
"EVALUE: " 
+ evalue);
 
Console.WriteLine(
"DVALUE: " 
+ dvalue);
 
Console.WriteLine(
""
);
 
evalue = clientdes.Encrypt(value);
 
dvalue = serverdes.Decrypt(evalue);
 
Console.WriteLine(
"VALUE: " 
+ value);
 
Console.WriteLine(
"EVALUE: " 
+ evalue);
 
Console.WriteLine(
"DVALUE: " 
+ dvalue);
 
Console.WriteLine(
""
);
 
Console.Read();

tcp/ip网络通讯安全加密方法[通俗易懂]

    通过RSA和DES就能够简单地实现可靠的网络通讯安全,不过有些朋友喜欢构建自己的加密方法,在这里并不见意这样做;因为自己构建的加密方法的可靠性并没有得到验证,并不像现有的加密方法经过长时候实践和大量的应用总结出来。

相关资料:

DES http://zh.wikipedia.org/wiki/%E8%B3%87%E6%96%99%E5%8A%A0%E5%AF%86%E6%A8%99%E6%BA%96 

RSA http://zh.wikipedia.org/wiki/RSA%E5%8A%A0%E5%AF%86%E6%BC%94%E7%AE%97%E6%B3%95

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/144062.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • SQL Server 2008 还原数据库

    SQL Server 2008 还原数据库

  • goland 2021.5.1.1 激活码[在线序列号]

    goland 2021.5.1.1 激活码[在线序列号],https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • Java数组

    Java数组12.Java数组一、什么是数组数组可以理解成一个包含相同类型的有序数字集合也称储存一组数据的空间数组属于引用数据类型int[]a={1,2,3,4,5};集合内的数据称为元素

  • python文件句柄_Python 文件操作学习 就是这么简单!-文件句柄

    python文件句柄_Python 文件操作学习 就是这么简单!-文件句柄一、前言Python对文件的操作是相当简单的。二、文件操作函数的介绍Python通过open函数来打开文件,语法如下open(file,mode=‘r’,buffering=None,encoding=None,errors=None,newline=None,closefd=True)可以看到,除了第一个file参数是必须的,其它都是可选的。1、file:操作的文件2、mode:操…

    2022年10月18日
  • Java基础之序列化对象Serialized

    Java基础之序列化对象Serialized文章目录序列化对象Serialized目的:序列化类型应用场景代码案例直接应用自定义对象序列化序列化对象Serialized目的:序列化机制允许将实现序列化的Java对象转换成字节序列,这些字节序列可以被保存在磁盘上,或者通过网络传输,以备以后重新恢复成原来的对象.序列化类型对象的序列化(serialize)指将一个Java对象写入IO流中对象的反序列化机制(Deserialize)则指从IO流中恢复该Java对象.应用场景当你想把的内存中的对象保存到一个文件中或者数据库中时候;

  • 开源商城系统带app源码_萌果APP源码

    开源商城系统带app源码_萌果APP源码直接下载导入工程即可直接运行.包含服务器源码(服务器已经在线配置)主要功能如下:首页:从上到下分别是:广告轮播、菜单按钮、品牌推介、推介、热销商品分类:类似京东商品三级分类,左边是一级分类,右边是二级分类,二级分类下面包含三级子分类商城功能:商品详情、购物车、确认订单、支付功能商品详情:商品大图轮播、商品规格(选择不同规格显示不同价格,

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号