JS加密解密之字符编码知识

在这里插入图片描述

在前端开发中,字符编码是一个至关重要的概念,特别是在数据传输、加密和解密等方面。JavaScript作为一种常用的脚本语言,在处理字符编码时也有其独特之处。本文将详细介绍JavaScript中的字符编码知识,包括字符编码的分类和相关案例代码。

一、字符编码概述

字符编码是将字符映射到数字的过程,以便计算机能够理解和处理文本数据。在JavaScript中,常见的字符编码包括 ASCII、Unicode 和 UTF-8。

  1. ASCII编码:ASCII(American Standard Code for Information Interchange)是一种基于拉丁字母的字符编码,用于将字符映射到数字。ASCII编码只使用了一个字节(8位),因此最多可以表示256个字符。
  2. Unicode编码:Unicode是一种字符集,包含了世界上几乎所有的字符,每个字符都有一个唯一的Unicode码点。Unicode编码通常用16位(双字节)来表示字符。
  3. UTF-8编码:UTF-8(Unicode Transformation Format)是一种对Unicode进行变长编码的实现方式。UTF-8使用1至4个字节来表示一个字符,能够表示Unicode中的所有字符。

二、字符编码分类

根据字符编码的不同特点,可以将字符编码分为以下几类:

  1. 单字节编码:每个字符占用一个字节的编码方式,如ASCII编码。
  2. 双字节编码:每个字符占用两个字节的编码方式,如Unicode编码。
  3. 多字节编码:每个字符占用超过两个字节的编码方式,如UTF-8编码。

三、案例代码示例

1. ASCII编码示例:
// 字符串转换为ASCII码
function stringToAscii(str) {let asciiArr = [];for (let i = 0; i < str.length; i++) {asciiArr.push(str.charCodeAt(i));}return asciiArr;
}// ASCII码转换为字符串
function asciiToString(asciiArr) {let str = '';for (let i = 0; i < asciiArr.length; i++) {str += String.fromCharCode(asciiArr[i]);}return str;
}let inputStr = "Hello";
let asciiArray = stringToAscii(inputStr);
console.log("ASCII码数组:", asciiArray);
console.log("ASCII码转换后的字符串:", asciiToString(asciiArray));
2. Unicode编码示例:
// 字符串转换为Unicode码
function stringToUnicode(str) {let unicodeArr = [];for (let i = 0; i < str.length; i++) {unicodeArr.push(str.charCodeAt(i));}return unicodeArr;
}// Unicode码转换为字符串
function unicodeToString(unicodeArr) {let str = '';for (let i = 0; i < unicodeArr.length; i++) {str += String.fromCharCode(unicodeArr[i]);}return str;
}let inputStr = "你好";
let unicodeArray = stringToUnicode(inputStr);
console.log("Unicode码数组:", unicodeArray);
console.log("Unicode码转换后的字符串:", unicodeToString(unicodeArray));
3. UTF-8编码示例:
// 字符串转换为UTF-8编码
function stringToUtf8(str) {return unescape(encodeURIComponent(str));
}// UTF-8编码转换为字符串
function utf8ToString(utf8Str) {return decodeURIComponent(escape(utf8Str));
}let inputStr = "🚀";
let utf8Encoded = stringToUtf8(inputStr);
console.log("UTF-8编码后的字符串:", utf8Encoded);
console.log("UTF-8编码转换后的字符串:", utf8ToString(utf8Encoded));

四、总结

本文介绍了JavaScript中的字符编码知识,包括ASCII、Unicode和UTF-8编码的概念、分类以及相关的案例代码。了解字符编码对于前端开发者来说至关重要,能够帮助他们更好地处理文本数据,确保数据的正确性和安全性。

五、和js加密的关系

字符编码在JavaScript加密中扮演着重要的角色,它与加密算法和数据传输密切相关,确保加密和解密过程的正确性、安全性和可靠性。因此,在开发JavaScript加密应用程序时,理解字符编码的原理和使用方法是非常重要的。

Jsjiami.v7在线js加密

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/765439.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringCloud从入门到精通速成(二)

文章目录 1.Nacos配置管理1.1.统一配置管理1.1.1.在nacos中添加配置文件1.1.2.从微服务拉取配置 1.2.配置热更新1.2.1.方式一1.2.2.方式二 1.3.配置共享1&#xff09;添加一个环境共享配置2&#xff09;在user-service中读取共享配置3&#xff09;运行两个UserApplication&…

【算法】数论——蓝桥杯笔记、最大公约数、欧拉函数模版、线性筛法求欧拉函数、快速幂 a^k%p、扩展欧几里得算法

文章目录 蓝桥杯* 最大公约数欧拉函数模版* 线性筛法 求欧拉函数* 快速幂 a^k%p扩展欧几里得算法 蓝桥杯 * 最大公约数 两个整数的最大公约数等于其中较小的那个数和两数的差的最大公约数。通过不断地用较小的数替换较大的数&#xff0c;并用两数的差替换较小的数&#xff0c;…

ElasticSearch文档操作[ES系列] - 第502篇

历史文章&#xff08;文章累计500&#xff09; 《国内最全的Spring Boot系列之一》 《国内最全的Spring Boot系列之二》 《国内最全的Spring Boot系列之三》 《国内最全的Spring Boot系列之四》 《国内最全的Spring Boot系列之五》 《国内最全的Spring Boot系列之六》 《…

阿里云OSS存储的视频如何加水印

OSS是不能进行视频添加水印的&#xff0c;可以图片添加水印。 您可以在视频点播中进行配置&#xff1a; https://help.aliyun.com/zh/vod/user-guide/video-watermarks?spma2c4g.11186623.0.i2 原来的业务代码都是使用python 对oss的 视频进行上传 的,上传的视频路径已经保存到…

qt5-入门-国际化

参考&#xff1a; Qt 国际化(上)_w3cschool https://www.w3cschool.cn/learnroadqt/fwkx1j4j.html QT5实现语言国际化&#xff08;中英文界面动态切换&#xff0c;超详细&#xff09;_qt qevent::languagechange-CSDN博客 https://blog.csdn.net/m0_49047167/article/details/…

【随手记】MySQL窗口函数计算累加和

SELECT id, month, salary,SUM(salary) OVER (ORDER BY month ROWS BETWEEN 2 PRECEDING AND CURRENT ROW) AS rolling_total FROM employee;1.当前行及其前2行累加求和 SUM(salary) OVER (ORDER BY month ROWS BETWEEN 2 PRECEDING AND CURRENT ROW) 是一个窗口函数&#xff…

鸿蒙Harmony应用开发—ArkTS(stateStyles:多态样式)

Styles和Extend仅仅应用于静态页面的样式复用&#xff0c;stateStyles可以依据组件的内部状态的不同&#xff0c;快速设置不同样式。这就是我们本章要介绍的内容stateStyles&#xff08;又称为&#xff1a;多态样式&#xff09;。 概述 stateStyles是属性方法&#xff0c;可以…

uniapp app端跳转到应用商店

uniapp app端跳转到应用商店 安卓是指定包名跳转&#xff0c;iOS需要指定id: if (plus.os.name "Android") {// 跳转安卓应用市场let appurl "market://details?idcom.tencent.mm" //这个是通用应用市场&#xff0c;如果想指定某个应用商店&#xff0…

基于springboot的4S店车辆管理系统

基于springboot的4S店车辆管理系统 的设计和实现 开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09; 数据库工具&#xff1a;Navicat11 开…

c语言食堂就餐排队问题290行

定制魏&#xff1a;QTWZPW&#xff0c;获取更多源码等 目录 题目 数据结构 函数设计 结构设计 总结 效果截图 ​ 主函数代码 题目 设计一个程序来模拟食堂就餐排队问题&#xff0c;通过输入学生人数和面包数量&#xff0c;计算有多少学生能够吃到午餐。 数据结构 该…

【Docker】在 Ubuntu 上安装 Docker 的步骤

在 Ubuntu 上安装 Docker 的步骤如下&#xff1a; 更新包索引并安装必要的软件包以允许 apt 使用 HTTPS&#xff1a; sudo apt update sudo apt install apt-transport-https ca-certificates curl software-properties-common注意&#xff01;网上另有一个命令声称最简洁&am…

25.2 微服务Dubbo

25.2 微服务Dubbo 1. Dubbo简介2. RPC3. Dubbo工作原理4. 代码实操4.1 父项目1. 依赖4.2 服务提供者1. 依赖2. 配置文件3. 启动类4. 业务类4.3 服务消费者1. 依赖2. 配置文件3. 消费者启动类4. 业务:实现远程调用

GPS授时器(NTP校时服务器)助力电子政务系统建设

GPS授时器&#xff08;NTP校时服务器&#xff09;助力电子政务系统建设 GPS授时器&#xff08;NTP校时服务器&#xff09;助力电子政务系统建设 摘要&#xff1a;随着电子政务的不断发展&#xff0c;许多省份都建立了自己的政务网络&#xff0c;使用的网络设备和服务器日益增多…

Tomcat部署war包

1.首先将咱们的web项目进行打包,打成一个war包&#xff1b; 2.将war包放置在webapps目录下&#xff0c;当tomcat启动运行时会将war包自动解压在当前文件夹&#xff0c;war包名称即为访问路径&#xff1b; 3.在conf目录下server.xml里可以设置tomcat访问端口&#xff0c;如果端口…

数字资产管理系统、企业数字资产管理软件

数字资产管理系统&#xff08;DAMS&#xff09;是一系列软件&#xff0c;它提供了一个开放平台&#xff0c;支持对多媒体数据的采集、创建、管理、存储、归档、检索、传输和显示。这些多媒体数据包括图像、视频、声音、文本和电影剪辑等。这些基础软件不仅是内容创作&#xff0…

使用React搭建single-spa

自己搭建的Demo GitHub - ftao123/single-spa-react-demo: single-spa-react-demo 修改子应用的webpack配置 library: "app2"和libraryTarget: "umd"配置必须添加。 可以看到filename在开发环境下的地址是static/js/bundle.js&#xff0c;所以我们主应用…

Java多线程自定义线程池——线程池的七大参数和四大拒绝策略

线程池 2.1 线程池思想 我们使用线程的时候就去创建一个线程&#xff0c;这样实现起来非常简便&#xff0c;但是就会有一个问题&#xff1a; 如果并发的线程数量很多&#xff0c;并且每个线程都是执行一个时间很短的任务就结束了&#xff0c;这样频繁创建线程就会大大降低系统…

Linux/Bizness

Enumeration nmap 用 nmap 扫描了常见的端口&#xff0c;发现对外开放了22,80,443 ┌──(kali㉿kali)-[~] └─$ nmap 10.10.11.252 Starting Nmap 7.93 ( https://nmap.org ) at 2024-03-08 01:21 EST Nmap scan report for 10.10.11.252 Host is up (0.36s latency). Not…

python 空间距离计算

目录 python 空间距离计算 已知两点&#xff0c;画三角形 批量矩阵计算 python 空间距离计算 要在空间中找到一个点&#xff0c;使其位于点 b 和 c 之间的连线上&#xff0c;并且与点 b 的距离等于点 a 到点 b 的距离的2倍。 import numpy as npif __name__ __main__:a …

MySQL下载安装和本地连接

1、下载MySQL 从MySQL官网下载MySQL Community Server版本&#xff1a; 下载地址&#xff1a;MySQL官网 1、进入官网&#xff0c;点击DOWNLOADS 2、点击MySQL Community(GPL)Downloads 3、点击MySQL Installer for Windows 4、这个会直接跳转到最新的版本 如果想下载以往的…