php usdt地址生成

首先下载扩展类

composer require paragonie/ecc:^2.5

composer require kornrunner/keccak:^1.1

php开启扩展gmp

composer require kornrunner/secp256k1

在写一个地址通用类

<?php

namespace app\common;

use kornrunner\Keccak;

use kornrunner\Serializer\HexPrivateKeySerializer;

use Mdanter\Ecc\EccFactory;

class UsdtAddress

{

public function generateTronAddress()

{

$adapter = EccFactory::getAdapter();

$generator = EccFactory::getSecgCurves()->generator256k1();

privateKey = generator->createPrivateKey();

// 修正:传入 generator 而不是 adapter

serializer = new HexPrivateKeySerializer(generator);

privateKeyHex = serializer->serialize($privateKey);

// Get public key (uncompressed)

publicKey = privateKey->getPublicKey();

x = str_pad(gmp_strval(publicKey->getPoint()->getX(), 16), 64, '0', STR_PAD_LEFT);

y = str_pad(gmp_strval(publicKey->getPoint()->getY(), 16), 64, '0', STR_PAD_LEFT);

pubkeyHex = '04' . x . $y;

// Keccak256 hash, take last 20 bytes

hash = Keccak::hash(substr(hex2bin(pubkeyHex), 1), 256);

addressHex = '41' . substr(hash, -40); // TRON address prefix is 41

// Base58Check encoding

addressBin = hex2bin(addressHex);

checksum = substr(hash('sha256', hash('sha256', addressBin, true), true), 0, 4);

base58Address = this->base58_encode(addressBin . checksum);

return [

'private_key' => $privateKeyHex,

'address' => $base58Address,

];

}

// Base58 encode helper

function base58_encode($input)

{

$alphabet = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';

base_count = strlen(alphabet);

num = gmp_init(bin2hex(input), 16);

$encoded = '';

while (gmp_cmp($num, 0) > 0) {

list(num, rem) = gmp_div_qr(num, base_count);

encoded = alphabet[gmp_intval(rem)\] . encoded;

}

// Handle leading zeros

foreach (str_split(input) as byte) {

if ($byte === "\x00") {

encoded = alphabet[0] . $encoded;

} else {

break;

}

}

return $encoded;

}

}

相关推荐
半夏知半秋1 分钟前
kcp学习-skynet中的kcp绑定
开发语言·笔记·后端·学习
扶苏-su9 分钟前
Java--标准输入输出流
java·开发语言
奋斗的小青年!!34 分钟前
Flutter跨平台开发OpenHarmony应用:个人中心实现
开发语言·前端·flutter·harmonyos·鸿蒙
石头wang40 分钟前
jmeter java.lang.OutOfMemoryError: Java heap space 修改内存大小,指定自己的JDK
java·开发语言·jmeter
LawrenceLan1 小时前
Flutter 零基础入门(十五):继承、多态与面向对象三大特性
开发语言·前端·flutter·dart
zh_xuan1 小时前
kotlin对象表达式
开发语言·kotlin
froginwe111 小时前
ECharts 旭日图:全面解析与应用指南
开发语言
yaoxin5211231 小时前
292. Java Stream API - 使用构建器模式创建 Stream
java·开发语言
CoderCodingNo1 小时前
【GESP】C++六级考试大纲知识点梳理, (2) 哈夫曼树、完全二叉树与二叉排序树
开发语言·c++
a努力。1 小时前
字节跳动Java面试被问:一致性哈希的虚拟节点和数据迁移
java·开发语言·分布式·算法·缓存·面试·哈希算法