PLM之家PLMHome-国产软件践行者

MD5加密方法介绍

[复制链接]

2018-12-5 10:28:35 2136 0

Araser 发表于 2018-12-5 10:28:35 |阅读模式

Araser 楼主

2018-12-5 10:28:35

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x
MD5算法简单的来说就是把任意长度的字串变换成固定长度(通常是128位)的16进制串。RFC 1321定义了MD5算法。
1 ?/ x; J5 y7 m1 JMD5的用途主要有:6 f0 q4 V% P" ?5 E
一致性验证。比如我们从网上下载了某个文件,网站上一般会给出该文件的MD5值,我们下载下来后,可以利用工具计算出$ Q0 T, R. e3 _
新的MD5值,与正确的MD5值进行对照,如果不一样,则可以断定该文件下载出错或被篡改了。
0 t! G2 S8 T) b6 U, B# |数字签名。可以用MD5算法对发布的程序或发布的消息生成MD5值作为签名等。
# h( `6 s* t; I5 X+ c% |密码存储。在传输过程中或存储过程中,直接用明文的密码都是很危险的。可以在传输之前先用MD5加密,存储也不用存储. u8 D+ Y. m4 H0 I  k
明文,可以直接存储MD5值。在验证时,先把输入的密码转换成MD5值再与存储值进行对比。
对于密码存储,Asp.net的实现方法为:

+ m# |2 N9 @' T+ Y- s5 A6 C
[mw_shl_code=csharp,true]protected void Page_Load(object sender, EventArgs e)' _4 n$ q- R9 z  X
        {, @3 P* W3 Q) H, {, V& H5 M
            string plainPassword = "innovator";
3 ^: v4 M, _, u6 ~& Q5 M
: Z, w  A( O. F8 l2 o' H            System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();3 b6 k) W0 G: A7 P* N& H6 w
            System.Text.ASCIIEncoding ascii = new System.Text.ASCIIEncoding();( }6 N! l" Z* D8 X+ T9 z
            byte[] data = ascii.GetBytes(plainPassword);& L3 z2 G% N/ R2 ~# j
            byte[] result = md5.ComputeHash(data);; K4 t3 o2 y" a2 Z
            // Convert the MD5 result to Hexadecimal string
( [. E: U& q, R5 M! F, j. t' y2 R  J$ m  m0 t
            string MD5Password = BinaryToHex(result);
# A; P7 M5 n$ Y0 i# [% J0 v: L            string aa = "";" V# C. v+ B( }2 I2 H
        }[/mw_shl_code]

! k  n2 d* r& v! @! }$ F( I
[mw_shl_code=csharp,true]private String BinaryToHex(byte[] BinaryArray)
+ |9 o* ~, D7 ~* A  I2 W" J2 \& {* U        {
) y4 A" s" Q4 @3 [8 A3 h            string result = "";- d5 }" G& y: @# p4 T  `( _
            long lowerByte;
, e5 e- P& p  T3 e# f3 }1 Z* V  F            long upperByte;
7 L+ [0 o7 l- e# m
( }1 L8 V# n4 c& y: U0 ?2 B            foreach (Byte singleByte in BinaryArray)
# H% S3 q. Q4 `% I            {
: G5 ?, l7 H  H% m# ^- E                lowerByte = singleByte & 15;& K' [9 ]) l) j* _& R* W
                upperByte = singleByte >> 4;, y. C1 b, b$ r
8 w  k  Q: w/ w$ l5 k7 C
                result += NumberToHex(upperByte);
' g  P: x& K/ W) l" v8 y+ Z                result += NumberToHex(lowerByte);, a% I( e: }5 T0 n( T
            }: F1 Q, }! ~6 O/ u2 F9 Q
            return result;
6 g: X, h  T% H+ {1 v        }[/mw_shl_code]

1 j5 a8 G6 J; Y7 ^
[mw_shl_code=csharp,true]private static char NumberToHex(long Number)
. u9 w# c) O' s        {" g; u: h1 c# m: p6 u0 O6 P
            if (Number > 9)) A# [5 u" m, w2 C
                return Convert.ToChar(65 + (Number - 10));( ]4 r! B% }; |4 s( p
            else
+ e1 ]9 J% [* A+ H# F                return Convert.ToChar(48 + Number);
: @3 [8 M$ y: B        }[/mw_shl_code]
( q) D% L% y( s
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了