软录 · 2023年10月10日

cappconfig加密|net sqlconnection 连接字符串如何加密

㈠ .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然后查询数据库就行了。

㈢ C#自定义应用程序配置文件 节加密怎么实现

如上所说,写进穗颂去时加密就可以,读取时再解密, 如下:///<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 executableConfiguration config =ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);// You need to remove the old settings object before you can replace itif (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 "";}