cookie操作类(加密,获取,删除)

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介:
 

using System;
using System.IO;
using System.Text;
using System.Diagnostics;
using System.Web.Security;
using System.Security;
using System.Security.Cryptography;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace ASPNET3DBBook
{
 public class EncryptString
 {   ///定义64位和192位的Kev和IV
  private static byte[] Key64 = {42, 16, 93, 156, 78, 4, 218, 32};
  private static byte[] IV64  = {55, 103, 246, 79, 36, 99, 167, 3};
  private static byte[] Key192 = {42, 16, 93, 156, 78, 4, 218, 32,15, 167, 44, 80, 26, 250, 155, 112,2, 94, 11, 204, 119, 35, 184, 197};
  private static byte[] IV192  = {55, 103, 246, 79, 36, 99, 167, 3,42, 5, 62, 83, 184, 7, 209, 13,145, 23, 200, 58, 173, 10, 121, 222};

  /// <summary>
  /// 加密字符串
  /// </summary>
  /// <param name="valueString"></param>
  /// <returns></returns>
  public static String Encrypt(String valueString)
  {
   if(valueString != "")
   {   ///创建加密的provider
    DESCryptoServiceProvider desprovider = new DESCryptoServiceProvider();
    ///创建加密的流
    MemoryStream memoryStream = new MemoryStream();    
    CryptoStream cryptoStream = new CryptoStream(memoryStream,desprovider.CreateEncryptor

                               (Key64,IV64),CryptoStreamMode.Write);
    StreamWriter writerStream = new StreamWriter(cryptoStream);
    ///加密给定的字符串
    writerStream.Write(valueString);
    writerStream.Flush();
    cryptoStream.FlushFinalBlock();
    ///返回加密后的字符串
    memoryStream.Flush();
    return(Convert.ToBase64String(memoryStream.GetBuffer(),0,(int)memoryStream.Length));
   }
   return(null);
  }

  /// <summary>
  /// 解密字符串
  /// </summary>
  /// <param name="valueString"></param>
  /// <returns></returns>
  public static String Decrypt(String valueString)
  {
   if(valueString != "")
   {   ///创建解密的provider
    DESCryptoServiceProvider desprovider = new DESCryptoServiceProvider();
    byte[] buffer = Convert.FromBase64String(valueString);
    MemoryStream memoryStream = new MemoryStream();
    ///解密给定的字符串
    CryptoStream cryptoStream = new CryptoStream(memoryStream,desprovider.CreateEncryptor

                                (Key64,IV64),CryptoStreamMode.Read);
    StreamReader readerStream = new StreamReader(cryptoStream);
    return(readerStream.ReadToEnd());
   }
   return(null);
  }

  /// <summary>
  /// DES加密方法
  /// </summary>
  /// <param name="valueString"></param>
  /// <returns></returns>
  public static String EncryptTripleDES(String valueString)
  {
   if(valueString != "")
   {  

    ///创建加密的provider
    TripleDESCryptoServiceProvider triprovider = new TripleDESCryptoServiceProvider();
    ///创建加密的流
    MemoryStream memoryStream = new MemoryStream();
    CryptoStream cryptoStream = new CryptoStream(memoryStream,triprovider.CreateEncryptor

                               (Key192,IV192),CryptoStreamMode.Write);
    StreamWriter writerStream = new StreamWriter(cryptoStream);
    ///加密给定的字符串
    writerStream.Write(valueString);
    writerStream.Flush();
    cryptoStream.FlushFinalBlock();
    ///返回加密后的字符串
    memoryStream.Flush();
    return(Convert.ToBase64String(memoryStream.GetBuffer(),0,(int)memoryStream.Length));
   }
   return(null);
  }

  /// <summary>
  /// DES解密方法
  /// </summary>
  /// <param name="valueString"></param>
  /// <returns></returns>
  public static String DecryptTripleDES(String valueString)
  {
   if(valueString != "")
   {   ///创建加密的provider
    TripleDESCryptoServiceProvider triprovider = new TripleDESCryptoServiceProvider();
    ///创建加密的流
    byte[] buffer = Convert.FromBase64String(valueString);
    MemoryStream memoryStream = new MemoryStream();
    CryptoStream cryptoStream = new CryptoStream(memoryStream,triprovider.CreateEncryptor

                                (Key192,IV192),CryptoStreamMode.Read);
    StreamReader readerStream = new StreamReader(cryptoStream);
    return(readerStream.ReadToEnd());
   }
   return(null);
  }
 }

 public class CookieEncrypt
 {  
  /// <summary>
  /// 设置Cookie
  /// </summary>
  /// <param name="cookie"></param>
  public static void SetCookie(HttpCookie cookie)
  {
   HttpContext.Current.Response.Cookies.Set(cookie);
  }

  /// <summary>
  /// 设置Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <param name="valueString"></param>
  public static void SetCookie(String key,String valueString)
  {   ///获取关键字和值
   key = HttpContext.Current.Server.UrlEncode(key);
   valueString = HttpContext.Current.Server.UrlEncode(valueString);
   ///设置Cookie
   HttpCookie cookie = new HttpCookie(key,valueString);
   SetCookie(cookie);
  }

  /// <summary>
  /// 设置Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <param name="valueString"></param>
  /// <param name="expires"></param>
  public static void SetCookie(String key,String valueString,DateTime expires)
  {   ///获取关键字和值
   key = HttpContext.Current.Server.UrlEncode(key);
   valueString = HttpContext.Current.Server.UrlEncode(valueString);
   ///设置Cookie
   HttpCookie cookie = new HttpCookie(key,valueString);
   cookie.Expires = expires;
   SetCookie(cookie);
  }

  /// <summary>
  /// 设置使用DES方法加密之后的Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <param name="valueString"></param>
  public static void SetTripleDESEncryptedCookie(String key,String valueString)
  {  

   ///获取关键字和值
   key = EncryptString.EncryptTripleDES(key);
   valueString = EncryptString.EncryptTripleDES(valueString);
   ///设置Cookie
   SetCookie(key,valueString);
  }

  /// <summary>
  /// 设置使用DES方法加密之后的Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <param name="valueString"></param>
  /// <param name="expires"></param>
  public static void SetTripleDESEncryptedCookie(String key,String valueString,DateTime expires)
  {  

   ///获取关键字和值
   key = EncryptString.EncryptTripleDES(key);
   valueString = EncryptString.EncryptTripleDES(valueString);
   ///设置Cookie
   SetCookie(key,valueString,expires);
  }

  /// <summary>
  /// 设置加密之后的Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <param name="valueString"></param>
  public static void SetEncryptedCookie(String key,String valueString)
  {   ///获取关键字和值
   key = EncryptString.Encrypt(key);
   valueString = EncryptString.Encrypt(valueString);
   ///设置Cookie
   SetCookie(key,valueString);
  }

  /// <summary>
  /// 设置加密之后的Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <param name="valueString"></param>
  /// <param name="expires"></param>
  public static void SetEncryptedCookie(String key,String valueString,DateTime expires)
  {  

   ///获取关键字和值
   key = EncryptString.Encrypt(key);
   valueString = EncryptString.Encrypt(valueString);
   ///设置Cookie
   SetCookie(key,valueString,expires);
  }

  /// <summary>
  /// 获取DES方法加密之后的Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <returns></returns>
  public static String GetTripleDESEncryptedCookieValue(String key)
  {  

   ///获取关键字和值
   key = EncryptString.EncryptTripleDES(key);
   String valueString = GetCookieValue(key);
   ///获取Cookie
   valueString = EncryptString.DecryptTripleDES(valueString);
   return(valueString);   
  }

  /// <summary>
  /// 获取DES方法加密之后的Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <returns></returns>
  public static String GetEncryptedCookieValue(String key)
  {  

   ///获取关键字和值
   key = EncryptString.Encrypt(key);
   String valueString = GetCookieValue(key);
   ///获取Cookie
   valueString = EncryptString.Decrypt(valueString);
   return(valueString);   
  }

  /// <summary>
  /// 获取Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <returns></returns>
  public static HttpCookie GetCookie(String key)
  {  

   ///获取关键字和值
   key = HttpContext.Current.Server.UrlEncode(key);
   ///获取Cookie
   return(HttpContext.Current.Request.Cookies.Get(key));
  }

  /// <summary>
  /// 获取Cookie
  /// </summary>
  /// <param name="key"></param>
  /// <returns></returns>
  public static String GetCookieValue(String key)
  {  

   ///获取关键字和值
   String valueString = GetCookie(key).Value;
   ///获取Cookie
   valueString = HttpContext.Current.Server.UrlDecode(valueString);
   return(valueString);
  }
 }
}

目录
相关文章
|
8月前
|
数据安全/隐私保护
18、cookie注入(base64加密)
18、cookie注入(base64加密)
62 0
|
3月前
|
JavaScript 数据安全/隐私保护
马蜂窝 cookie 加密(加速乐)
本文介绍了一次针对马蜂窝网站的逆向工程过程,旨在学习交流,不提供完整代码及敏感信息。文中详细描述了三次GET请求的过程,通过抓包工具分析了请求头和响应内容,并逐步解析了`cookie`参数的生成方法。最终通过携带特定`cookie`成功获取页面内容。严禁将本文内容用于非法或商业用途,违者自行承担一切后果。未经许可不得转载或修改后传播。
101 0
|
5月前
|
数据采集 JavaScript 前端开发
同花顺股票数据逆向:Cookie加密和Hook注入
同花顺股票数据逆向:Cookie加密和Hook注入
323 0
|
7月前
|
JavaScript 前端开发 安全
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
|
8月前
|
存储 Web App开发 安全
Django中Cookie相关操作
Django中Cookie相关操作
|
8月前
|
SQL 分布式计算 DataWorks
MaxCompute确实支持对id_card_no进行加密和解密操作
MaxCompute确实支持对id_card_no进行加密和解密操作
205 56
|
8月前
|
SQL 分布式计算 DataWorks
MaxCompute确实支持对id_card_no进行加密和解密操作
【2月更文挑战第4天】MaxCompute确实支持对id_card_no进行加密和解密操作
84 12
|
8月前
|
存储 JavaScript 前端开发
JavaScript DOM 操作:解释一下 cookie、sessionStorage 和 localStorage 的区别。
Cookie是服务器发送至客户端的文本信息,会随每个请求发送回服务器,适合控制会话状态但可能暴露隐私。SessionStorage仅在当前会话中存储数据,关闭浏览器后清除,适合临时存储如登录状态。LocalStorage则持久保存数据,即使关闭浏览器也不会清除,适用于存储长期设置。三种方式各有侧重,应按需求选择。
57 0
|
8月前
|
数据安全/隐私保护
小课堂 -- cookie注入(base64加密)
小课堂 -- cookie注入(base64加密)
59 0
|
8月前
|
存储 前端开发 Java
【源码共读】在前端如何操作 Cookie
【源码共读】在前端如何操作 Cookie
120 1