一、将整数转成字符:

String.fromCharCode(17496>>8,17496&0xFF,19504>>8,19504&0xFF,12848>>8,12848&0xFF,13360>>8,13360&0xFF,17969>>8,17969&0xFF,12592>>8,12592&0xFF,12337>>8,12337&0xFF,14592>>8,14592&0xFF)

//结果:DXL02040F110019

二、将json传过来的数据, unicode 编码的字符转成普通字符:

function ascii2native(asciicode) {
asciicode = asciicode.split("\\u");
var nativeValue = asciicode[0];
for (var i = 1; i < asciicode.length; i++) {
var code = asciicode[i];
nativeValue += String.fromCharCode(parseInt("0x" + code.substring(0, 4)));
if (code.length > 4) {
nativeValue += code.substring(4, code.length);
}
}
return nativeValue;
}

//调用

ascii2native("D\u0000\u0000\u0000X\u0000\u0000\u0000L\u0000\u0000\u00000\u0000\u0000\u00002\u0000\u0000\u00000\u0000\u0000\u00004\u0000\u0000\u00000\u0000\u0000\u0000F\u0000\u0000\u00001\u0000\u0000\u00001\u0000\u0000\u00000\u0000\u0000\u00000\u0000\u0000\u00001\u0000\u0000\u00009\u0000\u0000\u0000\u0000\u0000\u0000\u0000")

//结果:DXL02040F110019

下面是摘抄的:

将十进制数字 97 (ASCII 字符 a)存入文件,然后读出来。

admin  2012-10-23
 2
主要考察97在内存中,和文件中的字节序问题。
还有 int char 的区别。
 
用C语言实现:
 
vim 1.c
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <stdio.h>
 
int main() {
        FILE *fp;
        int a[1] = {97}; // 这个数组只存放一个数:97
 
        fp = fopen("./1.data", "wb");
        fwrite(a, 4, 1, fp);
        fclose(fp);
 
        return 0;
 
}

gcc 1.c

hexdump -C a.out
[root@localhost ~]# hexdump -C 1.data
00000000 61 00 00 00 |a...|
00000004

可以看到是逆序存放的,0x61 转为十进制便是 97, 也就是 ascii 字符 a。

 
然后我们来从文件中读取这个值:
vim 2.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <stdio.h>
 
int main() {
        FILE *fp;
        int a[4] = {97, 98, 99, 100};
        char c[16];
 
        fp = fopen("./1.data", "rb");
        fread(c, 16, 1, fp);
        fclose(fp);
 
        int i;
        for(i=0; i<4; i++) {
                printf("%02x ", c[i]);
        }
 
        printf("\r\n------------\r\n");
 
        for(i=0; i<1; i++) {
                printf("%d", a[i]);
        }
        return 0;
 
}<br>

gcc 2.c && ./a.out

输出:

[root@localhost ~]# ./a.out 
61 00 00 00 
------------
97
 
总结一下:
1. 文件忠实的保存了内存中的数据,怎么读就怎么写即可。
2. intel x86 litter-endian int 内存中的字节序的为逆序(char 为正序)。网络字节序,文件字节序都为正序。
 
 
用PHP实现将 97 存入文件:
1
2
3
4
<?php
$s = pack("L*", 97);
file_put_contents('./1.data', $s);
?>
如果一次要存放一堆怎么办?
pack("L*", array(97, 98, 99, 100)); // 这样是错误的!结果是 array() 转为的数值 1
eval() 不利于 cache ,最好别用。
 
实现了一个支持数组的:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
function int_to_string($arr) {
        $s = '';
        foreach($arr as $v) {
                $a = sprintf('%08x', $v);
                $b = '';
                // int 在内存中为逆序存放
                $b .= chr(base_convert(substr($a, 6, 2), 16, 10));
                $b .= chr(base_convert(substr($a, 4, 2), 16, 10));
                $b .= chr(base_convert(substr($a, 2, 2), 16, 10));
                $b .= chr(base_convert(substr($a, 0, 2), 16, 10));
                //echo $a;
                $s .= $b;
        }
        return $s;
}

js中将 整数转成字符,,将unicode 编码后的字符还原出来的方法。的更多相关文章

  1. Python如何将字符和Unicode编码转变

    小小总结一下,以防过几天忘记,自己的复习资料,如果能帮到大家,也是有所作用!! 1,字符转化为Unicode编码方法: ord("字符") ord("A") o ...

  2. PHP解码unicode编码的中文字符

    问题背景:晚上在抓取某网站数据,结果在数据包中发现了这么一串编码的数据:"......\u65b0\u6d6a\u5fae\u535a......www.jinyuanbao.cn" ...

  3. php正确解码javascript中通过escape编码后的字符

    js的escape如何在PHP中来解呢? 下面的这个函数可以正确的解析,网上有不少unescape的函数,但好用的不多. 这是很久以前收集的一个,不知道谁写的了,但经过测试没有问题~ function ...

  4. js中四舍五入保留两位效数,js中将Number转换成字符类型

    今天在写代码的时候遇到了点问题,特意记下,以免忘记!四舍五入方法: // num为传入的值,n为保留的小数位 function fomatFloat(num,n){ var f = parseFloa ...

  5. js中将字符串转换成json的方式

    1.eval 方式解析,实际中用的还是比较少 function evalJson(str){ var json = eval('(' + str + ')'); return json; } 2.使用 ...

  6. js中将字符串转换成json的三种方式

    1,eval方式解析,恐怕这是最早的解析方式了.如下: function strToJson(str){ var json = eval('(' + str + ')'); return json; ...

  7. C# 获取字符的Unicode编码

    using UnityEngine;using System.Collections;using System.Collections.Generic; List<); string chars ...

  8. 字符串及其操作,字符的Unicode编码

    plainText=input('message:') for c in plainText: print(chr(ord(c)-3),end='') plainText=input('message ...

  9. PHP-解码unicode编码的中文字符

    在Python中使用 "\uxxxx".decode("unicode_escape") 1. class Helper_Tool { public stati ...

随机推荐

  1. 计算机网络分层(OSI七层、 TCP/IP四层)

  2. VBS基础篇 - 对象(6) - Folder对象

    VBS基础篇 - 对象(6) - Folder对象   描述:提供对文件所有属性的访问,从FSO对象的GetFile方法获得 使用Folder对象 要用Folder对象模型来编程必须先用FSO对象的G ...

  3. shell中的cat和文件分界符(<<EOF)

    在shell中,文件分界符(通常写成EOF,你也可以写成FOE或者其他任何字符串)紧跟在<<符号后,意思是分界符后的内容将被当做标准输入传给<<前面的命令,直到再次在独立的一行 ...

  4. ebtables

    ebtables是以太网桥防火墙,以太网工作在数据链路层,ebtables过滤数据链路层包.2.6内核内置了ebtables,要使用它必须先按装她的用户空间工具(ebtables-V2.0.6),安装 ...

  5. As3.0 Interface 与类的使用

    来源:http://blog.sina.com.cn/s/blog_4d65c19e0100bfkb.html 抽象类:又叫抽象基类:可以包含一般类所包含的所有特性,例如,字段,属性,方法,抽象类不能 ...

  6. kubernetes 留言版DEMO

    kubernates hello world1 关闭防火墙 $systemctl disable firewalld $systemctl stop firewalld 2 安装etcd 和 kube ...

  7. liunx 内存文件 tmpfs

    tmpfs是Linux/Unix系统上的一种基于内存的文件系统.tmpfs可以使用您的内存或swap分区来存储文件 1 创建将被挂载的文件 mkdir /tmp/tmpfs/ 2 写入测试文件内容.大 ...

  8. listview前几个item怎么不停加载

    在加载前几个item的时候,listview有个Adapter,里面的getView方法会被调用好几遍.原因可能有两种: 1.listview在布局文件里高度写成了wrap_content <? ...

  9. PHP之输出控制 ob_start(),ob_get_contents(),ob_end_clean()

    1.常用函数 ob_start();#打开输出缓冲区 ob_get_contents();#获取缓冲区内容 ob_get_length();#获取缓冲区内容长度 ob_clean();#清除之前的所有 ...

  10. Python 模块功能paramiko SSH 远程执行及远程下载

    模块 paramiko paramiko是一个用于做远程控制的模块,使用该模块可以对远程服务器进行命令或文件操作,值得一说的是,fabric和ansible内部的远程管理就是使用的paramiko来现 ...