SecurityLibrary
using System;
using System.IO;
using System.Linq;
using System.Security.Cryptography;
using System.Text; namespace Miraclesoft.SecurityLibrary
{
/// <summary>
/// 使用加密服务提供程序 (CSP) 版本的数据加密标准 (System.Security.Cryptography.DES) 算法
/// </summary>
public static class DESCryp
{
#region 加密 /// <summary>
/// 使用默认密码(MiracleSoft)加密字符串
/// </summary>
/// <param name="str">明文字符串</param>
/// <returns>密文字符串</returns>
public static string Encrypt(string str) => Encrypt(str, "MiracleSoft"); /// <summary>
/// 加密数据
/// </summary>
/// <param name="str">明文字符串</param>
/// <param name="key">密码</param>
/// <returns>密文字符串</returns>
public static string Encrypt(string str, string key)
{
var des = new DESCryptoServiceProvider
{
Key = Encoding.ASCII.GetBytes(GetMD5(key)),
IV = Encoding.ASCII.GetBytes(GetMD5(key))
};
var inputByteArray = Encoding.Default.GetBytes(str);
using (var ms = new MemoryStream())
{
using (var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(inputByteArray, , inputByteArray.Length);
cs.FlushFinalBlock();
var ret = new StringBuilder();
foreach (var b in ms.ToArray())
ret.AppendFormat($"{b:X2}");
return ret.ToString();
}
}
} #endregion #region 解密 /// <summary>
/// 使用默认密码(MiracleSoft)解密字符串
/// </summary>
/// <param name="str">密文字符串</param>
/// <returns>明文</returns>
public static string Decrypt(string str) => Decrypt(str, "MiracleSoft"); /// <summary>
/// 解密数据
/// </summary>
/// <param name="str"></param>
/// <param name="key"></param>
/// <returns></returns>
public static string Decrypt(string str, string key)
{
var des = new DESCryptoServiceProvider
{
Key = Encoding.ASCII.GetBytes(GetMD5(key)),
IV = Encoding.ASCII.GetBytes(GetMD5(key))
};
var len = str.Length / ;
var inputByteArray = new byte[len];
for (var i = ; i < len; i++)
inputByteArray[i] = (byte)Convert.ToInt32(str.Substring(i * , ), );
using (var ms = new MemoryStream())
{
using (var cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
{
cs.Write(inputByteArray, , inputByteArray.Length);
cs.FlushFinalBlock();
return Encoding.Default.GetString(ms.ToArray());
}
}
} #endregion #region MD5 /// <summary>
/// 获取MD5字符串
/// </summary>
/// <param name="str">传入的字符串</param>
/// <returns>MD5</returns>
private static string GetMD5(string str)
{
MD5 md5 = new MD5CryptoServiceProvider(); #region ///MD5CryptoServiceProvider 类MSDN详解 //https://msdn.microsoft.com/zh-cn/library/system.security.cryptography.md5cryptoserviceprovider(v=vs.110).aspx #endregion var md5char = md5.ComputeHash(Encoding.Unicode.GetBytes(str));
var result = md5char.Aggregate<byte, string>(null, (current, t) => current + t.ToString("x2"));
return result.ToUpper();
} #endregion
}
}
using System;
using System.Linq;
using System.Security.Cryptography;
using System.Text; namespace Miraclesoft.SecurityLibrary
{
/// <summary>
/// 得到随机哈希加密字符串,该加密不可逆.
/// </summary>
public static class HashCryp
{
/// <summary>
/// 得到随机哈希加密字符串
/// </summary>
/// <returns></returns>
public static string Security => HashEncoding(); ///<summary>
///生成随机长度随机字符串(10-64的长度)
///</summary>
///<param name="useNum">是否包含数字,true=包含,默认包含</param>
///<param name="useLow">是否包含小写字母,true=包含,默认包含</param>
///<param name="useUpp">是否包含大写字母,true=包含,默认包含</param>
///<param name="useSpe">是否包含特殊字符,true=包含,默认不包含</param>
///<param name="custom">要包含的自定义字符</param>
///<returns>指定长度的随机字符串</returns>
private static string GetRandomString(bool useNum = true, bool useLow = true, bool useUpp = true,
bool useSpe = true, string custom = "")
{
var b = new byte[];
new RNGCryptoServiceProvider().GetBytes(b);
var rad = new Random(BitConverter.ToInt32(b, ));
var length = rad.Next(, );
string result = null;
if (useNum)
custom += "";
if (useLow)
custom += "abcdefghijklmnopqrstuvwxyz";
if (useUpp)
custom += "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
if (useSpe)
custom += "!\"#$%&'()*+,-./:;<=>?@[\\]^_`{|}~";
for (var i = ; i < length; i++)
result += custom.Substring(rad.Next(, custom.Length - ), );
return result;
} /// <summary>
/// 哈希加密一个字符串
/// </summary>
/// <returns></returns>
public static string HashEncoding()
{
var sHA512 = new SHA512Managed();
var unicodeEncoding = new UnicodeEncoding();
var value = sHA512.ComputeHash(unicodeEncoding.GetBytes(GetRandomString()));
return value.Aggregate("", (current, o) => current + ((int)o + "O"));
}
}
}
using System;
using System.IO;
using System.Security.Cryptography;
using System.Text; namespace Miraclesoft.SecurityLibrary
{
/**
* ##############################################################################
* RSA 方式加密及RSA验证
* 说明KEY必须是XML的行式,返回的是字符串
* 有一点需要说明!!该加密方式有 长度 限制的!!
* ##############################################################################
*/
/**
* .Net Framework中提供的RSA算法规定,每次加密的字节数,不能超过密钥的长度值减去11,
* 每次加密得到的密文长度,刚好是密钥的长度.所以,如果要加密较长的数据,可以采用数据截取的方法,分段加密.
* 解密时肯定也要使用分段解密
*/
/// <summary>
/// RSA加密解密及RSA签名和验证
/// 使用加密服务提供程序 (CSP) 提供的 System.Security.Cryptography.RSA 算法的实现执行非对称加密和解密
/// </summary>
public class RSACryp
{
#region RSA 的密钥产生 /// <summary>
/// RSA 的密钥产生 产生私钥和公钥
/// </summary>
/// <param name="XmlPrivateKey">当前RSA对象的密匙XML字符串(包括专用参数)--私钥</param>
/// <param name="XmlPublicKey">当前RSA对象的密匙XML字符串(不包括专用参数)--公钥</param>
public static void RSAKey(out string XmlPrivateKey, out string XmlPublicKey)
{
var rsa = new RSACryptoServiceProvider();
XmlPrivateKey = rsa.ToXmlString(true);
XmlPublicKey = rsa.ToXmlString(false);
} #endregion #region RSA的加密函数 /// <summary>
/// 使用RSA的加密String(该方法存在长度限制)
/// </summary>
/// <param name="XmlPublicKey">当前RSA对象的密匙XML字符串(不包括专用参数)--公钥</param>
/// <param name="Plaintext">需要进行加密的字符串</param>
/// <returns>加密后的字符串</returns>
public static string RSAEncrypt(string XmlPublicKey, string Plaintext) =>
Convert.ToBase64String(RSAEncrypt(XmlPublicKey, new UnicodeEncoding().GetBytes(Plaintext))); /// <summary>
/// 使用RSA的加密byte[](该方法存在长度限制)
/// </summary>
/// <param name="XmlPublicKey">当前RSA对象的密匙XML字符串(不包括专用参数)--公钥</param>
/// <param name="Plaintext">需要进行加密的字节数组</param>
/// <returns>加密后的字节数组</returns>
public static byte[] RSAEncrypt(string XmlPublicKey, byte[] Plaintext)
{
var rsa = new RSACryptoServiceProvider();
rsa.FromXmlString(XmlPublicKey);
return rsa.Encrypt(Plaintext, false);
} #endregion #region RSA的解密函数 /// <summary>
/// RSA解密String(该方法存在长度限制)
/// </summary>
/// <param name="XmlPrivateKey">当前RSA对象的密匙XML字符串(包括专用参数)--私钥</param>
/// <param name="Ciphertext">需要进行解密的字符串</param>
/// <returns>解密后的字符串</returns>
public static string RSADecrypt(string XmlPrivateKey, string Ciphertext) =>
new UnicodeEncoding().GetString(RSADecrypt(XmlPrivateKey, Convert.FromBase64String(Ciphertext))); /// <summary>
/// RSA解密byte[](该方法存在长度限制)
/// </summary>
/// <param name="XmlPrivateKey">当前RSA对象的密匙XML字符串(包括专用参数)--私钥</param>
/// <param name="Ciphertext">需要进行解密的字节数组</param>
/// <returns>解密后的字节数组</returns>
public static byte[] RSADecrypt(string XmlPrivateKey, byte[] Ciphertext)
{
var rsa = new RSACryptoServiceProvider();
rsa.FromXmlString(XmlPrivateKey);
return rsa.Decrypt(Ciphertext, false);
} #endregion #region 获取Hash描述表 /// <summary>
/// 从字符串中取得Hash描述字节数组
/// </summary>
/// <param name="source">源字符串</param>
/// <exception cref="ArgumentException"></exception>
/// <returns>Hash字节数组</returns>
public static byte[] GetHashByte(string source)
{
if (string.IsNullOrEmpty(source))
throw new ArgumentException("源字符串不能为空", nameof(source));
return HashAlgorithm.Create("MD5").ComputeHash(Encoding.GetEncoding("GB2312").GetBytes(source));
} /// <summary>
/// 从字符串中取得Hash描述字符串
/// </summary>
/// <param name="source">源字符串</param>
/// <returns>Hash字符串</returns>
public static string GetHashString(string source) => Convert.ToBase64String(GetHashByte(source)); /// <summary>
/// 从文件中取得Hash描述字节数组
/// </summary>
/// <param name="objFile">文件流</param>
/// <exception cref="ArgumentNullException"></exception>
/// <returns>Hash字节数组</returns>
public static byte[] GetFileHashByte(FileStream objFile)
{
if (objFile == null)
throw new ArgumentNullException(nameof(objFile));
var arry = HashAlgorithm.Create("MD5").ComputeHash(objFile);
objFile.Close();
return arry;
} /// <summary>
/// 从文件中取得Hash描述字符串
/// </summary>
/// <param name="objFile"></param>
/// <returns></returns>
public static string GetFileHashString(FileStream objFile) =>
Convert.ToBase64String(GetFileHashByte(objFile)); #endregion #region RSA签名 /// <summary>
/// RSA签名
/// </summary>
/// <param name="XmlPrivateKey">当前RSA对象的密匙XML字符串(包括专用参数)--私钥</param>
/// <param name="HashbyteSignature">需要签名的字节数组数据</param>
/// <param name="EncryptedSignatureByte">签名后的字节数组数据</param>
public static void SignatureFormatter(string XmlPrivateKey, byte[] HashbyteSignature, ref byte[] EncryptedSignatureByte)
{
var RSA = new RSACryptoServiceProvider();
RSA.FromXmlString(XmlPrivateKey);
var RSAFormatter = new RSAPKCS1SignatureFormatter(RSA);
//设置签名的算法为MD5
RSAFormatter.SetHashAlgorithm("MD5");
//执行签名
EncryptedSignatureByte = RSAFormatter.CreateSignature(HashbyteSignature);
} /// <summary>
/// RSA签名
/// </summary>
/// <param name="XmlPrivateKey">当前RSA对象的密匙XML字符串(包括专用参数)--私钥</param>
/// <param name="HashbyteSignature">需要签名的字节数组数据</param>
/// <param name="EncryptedSignatureString">签名后字符串</param>
public static void SignatureFormatter(string XmlPrivateKey, byte[] HashbyteSignature, ref string EncryptedSignatureString)
{
byte[] EncryptedSignatureData = null;
SignatureFormatter(XmlPrivateKey, HashbyteSignature, ref EncryptedSignatureData);
EncryptedSignatureString = Convert.ToBase64String(EncryptedSignatureData);
} /// <summary>
/// RSA签名
/// </summary>
/// <param name="XmlPrivateKey">当前RSA对象的密匙XML字符串(包括专用参数)--私钥</param>
/// <param name="HashStringSignature">需要签名的字符串</param>
/// <param name="EncryptedSignatureByte">签名后的字节数组数据</param>
/// <returns></returns>
public static void SignatureFormatter(string XmlPrivateKey, string HashStringSignature, ref byte[] EncryptedSignatureByte) =>
SignatureFormatter(XmlPrivateKey, Convert.FromBase64String(HashStringSignature), ref EncryptedSignatureByte); /// <summary>
/// RSA签名
/// </summary>
/// <param name="XmlPrivateKey">当前RSA对象的密匙XML字符串(包括专用参数)--私钥</param>
/// <param name="HashStringSignature">需要签名的字符串</param>
/// <param name="EncryptedSignatureString">签名后字符串</param>
public static void SignatureFormatter(string XmlPrivateKey, string HashStringSignature, ref string EncryptedSignatureString) =>
SignatureFormatter(XmlPrivateKey, Convert.FromBase64String(HashStringSignature), ref EncryptedSignatureString); #endregion #region RSA 签名验证 /// <summary>
/// RSA 签名验证
/// </summary>
/// <param name="XmlPublicKey">当前RSA对象的密匙XML字符串(不包括专用参数)--公钥</param>
/// <param name="HashByteVerification">用RSA签名的字节数组数据</param>
/// <param name="SignatureByte">要为该数据验证的签名字节数组</param>
/// <returns> 如果 HashByteVerification 与使用指定的哈希算法和密钥在 SignatureByte 上计算出的签名匹配,则为 true;否则为 false.</returns>
public static bool SignatureVerification(string XmlPublicKey, byte[] HashByteVerification, byte[] SignatureByte)
{
var RSA = new RSACryptoServiceProvider();
RSA.FromXmlString(XmlPublicKey);
var RSADeformatter = new RSAPKCS1SignatureDeformatter(RSA);
//指定解密的时候HASH算法为MD5
RSADeformatter.SetHashAlgorithm("MD5");
return RSADeformatter.VerifySignature(HashByteVerification, SignatureByte);
} /// <summary>
/// RSA 签名验证
/// </summary>
/// <param name="XmlPublicKey">当前RSA对象的密匙XML字符串(不包括专用参数)--公钥</param>
/// <param name="HashStringVerification">用RSA签名的字符串数据</param>
/// <param name="SignatureByte">要为该数据验证的签名字节数组</param>
/// <returns>如果 HashStringVerification 与使用指定的哈希算法和密钥在 SignatureByte 上计算出的签名匹配,则为 true;否则为 false.</returns>
public static bool SignatureVerification(string XmlPublicKey, string HashStringVerification, byte[] SignatureByte) =>
SignatureVerification(XmlPublicKey, Convert.FromBase64String(HashStringVerification), SignatureByte); /// <summary>
/// RSA 签名验证
/// </summary>
/// <param name="XmlPublicKey">当前RSA对象的密匙XML字符串(不包括专用参数)--公钥</param>
/// <param name="HashByteVerification">用RSA签名的字节数组数据</param>
/// <param name="SignatureString">要为该数据验证的签名字符串</param>
/// <returns>如果 HashByteVerification 与使用指定的哈希算法和密钥在 SignatureString 上计算出的签名匹配,则为 true;否则为 false.</returns>
public static bool SignatureVerification(string XmlPublicKey, byte[] HashByteVerification, string SignatureString) =>
SignatureVerification(XmlPublicKey, HashByteVerification, Convert.FromBase64String(SignatureString)); /// <summary>
/// RSA 签名验证
/// </summary>
/// <param name="XmlPublicKey">当前RSA对象的密匙XML字符串(不包括专用参数)--公钥</param>
/// <param name="HashStringVerification">用RSA签名的字符串数据</param>
/// <param name="SignatureString">要为该数据验证的签名字符串</param>
/// <returns>如果 HashStringVerification 与使用指定的哈希算法和密钥在 SignatureString 上计算出的签名匹配,则为 true;否则为 false.</returns>
public static bool SignatureVerification(string XmlPublicKey, string HashStringVerification, string SignatureString) =>
SignatureVerification(XmlPublicKey, HashStringVerification, Convert.FromBase64String(SignatureString)); #endregion #region 不限长度 /// <summary>
/// RSA加密 不限长度的加密版本
/// </summary>
/// <param name="XmlPublicKey">公匙</param>
/// <param name="Plaintext">需要进行加密的字符串</param>
/// <param name="Ciphertext">加密后的字符串</param>
public static void RSAEncrypt(string XmlPublicKey, string Plaintext, ref string Ciphertext)
{
if (string.IsNullOrEmpty(Plaintext))
throw new Exception("加密字符串不能为空.");
if (string.IsNullOrWhiteSpace(XmlPublicKey))
throw new ArgumentException("错误的公匙");
using (var rsaProvider = new RSACryptoServiceProvider())
{
var inputBytes = Convert.FromBase64String(Plaintext); //有含义的字符串转化为字节流
rsaProvider.FromXmlString(XmlPublicKey); //载入公钥
var bufferSize = (rsaProvider.KeySize / ) - ; //单块最大长度
var buffer = new byte[bufferSize];
using (MemoryStream inputStream = new MemoryStream(inputBytes), outputStream = new MemoryStream())
{
while (true)
{
//分段加密
var readSize = inputStream.Read(buffer, , bufferSize);
if (readSize <= )
break;
var temp = new byte[readSize];
Array.Copy(buffer, , temp, , readSize);
var encryptedBytes = rsaProvider.Encrypt(temp, false);
outputStream.Write(encryptedBytes, , encryptedBytes.Length);
}
Ciphertext = Convert.ToBase64String(outputStream.ToArray()); //转化为字节流方便传输
}
}
} /// <summary>
/// RSA解密 不限长度的解密版本
/// </summary>
/// <param name="XmlPrivateKey">私匙</param>
/// <param name="Ciphertext">需要进行解密的字符串</param>
/// <param name="Plaintext">解密后的字符串</param>
public static void RSADecrypt(string XmlPrivateKey, string Ciphertext, ref string Plaintext)
{
if (string.IsNullOrEmpty(Ciphertext))
throw new Exception("解密字符串不能为空.");
if (string.IsNullOrWhiteSpace(XmlPrivateKey))
throw new ArgumentException("错误的私匙");
using (var rsaProvider = new RSACryptoServiceProvider())
{
var inputBytes = Convert.FromBase64String(Ciphertext);
rsaProvider.FromXmlString(XmlPrivateKey);
var bufferSize = rsaProvider.KeySize / ;
var buffer = new byte[bufferSize];
using (MemoryStream inputStream = new MemoryStream(inputBytes), outputStream = new MemoryStream())
{
while (true)
{
var readSize = inputStream.Read(buffer, , bufferSize);
if (readSize <= )
break;
var temp = new byte[readSize];
Array.Copy(buffer, , temp, , readSize);
var rawBytes = rsaProvider.Decrypt(temp, false);
outputStream.Write(rawBytes, , rawBytes.Length);
}
Plaintext = new UnicodeEncoding().GetString((outputStream.ToArray()));
}
}
} #endregion
}
}
using System;
using System.Security.Cryptography;
using System.Text; namespace Miraclesoft.SecurityLibrary
{
/// <summary>
/// 使用加密服务提供程序 (CSP) 版本 System.Security.Cryptography.TripleDES 算法
/// </summary>
public static class TripleDESCryp
{
#region 使用 缺省密钥字符串 加密/解密String /// <summary>
/// 使用缺省密钥字符串(yuwan.net)加密String
/// </summary>
/// <param name="original">明文</param>
/// <returns>密文</returns>
public static string Encrypt(string original) => Encrypt(original, "yuwan.net"); /// <summary>
/// 使用缺省密钥字符串(yuwan.net)解密String
/// </summary>
/// <param name="original">密文</param>
/// <returns>明文</returns>
public static string Decrypt(string original) => Decrypt(original, "yuwan.net", Encoding.Default); #endregion #region 使用 给定密钥字符串 加密/解密String /// <summary>
/// 使用给定密钥字符串加密String
/// </summary>
/// <param name="original">原始文字</param>
/// <param name="key">密钥</param>
/// <returns>密文</returns>
public static string Encrypt(string original, string key) =>
Convert.ToBase64String(Encrypt(Encoding.Default.GetBytes(original), Encoding.Default.GetBytes(key))); /// <summary>
/// 使用给定密钥字符串解密string
/// </summary>
/// <param name="original">密文</param>
/// <param name="key">密钥</param>
/// <returns>明文</returns>
public static string Decrypt(string original, string key) => Decrypt(original, key, Encoding.Default); /// <summary>
/// 使用给定密钥字符串解密string,返回指定编码方式明文
/// </summary>
/// <param name="encrypted">密文</param>
/// <param name="key">密钥</param>
/// <param name="encoding">字符编码方案</param>
/// <returns>明文</returns>
public static string Decrypt(string encrypted, string key, Encoding encoding) =>
encoding.GetString(Decrypt(Convert.FromBase64String(encrypted), Encoding.Default.GetBytes(key))); #endregion #region 使用 缺省密钥字符串 加密/解密/byte[] /// <summary>
/// 使用缺省密钥字符串(MiracleSoft)解密Byte[]
/// </summary>
/// <param name="encrypted">密文Byte[]</param>
/// <returns>明文</returns>
public static byte[] Decrypt(byte[] encrypted) =>
Decrypt(encrypted, Encoding.Default.GetBytes("MiracleSoft")); /// <summary>
/// 使用缺省密钥字符串(MiracleSoft)加密
/// </summary>
/// <param name="original">明文</param>
/// <returns>密文</returns>
public static byte[] Encrypt(byte[] original) =>
Encrypt(original, Encoding.Default.GetBytes("MiracleSoft")); #endregion #region 使用 给定密钥 加密/解密/byte[] /// <summary>
/// 生成MD5摘要
/// </summary>
/// <param name="original">元数据</param>
/// <returns>MD5摘要</returns>
public static byte[] MakeMD5(byte[] original) => new MD5CryptoServiceProvider().ComputeHash(original); /// <summary>
/// 使用给定密钥加密
/// </summary>
/// <param name="original">明文</param>
/// <param name="key">密钥</param>
/// <returns>密文</returns>
public static byte[] Encrypt(byte[] original, byte[] key)
{
var des = new TripleDESCryptoServiceProvider
{
Key = MakeMD5(key),
Mode = CipherMode.ECB
};
return des.CreateEncryptor().TransformFinalBlock(original, , original.Length);
} /// <summary>
/// 使用给定密钥解密数据
/// </summary>
/// <param name="encrypted">密文</param>
/// <param name="key">密钥</param>
/// <returns>明文</returns>
public static byte[] Decrypt(byte[] encrypted, byte[] key)
{
var des = new TripleDESCryptoServiceProvider
{
Key = MakeMD5(key),
Mode = CipherMode.ECB
};
return des.CreateDecryptor().TransformFinalBlock(encrypted, , encrypted.Length);
} #endregion
}
}
SecurityLibrary的更多相关文章
- Case1:WorkFlow不能运行的解决办法
原因为CRMAppPool选择了一个域用户,然后异步服务的用户执行会有问题 at CrmException..ctor(Int32 errorCode, Object[] arguments) ilO ...
- The initialization of the CRM authentication pipline execution has failed
由于公司电路切换,昨天晚上不得不将服务器暂时关闭.早上重新开机时,发现开发环境连不上了.这可把我急坏了,大家可都等着开发呢. 于是查看服务器错误消息,发现时数据库连接连接不上. The initial ...
随机推荐
- R中数据的输入和数据的标注
数据的导入 默认情况下数据导入时,字符型变量将转化为因子.若不希望转化,可设置 stringsAsFactors=FALSE 从带分隔符的文本文件中导入数据 read.table() file --& ...
- Elasticsearch:fuzzy 搜索 (模糊搜索)
在实际的搜索中,我们有时候会打错字,从而导致搜索不到.在Elasticsearch中,我们可以使用fuzziness属性来进行模糊查询,从而达到搜索有错别字的情形. match查询具有"fu ...
- Load store action in vulkan & ogles 的解决方案
metal的带宽之前的blog有讲 这篇主要是vulkan 和ogles的解决方案 https://www.khronos.org/registry/vulkan/specs/1.1-extensio ...
- Mybatis一对一和一对多配置
作者:夕下奕林 问题描述 现在有三张数据表,表名为orders,orderdetail,items,分别表示订单,订单详情,商品. 其中一个订单包含多个订单详情,表示订单中的不同个具体的商品,订单详情 ...
- UVALive 6862——结论题&&水题
题目 链接 题意:求满足$0 \leq x \leq y \leq z \leq m$且$x^j + y^j = z^j, \ j=2 \cdots n$的三元组的对数 分析 由费马大定理:整数$n ...
- rsync 同步操作
同步:增量拷贝,只传输变化过的数据 rsync [ 选项] 源目录/目标目录 -a :归档模式 相当于 -rlptgoD -v:显示详细操作信息 -z:传输过程中启用压缩/解压 --delet ...
- JavaScript程序设计——FOR循环
FOR循环流程图: 1.编写求6!的阶乘的代码 2.编写10个10相加的和 3.编写1+2+3+...+10连续相加的和 4.编写1+(1+2)+(1+2+3)+...+(1+2+3+...+10)连 ...
- 观察者模式(Observer)---行为型
1 基础知识 定义:定义了对象之间的一对多依赖,让多个观察者对象同时监听某一个主题对象,当主题对象发生变化时,它的所有依赖(观察者)都会收到通知并更新. 本质:触发联动 使用场景:关联行为场景,建立一 ...
- SQL Server text field里面有换行符的时候copy到excel数据会散乱
解决方法: select '"'+convert(varchar(8000),testField)+'"'astestField from testTable 这样虽然结果集里面有 ...
- LA 7043 International Collegiate Routing Contest 路由表 字典树离散化+bitset 银牌题
题目链接:给你n(n<=3e4)个路由地址(注意有子网掩码现象), 路由地址:128.0.0.0/1的形式 要求你输出一个路由集合,其是给定的路由集合的补集,且个数越少越好 #include & ...