mirror of
				https://github.com/NeteaseCloudMusicApiEnhanced/api-enhanced.git
				synced 2025-10-22 22:53:09 +00:00 
			
		
		
		
	 abd0c9ca91
			
		
	
	
		abd0c9ca91
		
	
	
	
	
		
			
			Refactored main.js to optimize module and server loading, improving code clarity and lazy loading. Updated several dependencies in package.json to their latest versions for better security and compatibility. Updated documentation cover page and home page to reflect project branding changes. Co-Authored-By: binaryify <binaryify@gmail.com>
		
			
				
	
	
		
			136 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| const CryptoJS = require('crypto-js')
 | ||
| const forge = require('node-forge')
 | ||
| const iv = '0102030405060708'
 | ||
| const presetKey = '0CoJUm6Qyw8W8jud'
 | ||
| const linuxapiKey = 'rFgB&h#%2?^eDg:Q'
 | ||
| const base62 = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'
 | ||
| const publicKey = `-----BEGIN PUBLIC KEY-----
 | ||
| MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDgtQn2JZ34ZC28NWYpAUd98iZ37BUrX/aKzmFbt7clFSs6sXqHauqKWqdtLkF2KexO40H1YTX8z2lSgBBOAxLsvaklV8k4cBFK9snQXE9/DDaFt6Rr7iVZMldczhC0JNgTz+SHXT6CBHuX3e9SdB1Ua44oncaTWz7OBGLbCiK45wIDAQAB
 | ||
| -----END PUBLIC KEY-----`
 | ||
| const eapiKey = 'e82ckenh8dichen8'
 | ||
| 
 | ||
| const aesEncrypt = (text, mode, key, iv, format = 'base64') => {
 | ||
|   let encrypted = CryptoJS.AES.encrypt(
 | ||
|     CryptoJS.enc.Utf8.parse(text),
 | ||
|     CryptoJS.enc.Utf8.parse(key),
 | ||
|     {
 | ||
|       iv: CryptoJS.enc.Utf8.parse(iv),
 | ||
|       mode: CryptoJS.mode[mode.toUpperCase()],
 | ||
|       padding: CryptoJS.pad.Pkcs7,
 | ||
|     },
 | ||
|   )
 | ||
|   if (format === 'base64') {
 | ||
|     return encrypted.toString()
 | ||
|   }
 | ||
| 
 | ||
|   return encrypted.ciphertext.toString().toUpperCase()
 | ||
| }
 | ||
| const aesDecrypt = (ciphertext, key, iv, format = 'base64') => {
 | ||
|   let bytes
 | ||
|   if (format === 'base64') {
 | ||
|     bytes = CryptoJS.AES.decrypt(ciphertext, CryptoJS.enc.Utf8.parse(key), {
 | ||
|       iv: CryptoJS.enc.Utf8.parse(iv),
 | ||
|       mode: CryptoJS.mode.ECB,
 | ||
|       padding: CryptoJS.pad.Pkcs7,
 | ||
|     })
 | ||
|   } else {
 | ||
|     bytes = CryptoJS.AES.decrypt(
 | ||
|       { ciphertext: CryptoJS.enc.Hex.parse(ciphertext) },
 | ||
|       CryptoJS.enc.Utf8.parse(key),
 | ||
|       {
 | ||
|         iv: CryptoJS.enc.Utf8.parse(iv),
 | ||
|         mode: CryptoJS.mode.ECB,
 | ||
|         padding: CryptoJS.pad.Pkcs7,
 | ||
|       },
 | ||
|     )
 | ||
|   }
 | ||
|   return bytes.toString(CryptoJS.enc.Utf8)
 | ||
| }
 | ||
| const rsaEncrypt = (str, key) => {
 | ||
|   const forgePublicKey = forge.pki.publicKeyFromPem(key)
 | ||
|   const encrypted = forgePublicKey.encrypt(str, 'NONE')
 | ||
|   return forge.util.bytesToHex(encrypted)
 | ||
| }
 | ||
| 
 | ||
| const weapi = (object) => {
 | ||
|   const text = JSON.stringify(object)
 | ||
|   let secretKey = ''
 | ||
|   for (let i = 0; i < 16; i++) {
 | ||
|     secretKey += base62.charAt(Math.round(Math.random() * 61))
 | ||
|   }
 | ||
|   return {
 | ||
|     params: aesEncrypt(
 | ||
|       aesEncrypt(text, 'cbc', presetKey, iv),
 | ||
|       'cbc',
 | ||
|       secretKey,
 | ||
|       iv,
 | ||
|     ),
 | ||
|     encSecKey: rsaEncrypt(secretKey.split('').reverse().join(''), publicKey),
 | ||
|   }
 | ||
| }
 | ||
| 
 | ||
| const linuxapi = (object) => {
 | ||
|   const text = JSON.stringify(object)
 | ||
|   return {
 | ||
|     eparams: aesEncrypt(text, 'ecb', linuxapiKey, '', 'hex'),
 | ||
|   }
 | ||
| }
 | ||
| 
 | ||
| const eapi = (url, object) => {
 | ||
|   const text = typeof object === 'object' ? JSON.stringify(object) : object
 | ||
|   const message = `nobody${url}use${text}md5forencrypt`
 | ||
|   const digest = CryptoJS.MD5(message).toString()
 | ||
|   const data = `${url}-36cd479b6b5-${text}-36cd479b6b5-${digest}`
 | ||
|   return {
 | ||
|     params: aesEncrypt(data, 'ecb', eapiKey, '', 'hex'),
 | ||
|   }
 | ||
| }
 | ||
| const eapiResDecrypt = (encryptedParams) => {
 | ||
|   // 使用aesDecrypt解密参数
 | ||
|   try {
 | ||
|     const decryptedData = aesDecrypt(encryptedParams, eapiKey, '', 'hex')
 | ||
|     return JSON.parse(decryptedData)
 | ||
|   } catch (error) {
 | ||
|     console.log('eapiResDecrypt error:', error)
 | ||
|     return null
 | ||
|   }
 | ||
| }
 | ||
| const eapiReqDecrypt = (encryptedParams) => {
 | ||
|   // 使用aesDecrypt解密参数
 | ||
|   const decryptedData = aesDecrypt(encryptedParams, eapiKey, '', 'hex')
 | ||
|   // 使用正则表达式解析出URL和数据
 | ||
|   const match = decryptedData.match(/(.*?)-36cd479b6b5-(.*?)-36cd479b6b5-(.*)/)
 | ||
|   if (match) {
 | ||
|     const url = match[1]
 | ||
|     const data = JSON.parse(match[2])
 | ||
|     return { url, data }
 | ||
|   }
 | ||
| 
 | ||
|   // 如果没有匹配到,返回null
 | ||
|   return null
 | ||
| }
 | ||
| const decrypt = (cipher) => {
 | ||
|   const decipher = CryptoJS.AES.decrypt(
 | ||
|     {
 | ||
|       ciphertext: CryptoJS.enc.Hex.parse(cipher),
 | ||
|     },
 | ||
|     eapiKey,
 | ||
|     {
 | ||
|       mode: CryptoJS.mode.ECB,
 | ||
|     },
 | ||
|   )
 | ||
|   const decryptedBytes = CryptoJS.enc.Utf8.stringify(decipher)
 | ||
|   return decryptedBytes
 | ||
| }
 | ||
| 
 | ||
| module.exports = {
 | ||
|   weapi,
 | ||
|   linuxapi,
 | ||
|   eapi,
 | ||
|   decrypt,
 | ||
|   aesEncrypt,
 | ||
|   aesDecrypt,
 | ||
|   eapiReqDecrypt,
 | ||
|   eapiResDecrypt,
 | ||
| }
 |