标签 php 下的文章

“”

php 实现udp发送数据,主要使用 socket_sendto就可以了。

  $socket = socket_create(AF_INET, SOCK_DGRAM, SOL_UDP);
  //PHP UDP socket_ recv() timeout
  socket_set_option($socket,SOL_SOCKET,SO_RCVTIMEO,array("sec"=>2,"usec"=>0));

  //Set socket options.
  socket_set_nonblock($socket);
  socket_set_option($socket, SOL_SOCKET, SO_BROADCAST, 1);
  socket_set_option($socket, SOL_SOCKET, SO_REUSEADDR, 1);
  if (defined('SO_REUSEPORT'))
      socket_set_option($socket, SOL_SOCKET, SO_REUSEPORT, 1);

  //Bind to any address & rand port 
  socket_bind($socket, '0.0.0.0', 9999)
  
  $senddata = "hello";
  socket_sendto($socket,$sendcmd, strlen($senddata), 0, "127.0.0.1", 54321);

php 设置socket 非阻塞

socket_set_nonblock($socket);

php 设置udp 广播

socket_set_option($socket, SOL_SOCKET, SO_BROADCAST, 1);

php 设置 udp 地址端口重用

socket_set_option($socket, SOL_SOCKET, SO_REUSEADDR, 1);

php 设置udp_recv接收超时

  socket_set_option($socket,SOL_SOCKET,SO_RCVTIMEO,array("sec"=>2,"usec"=>0));

php 字符串转大写

uppercase

php 判断http post

 function is_post()
{
    return isset($_SERVER['REQUEST_METHOD']) && strtoupper($_SERVER['REQUEST_METHOD'])=='POST';    
}

php 取随机数

echo(rand();
echo(rand();
echo(rand(10,100))

php socket 官方链接地址
https://www.php.net/manual/en/book.sockets.php

php explode 示例

$arr = explode(":", $buf);

php trim 示例 

$str = "Hello Const!";
echo $str . "<br>";
echo trim($str,"Const!");

<?php
$hex = hex2bin("6578616d706c65206865782064617461");
var_dump($hex);
?>

输出

string(16) "example hex data"

bin2hex() 函数把 ASCII 字符的字符串转换为十六进制值。

<?php

$str = bin2hex("Shanghai");
echo($str);
?>

输出

5368616e67686169

strcasecmp — 不区分大小写比较字符串

如果 str1 小于 str2 返回 < 0; 如果 str1 大于 str2 返回 > 0;如果两者相等,返回 0。

<?php
$var1 = "Hello";
$var2 = "hello";
if (strcasecmp($var1, $var2) == 0) {
    echo '$var1 is equal to $var2 in a case-insensitive string comparison';
}
?>

高级加密标准(英语:Advanced Encryption Standard,缩写:AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。现在,高级加密标准已然成为对称密钥加密中最流行的算法之一。
aes-192密钥的长度为24字节,aes-256密钥的长度为32字节,aes-128密码的长度为16字节。aes-ctr需要密钥就行和iv,另外aes-ctr不需要填充。
计算器模式(Counter (CTR))
代码:

package main

import (
    "bytes"
    "crypto/aes"
    "crypto/cipher"
    "crypto/md5"
    "fmt"
)

func main() {
    fmt.Println("go crypto aes-128-ctr demo/example.")
    message := []byte("https://const.net.cn")
    //指定密钥
    key := []byte("1234567812345678")
    //加密
    cipherText := AES_CTR_Encrypt(message, key)
    fmt.Printf("加密后:%x\n", cipherText)
    fmt.Printf("MD5后为:%x\n", md5.Sum(cipherText))
    //解密
    plainText := AES_CTR_Decrypt(cipherText, key)
    fmt.Println("解密后为:", string(plainText))
}

//AES加密(CTR模式)
func AES_CTR_Encrypt(plainText []byte, key []byte) []byte {
    //指定加密算法,返回一个AES算法的Block接口对象
    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err)
    }
    //指定初始向量vi,长度和block的块尺寸一致
    iv := []byte("1234567812345678")
    //指定分组模式,返回一个BlockMode接口对象
    blockMode := cipher.NewCTR(block, iv)
    //加密连续数据库
    cipherText := make([]byte, len(plainText))
    blockMode.XORKeyStream(cipherText, plainText)
    //返回密文
    return cipherText
}

//AES解密(CTR模式)
func AES_CTR_Decrypt(cipherText []byte, key []byte) []byte {
    //指定解密算法,返回一个AES算法的Block接口对象
    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err)
    }
    //指定初始化向量IV,和加密的一致
    iv := []byte("1234567812345678")
    //指定分组模式,返回一个BlockMode接口对象
    blockMode := cipher.NewCTR(block, iv)
    //解密
    plainText := make([]byte, len(cipherText))
    blockMode.XORKeyStream(plainText, cipherText)
    return plainText
}

输出:

go run .
go crypto aes-128-ctr demo/example.
加密后:05d86826947dd5cf59a0e21be5ca468540c84b98
MD5后为:1facda6cb7539b51eda97b4a9fb7270d
解密后为: https://const.net.cn

php openssl 验证:

<?php
function aes_encrypt($text, $key) {
    $cipher_name = "aes-128-ctr";
    $iv = pack("H*", "31323334353637383132333435363738");
    $key = pack("H*", $key);
    $encrypted = openssl_encrypt($text, $cipher_name, $key, OPENSSL_RAW_DATA, $iv);
    echo "cipher_name = ".$cipher_name."\n";
    echo "plaintext = ".$text."\n";
    echo "md5 = ".md5($encrypted)."\n";
    return bin2hex($encrypted);
  }

  echo "aes-128-ctr cipher_text = ".aes_encrypt('https://const.net.cn', '31323334353637383132333435363738')."\n";
?>

输出:

php7.4 php/openssl.php 
cipher_name = aes-128-ctr
plaintext = https://const.net.cn
md5 = 1facda6cb7539b51eda97b4a9fb7270d
aes-128-ctr cipher_text = 05d86826947dd5cf59a0e21be5ca468540c84b98

高级加密标准(英语:Advanced Encryption Standard,缩写:AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。现在,高级加密标准已然成为对称密钥加密中最流行的算法之一。
aes-192密钥的长度为24字节,aes-256密钥的长度为32字节,aes-128密码的长度为16字节。aes-ctr需要密钥就行和iv,另外aes-ctr不需要填充。
计算器模式(Counter (CTR))
代码:

package main

import (
    "bytes"
    "crypto/aes"
    "crypto/cipher"
    "crypto/md5"
    "fmt"
)

func main() {
    fmt.Println("go crypto aes-192-ctr demo/example.")
    message := []byte("https://const.net.cn")
    //指定密钥
    key := []byte("123456781234567812345678")
    //加密
    cipherText := AES_CTR_Encrypt(message, key)
    fmt.Printf("加密后:%x\n", cipherText)
    fmt.Printf("MD5后为:%x\n", md5.Sum(cipherText))
    //解密
    plainText := AES_CTR_Decrypt(cipherText, key)
    fmt.Println("解密后为:", string(plainText))
}

//AES加密(CTR模式)
func AES_CTR_Encrypt(plainText []byte, key []byte) []byte {
    //指定加密算法,返回一个AES算法的Block接口对象
    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err)
    }
    //指定初始向量vi,长度和block的块尺寸一致
    iv := []byte("1234567812345678")
    //指定分组模式,返回一个BlockMode接口对象
    blockMode := cipher.NewCTR(block, iv)
    //加密连续数据库
    cipherText := make([]byte, len(plainText))
    blockMode.XORKeyStream(cipherText, plainText)
    //返回密文
    return cipherText
}

//AES解密(CTR模式)
func AES_CTR_Decrypt(cipherText []byte, key []byte) []byte {
    //指定解密算法,返回一个AES算法的Block接口对象
    block, err := aes.NewCipher(key)
    if err != nil {
        panic(err)
    }
    //指定初始化向量IV,和加密的一致
    iv := []byte("1234567812345678")
    //指定分组模式,返回一个BlockMode接口对象
    blockMode := cipher.NewCTR(block, iv)
    //解密
    plainText := make([]byte, len(cipherText))
    blockMode.XORKeyStream(plainText, cipherText)
    return plainText
}

输出:

go run .
go crypto aes-192-ctr demo/example.
加密后:adc0a51d488b4143d89f55c7abb6b64aac8fed06
MD5后为:c6b9e8cb1e32eb9bbf14f04a915ef89d
解密后为: https://const.net.cn

php openssl 验证:

<?php

function aes_encrypt($text, $key) {
    $cipher_name = "aes-192-ctr";
    $iv = pack("H*", "31323334353637383132333435363738");
    $key = pack("H*", $key);
    $encrypted = openssl_encrypt($text, $cipher_name, $key, OPENSSL_RAW_DATA, $iv);
    echo "cipher_name = ".$cipher_name."\n";
    echo "plaintext = ".$text."\n";
    echo "md5 = ".md5($encrypted)."\n";
    return bin2hex($encrypted);
  }

  echo "aes-192-ctr cipher_text = ".aes_encrypt('https://const.net.cn', '313233343536373831323334353637383132333435363738')."\n";
  
?>

验证输出:

php7.4 php/openssl.php 
cipher_name = aes-192-ctr
plaintext = https://const.net.cn
md5 = c6b9e8cb1e32eb9bbf14f04a915ef89d
aes-192-ctr cipher_text = adc0a51d488b4143d89f55c7abb6b64aac8fed06