php和.net 的加密解密
PHP版:
$key = 335ff';
/*
 * 加密方法
 * @param string $input,待加密的字符串
 * @param string $key,加密的密码(只能为8位长)
 * @return string,加密之后的文本
 * */
public static function encryptForDotNet($input, $key) {
    $iv = $key;
$addnum = 8 - ( strlen($input) % 8 );
    for ($i = 0; $i < $addnum; $i++) {
	$input .= chr($addnum);
    }
$output = mcrypt_encrypt(MCRYPT_DES, $key, $input, MCRYPT_MODE_CBC, $iv);
    return base64_encode($output);
}
/*
 * 解密方法
 * @param string $input,待解密的字符串
 * @param string $key,解密的密码(只能为8位长)
 * @return string,解密之后的文本
 * */
public static function decryptForDotNet($input, $key) {
    $iv = $key;
    $output = base64_decode($input);
    $output = mcrypt_decrypt(MCRYPT_DES, $key, $output, MCRYPT_MODE_CBC, $iv);
for ($i = 0; $i <= 8; $i++) {
	$output = str_replace(chr($i), "", $output);
    }
return $output;
}
C#版:
password = 'isso_key';
/// <summary>
        /// 加密方法
        /// </summary>
        /// <param name="input">待加密的字符串</param>
        /// <param name="password">加密的密码(只能为8位长)</param>
        /// <param name="encoding">编码方式</param>
        /// <returns>加密之后的文本</returns>
        public static string Encrypt(string input, string password, Encoding encoding = null)
        {
            encoding = encoding ?? Encoding.Default;
            //注意iv的长度,必须和key中的密码长度相同
            var iv = encoding.GetBytes(password);
            var key = encoding.GetBytes(password);
            var datas = encoding.GetBytes(input);
            var desCryptoServiceProvider = new DESCryptoServiceProvider();
            using (var memoryStream = new MemoryStream())
            {
                using (
                    var cryptoStream = new CryptoStream(memoryStream, desCryptoServiceProvider.CreateEncryptor(iv, key),
                                                        CryptoStreamMode.Write))
                {
                    cryptoStream.Write(datas, 0, datas.Length);
                    cryptoStream.FlushFinalBlock();
                    return Convert.ToBase64String(memoryStream.ToArray());
                }
            }
        }
/// <summary>
        /// 解密方法
        /// </summary>
        /// <param name="input">待解密的字符串</param>
        /// <param name="password">加密时用的密码(只能为8位长)</param>
        /// <param name="encoding">编码方式</param>
        /// <returns>解密之后的文本</returns>
        public static string Decrypt(string input, string password, Encoding encoding = null)
        {
            encoding = encoding ?? Encoding.Default;
            var iv = encoding.GetBytes(password);
            var key = encoding.GetBytes(password);
            var datas = Convert.FromBase64String(input);
            var desCryptoServiceProvider = new DESCryptoServiceProvider();
            using (var memoryStream = new MemoryStream())
            {
                using (
                    var cryptoStream = new CryptoStream(memoryStream, desCryptoServiceProvider.CreateDecryptor(iv, key),
                                                        CryptoStreamMode.Write))
                {
                    cryptoStream.Write(datas, 0, datas.Length);
                    cryptoStream.FlushFinalBlock();
                    return encoding.GetString(memoryStream.ToArray());
                }
            }
        }
php和.net 的加密解密的更多相关文章
- PHP的学习--RSA加密解密
		PHP服务端与客户端交互或者提供开放API时,通常需要对敏感的数据进行加密,这时候rsa非对称加密就能派上用处了. 举个通俗易懂的例子,假设我们再登录一个网站,发送账号和密码,请求被拦截了. 密码没加 ... 
- 兼容javascript和C#的RSA加密解密算法,对web提交的数据进行加密传输
		Web应用中往往涉及到敏感的数据,由于HTTP协议以明文的形式与服务器进行交互,因此可以通过截获请求的数据包进行分析来盗取有用的信息.虽然https可以对传输的数据进行加密,但是必须要申请证书(一般都 ... 
- .NET和JAVA中BYTE的区别以及JAVA中“DES/CBC/PKCS5PADDING” 加密解密在.NET中的实现
		场景:java 作为客户端调用已有的一个.net写的server的webservice,输入string,返回字节数组. 问题:返回的值不是自己想要的,跟.net客户端直接调用总是有差距 分析:平台不 ... 
- php使用openssl进行Rsa长数据加密(117)解密(128) 和 DES 加密解密
		PHP使用openssl进行Rsa加密,如果要加密的明文太长则会出错,解决方法:加密的时候117个字符加密一次,然后把所有的密文拼接成一个密文:解密的时候需要128个字符解密一下,然后拼接成数据. 加 ... 
- c#和js互通的AES加密解密
		一.使用场景 在使用前后端分离的框架中常常会进行传输数据相互加密解密以确保数据的安全性,如web Api返回加密数据客户端或web端进行解密,或者客户端或web端进行加密提交数据服务端解密数据等等. ... 
- PHP AES的加密解密
		AES加密算法 密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的DE ... 
- [PHP]加密解密函数
		非常给力的authcode加密函数,Discuz!经典代码(带详解) function authcode($string, $operation = 'DECODE', $key = '', $exp ... 
- 非对称技术栈实现AES加密解密
		非对称技术栈实现AES加密解密 正如前面的一篇文章所述,https协议的SSL层是实现在传输层之上,应用层之下,也就是说在应用层上看到的请求还是明码的,对于某些场景下要求这些http请求参数是非可读的 ... 
- 【转】asp.net(c#)加密解密算法之sha1、md5、des、aes实现源码详解
		原文地址:http://docode.top/Article/Detail/10003 目录: 1..Net(C#)平台下Des加密解密源代码 2..Net(C#)平台下Aes加密解密源代码 3..N ... 
- .Net(c#)加密解密之Aes和Des
		.Net(c#)加密解密工具类: /// <summary> /// .Net加密解密帮助类 /// </summary> public class NetCryptoHelp ... 
随机推荐
- Client-Side UI Automation Provider -  WinForm Sample
			Client-Side UI Automation Provider - WinForm Sample 2014-09-15 源代码 目录 引用程序集实现提供程序接口分发客户端提供程序注册和配置客户 ... 
- JUnit 4
			本文是转载的, 主要介绍 Junit 4 ( 搭建在 eclipse 中 ) JUnit4 初体验 Eclipse: 下载 Ant, 基于java的开源构建工具, 你可以在 http://ant.ap ... 
- UVa 1225 Digit Counting
			题意:给出n,将前n个整数顺次写在一起,统计各个数字出现的次数. 用的最笨的办法--直接统计-- 后来发现网上的题解有先打表来做的 #include<iostream> #include& ... 
- BZOJ 3391 Tree Cutting网络破坏
			不想写. #include<iostream> #include<cstdio> #include<cstring> #include<cstdlib> ... 
- 一个基于PDO的数据库操作类(新) 一个PDO事务实例
			<?php /* * 作者:胡睿 * 日期:2011/03/19 * 电邮:hooray0905@foxmail.com * * 20110319 * 常用数据库操作,如:增删改查,获取单条记录 ... 
- S2sh整合MAven项目所需坐标大全
			<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> & ... 
- OGNL valueStack StackContext(ActionContext)深入分析(转+个人理解)
			//还会补充 首先要有一个意识 ,为什么要了解这个?: struts2中的表单是怎么通过表达式(EL or OGNL)来传给Action 和 拿到Action的值的. 值栈(根)对象也可以直接使用EL ... 
- *ecshop 首页促销价显示倒计时
			1.打开includes/lib_goods.php 找到 get_promote_goods()函数部 在(注意:位置别找错了,大概在394行位置) $goods[$idx]['url'] = bu ... 
- ecshop 在首页每个商品下显示已销售数量
			1.在includes/lib_goods.php文件末尾加入以下代码 function get_buy_sum($goods_id) { $sql = "select sum(goods_ ... 
- 关于微信扫描二维码下载apk文件的细节设计
			微信使用的人数越来越多,渐渐的用户形成了一种习惯,扫描二维码的时候,也会打开微信去扫描,但是微信不支持第三方的链接下载,有些厂商已经发现了这一特点,所以在使用二维码下载自家的app时,会做一个提示,引 ... 
