服务器是小端模式, 发送过来前8个字节是 unsigned long long 类型的数据, 我怎么用unpack来读出来呢?
unpack("Q8md5/a10end_str", $recv_body); 这个不行 多谢

解决方案 »

  1.   

    拆开两个32位unpack,反正是整型,又不是浮点
    直接返回还要看系统会否溢出呢另外你上面写的都不符合unpack语法
      

  2.   

    Code Description 
    a NUL-padded string 
    A SPACE-padded string 
    h Hex string, low nibble first 
    H Hex string, high nibble first 
    c signed char 
    C unsigned char 
    s signed short (always 16 bit, machine byte order) 
    S unsigned short (always 16 bit, machine byte order) 
    n unsigned short (always 16 bit, big endian byte order) 
    v unsigned short (always 16 bit, little endian byte order) 
    i signed integer (machine dependent size and byte order) 
    I unsigned integer (machine dependent size and byte order) 
    l signed long (always 32 bit, machine byte order) 
    L unsigned long (always 32 bit, machine byte order) 
    N unsigned long (always 32 bit, big endian byte order) 
    V unsigned long (always 32 bit, little endian byte order) 
    f float (machine dependent size and representation) 
    d double (machine dependent size and representation) 
    x NUL byte 
    X Back up one byte 
    @ NUL-fill to absolute position 没有 Q
      

  3.   

    我来猜猜你想干什么
    unpack("Q8md5/a10end_str", $recv_body)
    应写作
    unpack("Qmd5/a10end_str", $recv_body)
    虽然32位的php不支持64位整数,但规则还是要的
    Q8 表示 8 个64位整数,显然是不合题意的既然是命名为 md5,那么也可以不作为整数来看待
    $a = unpack("amd5/a10end_str", $recv_body);
    $a['md5'] 不就是你要的结果吗
      

  4.   

    不对, amd5只是解出了头一个字节...
      

  5.   

    这个md5是我自己随便写的, 实际是一个 unsigned long long的数值, 这个类型的数值该怎么解出来呢?
      

  6.   

    你最好贴出 base64_encode($recv_body) 的结果
    有了样例数据才好讨论
      

  7.   

    ������ALLDATAEND
    前8个字节是个8位数字, 后面是文本ALLDATAEND;
    unpack("Nn1/a10end_str", $recv_body);
    用这个解, n1是负数 -1935870548
    正确的应该是441051427183631500才对
      

  8.   


     echo base64_encode($recv_body);
    贴出结果用了原始数据,我才能准确的告诉你该怎么写
      

  9.   

    recv_body is ====>jJz1rO/tHgZBTExEQVRBRU5E
    是这个 麻烦了
      

  10.   

    $s = base64_decode('jJz1rO/tHgZBTExEQVRBRU5E');
    $t = unpack('a8n/a10end_str', $s);
    $t['n'] = rmul($t['n']);
    print_r($t);function rmul($w) {
      $n = 0;
      foreach(array_reverse(unpack('v4', $w)) as $v) $n = bcadd(bcmul($n, 65536), $v);
      return $n;
    }Array
    (
        [n] => 441051427183631500
        [end_str] => ALLDATAEND
    )
      

  11.   

    非常感谢 好复杂呀 呵呵 unpack本身不能解码这么长的数字么?
      

  12.   

    php 都是是 32 位编译器编译的,所以没法处理 64 位的整数
    如果你用 64 位编译器编译时,就可支持 64 位整数了
    当然 Q 和 q 模式也就可以用了,也就简单了