js实现md5加密32位大写

本文介绍了如何使用JavaScript实现MD5算法,并将结果转化为32位大写形式,主要针对前端开发人员。

javascript实现md5算法32位

大小写代码片.

function MD5(instring) {
   
   
	var hexcase = 0;   /* hex output format. 0 - lowercase; 1 - uppercase        */
	var b64pad = "";  /* base-64 pad character. "=" for strict RFC compliance   */

	/*
		* These are the functions you'll usually want to call
		* They take string arguments and return either hex or base-64 encoded strings
		*/
	function hex_md5(s) {
   
    return rstr2hex(rstr_md5(str2rstr_utf8(s))); }
	function b64_md5(s) {
   
    return rstr2b64(rstr_md5(str2rstr_utf8(s))); }
	function any_md5(s, e) {
   
    return rstr2any(rstr_md5(str2rstr_utf8(s)), e); }
	function hex_hmac_md5(k, d) {
   
    return rstr2hex(rstr_hmac_md5(str2rstr_utf8(k), str2rstr_utf8(d))); }
	function b64_hmac_md5(k, d) {
   
    return rstr2b64(rstr_hmac_md5(str2rstr_utf8(k), str2rstr_utf8(d))); }
	function any_hmac_md5(k, d, e) {
   
    return rstr2any(rstr_hmac_md5(str2rstr_utf8(k), str2rstr_utf8(d)), e); }

	/*
		* Perform a simple self-test to see if the VM is working
		*/
	function md5_vm_test() {
   
   
		return hex_md5("abc").toLowerCase() == "900150983cd24fb0d6963f7d28e17f72";
	}

	/*
		* Calculate the MD5 of a raw string
		*/
	function rstr_md5(s) {
   
   
		return binl2rstr(binl_md5(rstr2binl(s), s.length * 8));
	}

	/*
		* Calculate the HMAC-MD5, of a key and some data (raw strings)
		*/
	function rstr_hmac_md5(key, data) {
   
   
		var bkey = rstr2binl(key);
		if (bkey.length > 16) bkey = binl_md5(bkey, key.length * 8);

		var ipad = Array(16), opad = Array(16);
		for (var i = 0; i < 16; i++) {
   
   
			ipad[i] = bkey[i] ^ 0x36363636;
			opad[i] = bkey[i] ^ 0x5C5C5C5C;
		}

		var hash = binl_md5(ipad.concat(rstr2binl(data)), 512 + data.length * 8);
		return binl2rstr(binl_md5(opad.concat(hash), 512 + 128));
	}

	/*
		* Convert a raw string to a hex string
		*/
	function rstr2hex(input) {
   
   
		try {
   
    hexcase } catch (e) {
   
    hexcase = 0; }
		var hex_tab = hexcase ? "0123456789ABCDEF" : "0123456789abcdef";
		var output = "";
		var x;
		for (var i = 0; i < input.length; i++) {
   
   
			x = input.charCodeAt(i);
			output += hex_tab.charAt((x >>> 4) & 0x0F)
				+ hex_tab.charAt(x & 0x0F);
		}
		return output;
	}

	/*
		* Convert a raw string to a base-64 string
		*/
	function rstr2b64(input) {
   
   
		try {
   
    b64pad } catch (e) {
   
    b64pad = ''; }
		var tab = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
		var output = "";
		var len = input.length;
		for (var i = 0; i < len; i += 3) {
   
   
			var triplet = (input.charCodeAt(i) << 16)
				| (i + 1 < len ? input.charCodeAt(i + 1) << 8 : 0)
				| (i + 2 < len ? input.charCodeAt(i + 2) : 0);
			for (var j = 0; j < 4; j++) {
   
   
				if (i * 8 + j * 6 > input.length * 8) output += b64pad;
				else output += tab.charAt((triplet >>> 6 * (3 - j)) & 0x3F);
			}
		}
		return output;
	}

	/*
		* Convert a raw string to an arbitrary string encoding
		*/
	function rstr2any(input, encoding
### 小程序中实现MD5加密并生成32大写密文 为了在微信小程序环境中实现MD5加密,并确保输出为32大写字母表示形式,可以采用JavaScript库来辅助完成这一功能。通常情况下,原生的JavaScript并不直接支持MD5算法,因此推荐引入第三方库如`crypto-js`。 #### 使用CryptoJS库进行MD5加密 首先,在项目根目录下通过npm安装`crypto-js`包或者下载对应的js文件放置于项目的合适置以便后续引用: ```bash npm install crypto-js --save ``` 接着,在需要执行加密操作的小程序页面或组件内的`.js`文件顶部导入所需的模块: ```javascript import CryptoJS from 'path_to_crypto_js/crypto-js'; // 替换成实际路径 ``` 之后定义一个用于处理数据转换以及调用MD5方法的函数: ```javascript function getMd5UpperCase(dataString){ let hash = CryptoJS.MD5(dataString); return hash.toString(CryptoJS.enc.Hex).toUpperCase(); } ``` 上述代码片段展示了如何创建一个名为`getMd5UpperCase()`的方法[^2],该方法接收待加密的数据作为参数,利用`CryptoJS.MD5()`来进行哈希运算得到十六进制格式的结果,最后将其全部转成大写字符返回给调用者。 #### 完整示例:封装后的请求携带MD5签名 考虑到提问还涉及到了网络请求部分的内容,这里给出一个完整的例子展示怎样将前面提到的MD5加密逻辑应用于实际场景&mdash;&mdash;即向服务器发送带有签名验证的信息之前先对其进行安全保护措施。 假设有一个简单的表单提交流程,其中包含了手机号码(`mobileNum`)和验证码(`mobileCode`)两个字段,则可以在发起HTTP POST请求前按照特定规则组合这些信息并通过上面介绍过的`getMd5UpperCase()`函数获取到最终版本的安全凭证附加至URL查询串或其他适当的置上传递给后台服务端校验身份合法性。 ```javascript const request = require('../../../utils/request.js'); // 页面引用 request.requestApi({ url: "/接口地址", params: { mobileNum: page.data.phone_num, mobileCode: page.data.phone_code, sign: getMd5UpperCase(`${page.data.phone_num}${page.data.phone_code}`)// 这里简单拼接了两项内容做演示用途,请根据实际情况调整 }, method: "POST" }).then((res)=>{ console.log(res); }); ``` 此段脚本说明了如何结合先前构建好的工具类与现有的异步通信机制一起工作,从而达到增强应用程序安全性的同时也满足了题目关于“生成32大写的密文”的需求[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值