㈠ .net sqlconnection 連接字元串如何加密
#regionAES加密
publicstaticstringEncrypt(stringtoEncrypt)
{
byte[]keyArray=UTF8Encoding.UTF8.GetBytes("");
byte[]toEncryptArray=UTF8Encoding.UTF8.GetBytes(toEncrypt);
RijndaelManagedrDel=newRijndaelManaged();//usingSystem.Security.Cryptography;
rDel.Key=keyArray;
rDel.Mode=CipherMode.ECB;//usingSystem.Security.Cryptography;
rDel.Padding=PaddingMode.PKCS7;//usingSystem.Security.Cryptography;
ICryptoTransformcTransform=rDel.CreateEncryptor();//usingSystem.Security.Cryptography;
byte[]resultArray=cTransform.TransformFinalBlock(toEncryptArray,0,toEncryptArray.Length);
returnConvert.ToBase64String(resultArray,0,resultArray.Length);
}
#endregionAES加密
#regionAES解密
publicstaticstringDecrypt(stringtoDecrypt)
{
try
{
byte[]keyArray=UTF8Encoding.UTF8.GetBytes("");
byte[]toEncryptArray=Convert.FromBase64String(toDecrypt);
RijndaelManagedrDel=newRijndaelManaged();
rDel.Key=keyArray;
rDel.Mode=CipherMode.ECB;
rDel.Padding=PaddingMode.PKCS7;
ICryptoTransformcTransform=rDel.CreateDecryptor();
byte[]resultArray=cTransform.TransformFinalBlock(toEncryptArray,0,toEncryptArray.Length);
returnUTF8Encoding.UTF8.GetString(resultArray);
}
catch(Exceptionex)
{
MessageBox.Show("無效字元串!!!");
return"";
}
}
#endregionAES解密
㈡ 微信開發用戶與公眾號的交互信息一般都需要存儲嗎
微信公眾號有個規則,一旦開啟了開發者模式,其他的常規功能就都必須通過介面調用完成。比如說自定義菜單功能,必須通過發送post請求的方式生成。本章就通過關注到取消關注的整個過程來談一談nodejs是怎麼樣與微信交互的。這些功能的入口就是你在測試公眾號裡面填寫的URL(以下用/login/wechat代替)。 事件交互 掃碼關注微信公眾號後,微信會調用你的介面/login/wechat,並且附帶一段xml信息,首先你需要獲取一些簽名,通過加密、排序比對是否與你填寫的TOKEN一致,如果一致則進行xml的解析。node解析xml時必須先引用模塊。所以,先引入xml解析模塊 //xml解析模塊 var XMLJS = require('xml2js'); //解析,將xml解析為json var parser = new XMLJS/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN)獲取用戶的頭像,性別,昵稱等信息,為你的app建立一個可靠的資料庫。 代碼實現 //微信事件推送的入口 app.post('/yourapi', function(req, res, next) { //獲取參數 var query = req.query; //簽名 var signature = query.signature; //輸出的字元,你填寫的TOKEN var echostr = query.echostr; //時間戳 var timestamp = query['timestamp']; //隨機字元串 var nonce = query.nonce; var oriArray = new Array(); oriArray[] = nonce; oriArray[] = timestamp; oriArray[] = appConfig.token; //排序參數 oriArray.sort(); var original = oriArray[]+oriArray[]+oriArray[]; //加密 var scyptoString = sha(original); //判斷是否與你填寫TOKEN相等 if (signature == scyptoString) { //獲取xml數據 req.on("data", function(data) { //將xml解析 parser.parseString(data.toString(), function(err, result) { var body = result.xml; var messageType = body.MsgType[]; //用戶點擊菜單響應事件 if(messageType === 'event') { var eventName = body.Event[]; (EventFunction[eventName]function(){})(body, req, res); //自動回復消息 }else if(messageType === 'text') { EventFunction.responseNews(body, res); //第一次填寫URL時確認介面是否有效 }else { res.send(echostr); } }); }); } else { //認證失敗,非法操作 res.send("Bad Token!"); } }); //微信客戶端各類回調用介面 var EventFunction = { //關注 subscribe: function(result, req, res) { //存入openid 通過微信的介面獲取用戶的信息同時存入資料庫。 }, //注銷 unsubscribe: function(openid, req, res) { //刪除對應id }, //打開某個網頁 VIEW: function() { //根據需求,處理不同的業務 }, //自動回復 responseNews: function(body, res) { //組裝微信需要的json var xml = {xml: { ToUserName: body.FromUserName, FromUserName: body.ToUserName, CreateTime: + new Date(), MsgType: 'text', Content: '編輯@+您想說的話,我們可以收到' }}; var reciviMessage = body.Content[] if(/^\@.*/.test(reciviMessage)) { xml.xml.Content = '已經收到您的建議,會及時處理!' }<br>//將json轉為xml xml = builder.buildObject(xml);<br>//發送給微信 res.send(xml); } } 此處,適合採用JS設計模式中的策略模式,在subscribe方法裡面寫上你自己的業務,通過發送帶openid參數的請求,可以在用戶關注微信號的時候將其幾本資料存入資料庫,並且建立會話。這樣在用戶接下來打開你的網頁的時候就無需再次認證,只需要比對openid然後查詢資料庫就行了。
如上所說,寫進穗頌去時加密就可以,讀取時再解密, 如下:
///<summary>
//野野/這是添加配置節時
///在*.exe.config文件中appSettings配置節增加一對鍵、值對
///</summary>
///<param name="newKey">配置節鍵</param>
///<param name="newValue">配置節值</param>
public static void UpdateAppConfig(string newKey, string newValue)
{
bool isModified = false;
foreach (string key in ConfigurationManager.AppSettings)
{
if (key == newKey)
{
isModified = true;
}
}
// Open App.Config of executable
Configuration config =
ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
// You need to remove the old settings object before you can replace it
if (isModified)
{
config.AppSettings.Settings.Remove(newKey);
}
//猜脊鄭 Add an Application Setting.
config.AppSettings.Settings.Add(newKey, StringEncry.EncodeBase64(newValue));
// Save the changes in App.config file.
config.Save(ConfigurationSaveMode.Modified);
// Force a reload of a changed section.
ConfigurationManager.RefreshSection("appSettings");
}
///<summary>
///讀取配置節時
///返回*.exe.config文件中appSettings配置節的value項
///</summary>
///<param name="strKey">配置節鍵</param>
///<returns></returns>
public static string GetAppConfig(string strKey)
{
foreach (string key in ConfigurationManager.AppSettings)
{
if (key == strKey)
{
return StringEncry.DecodeBase64(ConfigurationManager.AppSettings[strKey]);
}
}
return "";
}