当前位置: 首页 > news >正文

2023 楚慧杯 --- Crypto wp

文章目录

      • 初赛
        • so large e
      • 决赛
        • JIGE

初赛

so large e

题目:

from Crypto.Util.number import *
from Crypto.PublicKey import RSA
from flag import flag
import randomm = bytes_to_long(flag)p = getPrime(512)
q = getPrime(512)
n = p*q
e = random.getrandbits(1024)
assert size(e)==1024
phi = (p-1)*(q-1)
assert GCD(e,phi)==1
d = inverse(e,phi)
assert size(d)==269pub = (n, e)
PublicKey = RSA.construct(pub)
with open('pub.pem', 'wb') as f :f.write(PublicKey.exportKey())c = pow(m,e,n)
print('c =',c)print(long_to_bytes(pow(c,d,n)))#c = 6838759631922176040297411386959306230064807618456930982742841698524622016849807235726065272136043603027166249075560058232683230155346614429566511309977857815138004298815137913729662337535371277019856193898546849896085411001528569293727010020290576888205244471943227253000727727343731590226737192613447347860

读取公钥得到n,e,

e = 113449247876071397911206070019495939088171696712182747502133063172021565345788627261740950665891922659340020397229619329204520999096535909867327960323598168596664323692312516466648588320607291284630435682282630745947689431909998401389566081966753438869725583665294310689820290368901166811028660086977458571233n = 116518679305515263290840706715579691213922169271634579327519562902613543582623449606741546472920401997930041388553141909069487589461948798111698856100819163407893673249162209631978914843896272256274862501461321020961958367098759183487116417487922645782638510876609728886007680825340200888068103951956139343723

根据代码,获悉
0.25 ≤ d n = 0.263 ≤ 0.292 0.25 \le \frac{d}{n} = 0.263\le0.292 0.25nd=0.2630.292
满足 Boneh and Durfee attack
直接套用模板,修改一下delta 和m即可
其中delta = 0.263,m = 5

exp:

#sage
from __future__ import print_function
import time############################################
# Config
##########################################"""
Setting debug to true will display more informations
about the lattice, the bounds, the vectors...
"""
debug = True"""
Setting strict to true will stop the algorithm (and
return (-1, -1)) if we don't have a correct
upperbound on the determinant. Note that this
doesn't necesseraly mean that no solutions
will be found since the theoretical upperbound is
usualy far away from actual results. That is why
you should probably use `strict = False`
"""
strict = False"""
This is experimental, but has provided remarkable results
so far. It tries to reduce the lattice as much as it can
while keeping its efficiency. I see no reason not to use
this option, but if things don't work, you should try
disabling it
"""
helpful_only = True
dimension_min = 7 # stop removing if lattice reaches that dimension############################################
# Functions
########################################### display stats on helpful vectors
def helpful_vectors(BB, modulus):nothelpful = 0for ii in range(BB.dimensions()[0]):if BB[ii,ii] >= modulus:nothelpful += 1print(nothelpful, "/", BB.dimensions()[0], " vectors are not helpful")# display matrix picture with 0 and X
def matrix_overview(BB, bound):for ii in range(BB.dimensions()[0]):a = ('%02d ' % ii)for jj in range(BB.dimensions()[1]):a += '0' if BB[ii,jj] == 0 else 'X'if BB.dimensions()[0] < 60:a += ' 'if BB[ii, ii] >= bound:a += '~'print(a)# tries to remove unhelpful vectors
# we start at current = n-1 (last vector)
def remove_unhelpful(BB, monomials, bound, current):# end of our recursive functionif current == -1 or BB.dimensions()[0] <= dimension_min:return BB# we start by checking from the endfor ii in range(current, -1, -1):# if it is unhelpful:if BB[ii, ii] >= bound:affected_vectors = 0affected_vector_index = 0# let's check if it affects other vectorsfor jj in range(ii + 1, BB.dimensions()[0]):# if another vector is affected:# we increase the countif BB[jj, ii] != 0:affected_vectors += 1affected_vector_index = jj# level:0# if no other vectors end up affected# we remove itif affected_vectors == 0:print("* removing unhelpful vector", ii)BB = BB.delete_columns([ii])BB = BB.delete_rows([ii])monomials.pop(ii)BB = remove_unhelpful(BB, monomials, bound, ii-1)return BB# level:1# if just one was affected we check# if it is affecting someone elseelif affected_vectors == 1:affected_deeper = Truefor kk in range(affected_vector_index + 1, BB.dimensions()[0]):# if it is affecting even one vector# we give up on this oneif BB[kk, affected_vector_index] != 0:affected_deeper = False# remove both it if no other vector was affected and# this helpful vector is not helpful enough# compared to our unhelpful oneif affected_deeper and abs(bound - BB[affected_vector_index, affected_vector_index]) < abs(bound - BB[ii, ii]):print("* removing unhelpful vectors", ii, "and", affected_vector_index)BB = BB.delete_columns([affected_vector_index, ii])BB = BB.delete_rows([affected_vector_index, ii])monomials.pop(affected_vector_index)monomials.pop(ii)BB = remove_unhelpful(BB, monomials, bound, ii-1)return BB# nothing happenedreturn BB""" 
Returns:
* 0,0   if it fails
* -1,-1 if `strict=true`, and determinant doesn't bound
* x0,y0 the solutions of `pol`
"""
def boneh_durfee(pol, modulus, mm, tt, XX, YY):"""Boneh and Durfee revisited by Herrmann and Mayfinds a solution if:* d < N^delta* |x| < e^delta* |y| < e^0.5whenever delta < 1 - sqrt(2)/2 ~ 0.292"""# substitution (Herrman and May)PR.<u, x, y> = PolynomialRing(ZZ)Q = PR.quotient(x*y + 1 - u) # u = xy + 1polZ = Q(pol).lift()UU = XX*YY + 1# x-shiftsgg = []for kk in range(mm + 1):for ii in range(mm - kk + 1):xshift = x^ii * modulus^(mm - kk) * polZ(u, x, y)^kkgg.append(xshift)gg.sort()# x-shifts list of monomialsmonomials = []for polynomial in gg:for monomial in polynomial.monomials():if monomial not in monomials:monomials.append(monomial)monomials.sort()# y-shifts (selected by Herrman and May)for jj in range(1, tt + 1):for kk in range(floor(mm/tt) * jj, mm + 1):yshift = y^jj * polZ(u, x, y)^kk * modulus^(mm - kk)yshift = Q(yshift).lift()gg.append(yshift) # substitution# y-shifts list of monomialsfor jj in range(1, tt + 1):for kk in range(floor(mm/tt) * jj, mm + 1):monomials.append(u^kk * y^jj)# construct lattice Bnn = len(monomials)BB = Matrix(ZZ, nn)for ii in range(nn):BB[ii, 0] = gg[ii](0, 0, 0)for jj in range(1, ii + 1):if monomials[jj] in gg[ii].monomials():BB[ii, jj] = gg[ii].monomial_coefficient(monomials[jj]) * monomials[jj](UU,XX,YY)# Prototype to reduce the latticeif helpful_only:# automatically removeBB = remove_unhelpful(BB, monomials, modulus^mm, nn-1)# reset dimensionnn = BB.dimensions()[0]if nn == 0:print("failure")return 0,0# check if vectors are helpfulif debug:helpful_vectors(BB, modulus^mm)# check if determinant is correctly boundeddet = BB.det()bound = modulus^(mm*nn)if det >= bound:print("We do not have det < bound. Solutions might not be found.")print("Try with highers m and t.")if debug:diff = (log(det) - log(bound)) / log(2)print("size det(L) - size e^(m*n) = ", floor(diff))if strict:return -1, -1else:print("det(L) < e^(m*n) (good! If a solution exists < N^delta, it will be found)")# display the lattice basisif debug:matrix_overview(BB, modulus^mm)# LLLif debug:print("optimizing basis of the lattice via LLL, this can take a long time")BB = BB.LLL()if debug:print("LLL is done!")# transform vector i & j -> polynomials 1 & 2if debug:print("looking for independent vectors in the lattice")found_polynomials = Falsefor pol1_idx in range(nn - 1):for pol2_idx in range(pol1_idx + 1, nn):# for i and j, create the two polynomialsPR.<w,z> = PolynomialRing(ZZ)pol1 = pol2 = 0for jj in range(nn):pol1 += monomials[jj](w*z+1,w,z) * BB[pol1_idx, jj] / monomials[jj](UU,XX,YY)pol2 += monomials[jj](w*z+1,w,z) * BB[pol2_idx, jj] / monomials[jj](UU,XX,YY)# resultantPR.<q> = PolynomialRing(ZZ)rr = pol1.resultant(pol2)# are these good polynomials?if rr.is_zero() or rr.monomials() == [1]:continueelse:print("found them, using vectors", pol1_idx, "and", pol2_idx)found_polynomials = Truebreakif found_polynomials:breakif not found_polynomials:print("no independant vectors could be found. This should very rarely happen...")return 0, 0rr = rr(q, q)# solutionssoly = rr.roots()if len(soly) == 0:print("Your prediction (delta) is too small")return 0, 0soly = soly[0][0]ss = pol1(q, soly)solx = ss.roots()[0][0]#return solx, solydef example():############################################# How To Use This Script############################################ The problem to solve (edit the following values)## the modulusN = 116518679305515263290840706715579691213922169271634579327519562902613543582623449606741546472920401997930041388553141909069487589461948798111698856100819163407893673249162209631978914843896272256274862501461321020961958367098759183487116417487922645782638510876609728886007680825340200888068103951956139343723# the public exponente = 113449247876071397911206070019495939088171696712182747502133063172021565345788627261740950665891922659340020397229619329204520999096535909867327960323598168596664323692312516466648588320607291284630435682282630745947689431909998401389566081966753438869725583665294310689820290368901166811028660086977458571233# the hypothesis on the private exponent (the theoretical maximum is 0.292)delta = .263 # this means that d < N^delta## Lattice (tweak those values)## you should tweak this (after a first run), (e.g. increment it until a solution is found)m = 5 # size of the lattice (bigger the better/slower)# you need to be a lattice master to tweak theset = int((1-2*delta) * m)  # optimization from Herrmann and MayX = 2*floor(N^delta)  # this _might_ be too muchY = floor(N^(1/2))    # correct if p, q are ~ same size## Don't touch anything below## Problem put in equationP.<x,y> = PolynomialRing(ZZ)A = int((N+1)/2)pol = 1 + x * (A + y)## Find the solutions!## Checking boundsif debug:print("=== checking values ===")print("* delta:", delta)print("* delta < 0.292", delta < 0.292)print("* size of e:", int(log(e)/log(2)))print("* size of N:", int(log(N)/log(2)))print("* m:", m, ", t:", t)# boneh_durfeeif debug:print("=== running algorithm ===")start_time = time.time()solx, soly = boneh_durfee(pol, e, m, t, X, Y)# found a solution?if solx > 0:print("=== solution found ===")if False:print("x:", solx)print("y:", soly)d = int(pol(solx, soly) / e)print("private key found:", d)else:print("=== no solution was found ===")if debug:print(("=== %s seconds ===" % (time.time() - start_time)))if __name__ == "__main__":example()

计算得到d
在这里插入图片描述

d = 663822343397699728953336968317794118491145998032244266550694156830036498673227937

最后RSA解密得到flag

#sage
c = 6838759631922176040297411386959306230064807618456930982742841698524622016849807235726065272136043603027166249075560058232683230155346614429566511309977857815138004298815137913729662337535371277019856193898546849896085411001528569293727010020290576888205244471943227253000727727343731590226737192613447347860
d = 663822343397699728953336968317794118491145998032244266550694156830036498673227937
n = 116518679305515263290840706715579691213922169271634579327519562902613543582623449606741546472920401997930041388553141909069487589461948798111698856100819163407893673249162209631978914843896272256274862501461321020961958367098759183487116417487922645782638510876609728886007680825340200888068103951956139343723
m = pow(c,d,n)
flag = bytes.fromhex(hex(m)[2:])
print(flag)
#DASCTF{6f4fadce-5378-d17f-3c2d-2e064db4af19}

决赛

JIGE

题目:

from gmpy2 import *
from hashlib import md5
from Crypto.Util.number import *
from sympy import *message=XXXXXX
flag = 'DASCTF{'+md5(message).hexdigest()+'}'
p = getPrime(256)
q = getPrime(256)
assert p > q
n = p * q
e = 0x10001  #65537
m = bytes_to_long(message)
c = pow(m, e, n)N = pow(p, 11) * q
d1 = getPrime(2000)
d2 = nextprime(d1 + getPrime(1000))
e1 = invert(d1, (pow(p, 10) * (p - 1) * (q - 1)))
e2 = invert(d2, (pow(p, 10) * (p - 1) * (q - 1)))print(f'c = {c}')
print(f'N = {N}')
print(f'e1 = {e1}')
print(f'e2 = {e2}')'''
c = 1206807362850301500412872994631699583002892289904471476523412128137773618173466272359196256671175708216503443050872032061782739223138420055283507423416014
N = 2769972268494457422626756881035680365791374852650158574600757210295514312723202376005992652087072745127197622954236101990451854162917559723722518981897097628959272185981219794883530767584841881112435651621934537571083225349949311621207409183741363444346000402562578450456645711882560128619242711698327278980081266684521150227771637075686195050487818614035674633610096137625035790732645845723462391311298302637686542232835581871746884130013070996968184596449672622781116306181302392813217024411730226953994648038878074679828551669837254152265441513617958229372943240214088399450834487541147274643124286983672414825675492669859487862886608989862491581277404219285561282275675102529309186029976081969486912697417132568798720377963032348920342675126756050513673101405664709184620104181654397512121633023592966498206439167017063802120497727043888826589401745202319033829767714724756122673441156732069183201569766204472097988081541
e1 = 2019789551019093124420297272384567741634310853673511749178611164072776295834811119450621861426097251426338761387400947669712980885171825246712129400923345045714062211913328737569990247227840399725205366257333392335095407072561983345874628219982166479392648454069496646733709717240335264301129096508037181465890164627276692696540046415077712807666335629672257696160380799064676194674815656129599632459744438651570247278542393673849808278202966914757001771181720554604666343205509941102540930522715083963211556704973593626830060515529201025992233193710032293801887064920491994892731059564016729184073592209700547810374523193198684464611594086849851216947777536116800375704509948170375971236541467019409313469504630988967011023280553412399918851721362010464793913169072750314771104456079550196999871385309352503595586614818585704007635869697001268017638044593755012233245211072647051603150602669710674109645174749520576295708163
e2 = 1583703592049684873685114339953437401553059969077370065722292597953883761416746559834892164581234164438330080827740800363198430396478731634782581595240544469072569584848085012992026166904750154014378216852052182115039653650262042887676171319128137818446568464062868113062233139620367603439600244722942659267734053620937005194939432606278744697609503707934576549002757520737074102321078418822923889399221127593632747782118004212766847803779185975309956970980280169387201657554918144244843463689062591309308003163435148432749203807727111886042271473627935482161154494976464303547129663586810973936239964669196142557977332701367619795730332662446023712262922190841226239360097490311533265953167562594634954870494720064733019963379137130620318351648747992348207245430288065933286523588168735037017481803349125024025183996822657547245651094947702268545834292593852409172743667084611813423926836813703374530071303810930647531379459
'''

考察论文New attacks on RSA with Moduli N = p^rq
在这里插入图片描述
根据论文,可以构建如下多项式
e 1 e 2 ( d 1 − d 2 ) ≡ e 2 − e 1 m o d ϕ ( n ) e_1e_2(d_1-d_2) \equiv e_2-e_1 \space mod \space \phi(n) e1e2(d1d2)e2e1 mod ϕ(n)
因为 ϕ ( n ) = p r − 1 ( p − 1 ) ( q − 1 ) \phi(n) = p^{r-1}(p-1)(q-1) ϕ(n)=pr1(p1)(q1),所以上式子可以变为
e 1 e 2 x − ( e 2 − e 1 ) ≡ 0 m o d p r − 1 e_1e_2x-(e_2-e_1) \equiv0 \space mod \space p^{r-1} e1e2x(e2e1)0 mod pr1
∣ d 1 − d 2 ∣ < n r ( r − 1 ) ( r + 1 ) 2 |d_1-d_2|<n^\frac{r(r-1)}{(r+1)^2} d1d2<n(r+1)2r(r1)时,在多项式时间内可解
copper出x,也就是d1-d2
计算 g c d ( e 1 e 2 x − ( e 2 − e 1 ) , n ) = g c d ( y × p r − 1 ( p − 1 ) ( q − 1 ) , p r q ) = g gcd(e_1e_2x-(e_2-e_1),n) = gcd(y\times p^{r-1}(p-1)(q-1),p^rq) = g gcd(e1e2x(e2e1),n)=gcd(y×pr1(p1)(q1),prq)=g
p的值按如下情况取
w h e n g = p r − 1 , p = g 1 r − 1 ( 1 ) when \space g = p^{r-1},p = g^{\frac{1}{r-1}} \hspace {2cm} (1) when g=pr1,p=gr11(1)
w h e n g = p r , p = g 1 r ( 2 ) when \space g = p^{r},p = g^{\frac{1}{r}} \hspace {2.5cm} (2) when g=pr,p=gr1(2)
w h e n g = p r − 1 q , p = n g ( 3 ) when \space g = p^{r-1}q,p = \frac{n}{g} \hspace {2.1cm} (3) when g=pr1q,p=gn(3)

在本题中,我们得到的g为2560bit,p为256bit,那么 g = p 11 − 1 = p 10 g = p^{11-1} = p^{10} g=p111=p10
直接开10次方得到p,进而q = n//p^11,最后RSA解密再计算明文的md5摘要即可获得flag
exp:

#sage  
import gmpy2
from hashlib import *c = 1206807362850301500412872994631699583002892289904471476523412128137773618173466272359196256671175708216503443050872032061782739223138420055283507423416014
n = 2769972268494457422626756881035680365791374852650158574600757210295514312723202376005992652087072745127197622954236101990451854162917559723722518981897097628959272185981219794883530767584841881112435651621934537571083225349949311621207409183741363444346000402562578450456645711882560128619242711698327278980081266684521150227771637075686195050487818614035674633610096137625035790732645845723462391311298302637686542232835581871746884130013070996968184596449672622781116306181302392813217024411730226953994648038878074679828551669837254152265441513617958229372943240214088399450834487541147274643124286983672414825675492669859487862886608989862491581277404219285561282275675102529309186029976081969486912697417132568798720377963032348920342675126756050513673101405664709184620104181654397512121633023592966498206439167017063802120497727043888826589401745202319033829767714724756122673441156732069183201569766204472097988081541
e1 = 2019789551019093124420297272384567741634310853673511749178611164072776295834811119450621861426097251426338761387400947669712980885171825246712129400923345045714062211913328737569990247227840399725205366257333392335095407072561983345874628219982166479392648454069496646733709717240335264301129096508037181465890164627276692696540046415077712807666335629672257696160380799064676194674815656129599632459744438651570247278542393673849808278202966914757001771181720554604666343205509941102540930522715083963211556704973593626830060515529201025992233193710032293801887064920491994892731059564016729184073592209700547810374523193198684464611594086849851216947777536116800375704509948170375971236541467019409313469504630988967011023280553412399918851721362010464793913169072750314771104456079550196999871385309352503595586614818585704007635869697001268017638044593755012233245211072647051603150602669710674109645174749520576295708163
e2 = 1583703592049684873685114339953437401553059969077370065722292597953883761416746559834892164581234164438330080827740800363198430396478731634782581595240544469072569584848085012992026166904750154014378216852052182115039653650262042887676171319128137818446568464062868113062233139620367603439600244722942659267734053620937005194939432606278744697609503707934576549002757520737074102321078418822923889399221127593632747782118004212766847803779185975309956970980280169387201657554918144244843463689062591309308003163435148432749203807727111886042271473627935482161154494976464303547129663586810973936239964669196142557977332701367619795730332662446023712262922190841226239360097490311533265953167562594634954870494720064733019963379137130620318351648747992348207245430288065933286523588168735037017481803349125024025183996822657547245651094947702268545834292593852409172743667084611813423926836813703374530071303810930647531379459
e = 65537
a = e1 * e2
b = (e2 - e1)
R.<x> = PolynomialRing(Zmod(n))
f = a*x - b
f = f.monic()
res =  f.small_roots(2^2000,beta = 0.4)	
ans = int(res[0])
tmp = GCD(a*ans - b,n)
p  = gmpy2.iroot(tmp,10)[0]
q = n//(p**11)
phi = (p-1)*(q-1)
d = inverse_mod(e,phi)
m = pow(c,d,p*q)
plain = bytes.fromhex(hex(m)[2:])
#YOU MUST BE A XIAOHEIZI
flag = 'DASCTF{'+md5(plain).hexdigest()+'}'
print(flag)
#DASCTF{4ed94d288633e880f9d8a53039247805}

【世上伤病千百种,情伤病入膏肓,心病无药可救。】

相关文章:

2023 楚慧杯 --- Crypto wp

文章目录 初赛so large e 决赛JIGE 初赛 so large e 题目&#xff1a; from Crypto.Util.number import * from Crypto.PublicKey import RSA from flag import flag import randomm bytes_to_long(flag)p getPrime(512) q getPrime(512) n p*q e random.getrandbits(1…...

Python+OpenCV 零基础学习笔记(1-3):anaconda+vscode+jupyter环境配置

文章目录 前言相关链接环境配置&#xff1a;AnacondaPython配置OpenCVOpencv-contrib:Opencv扩展 Notebook:python代码笔记vscode配置配置AnacondaJupyter文件导出 前言 作为一个C# 上位机&#xff0c;我认为上位机的终点就是机器视觉运动控制。最近学了会Halcon发现机器视觉还…...

Spring Cloud Gateway 常见过滤器的基本使用

目录 1. 过滤器的作用 2. Spring Cloud Gateway 过滤器的类型 2.1 内置过滤器 2.1.1 AddResponseHeader 2.1.2 AddRequestHeader 2.1.3 PrefixPath 2.1.4 RequestRateLimiter 2.1.5 Retry 2.2 自定义过滤器 1. 过滤器的作用 过滤器通常用于拦截、处理或修改数据流和事…...

maven依赖无法传递问题排查

一、背景 在A模块中引入B模块&#xff0c;C服务引入A模块但是B模块没有传递进来。 二、排查 使用mvn clean install -Dmaven.test.skiptrue查看打包日志信息&#xff0c;通过搜索A模块名称&#xff0c;出现如下警告信息&#xff1a; [WARING] The POM for A:jar:0.0.1-SNAP…...

JVM钩子

JVM钩子 简介 在Java应用程序中&#xff0c;可以通过注册关闭钩子&#xff08;Shutdown Hook&#xff09;函数来实现在JVM关闭时执行特定的代码。关闭钩子是一种用于在JVM关闭时执行清理任务的机制&#xff0c;它允许开发者在JVM关闭之前执行一些必要的清理工作&#xff0c;如…...

linux cat命令增加-f显示文件名功能

在使用cat命令配合grep批量搜索文件内容时&#xff0c;我仅仅能知道是否搜索到&#xff0c;不知道是在哪个文件里找到的。比如cat ./src/*.c | grep full_write,在src目录下的所有.c文件里找full_write,能匹配到所有的full_write&#xff0c;但是不知道它们分别在哪些文件里。于…...

linux更改登录shell

从bash修改成python 在/etc/passwd下可以更改用户登录bash 例 root:x:0:0:root:/root:/bin/bash //更改bin/bash为/bin/python&#xff0c;就可以用root登录python页面了从python修改成bash 方法一 重启页面按e进入内核编辑模式linux16这行后添加&#xff1a;init/bin/…...

【JS】报错:Uncaught TypeError: Cannot read properties of null (reading ‘classList‘)

错误展示 今天写js代码的时候遇到报错&#xff1a; 源代码&#xff1a; <ul class"slider-indicator"><li class"active"></li><li></li><li></li><li></li><li></li><li><…...

kali2.0安装VMware Tools 和自定义改变分辨率

kali2.0安装VMware Tools 和自定义改变分辨率 VMware Tools 简介&#xff1a;VMware Tools安装&#xff1a;自定义改变分辨率&#xff1a;xrandr命令修改分辨率&#xff1a; 前言&#xff1a; 因为kali2.0比较老 所以需要手动安装 WMware Tools 进行复制粘贴操作&#xff01; …...

redis中根据通配符删除key

redis中根据通配符删除key 我们是不是在redis中keys user:*可以获取所有key&#xff0c;但是 del user:*却不行这里我提供的命令主要是SCANSCAN 0 MATCH user:* COUNT 100使用lua保证原子性 SCAN参数描述 在示例中&#xff0c;COUNT 被设置为 100。这是一个防止一次性获取大…...

【HDFS联邦(2)】HDFS Router-based Federation官网解读:HDFSRouterFederation的架构、各组件基本原理

文章目录 一. 介绍二、HDFS Router-based Federation 架构1. 示例说明2. Router2.1. Federated interface2.2. Router heartbeat2.3. NameNode heartbeat2.4. Availability and fault toleranceInterfaces 3. Quota management4. State Store 三、部署 ing 本文主要参考官网&am…...

【头歌实训】Spark 完全分布式的安装和部署

文章目录 第1关&#xff1a; Standalone 分布式集群搭建任务描述相关知识课程视频Spark分布式安装模式示例集群信息配置免密登录准备Spark安装包配置环境变量修改 spark-env.sh 配置文件修改 slaves 文件分发安装包启动spark验证安装 编程要求测试说明答案代码报错问题基本过程…...

Leetcode—86.分隔链表【中等】

2023每日刷题&#xff08;六十九&#xff09; Leetcode—86.分隔链表 实现代码 /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/ struct ListNode* partition(struct ListNode* head, int x) {struct ListNode…...

淘宝/天猫商品API:实时数据获取与安全隐私保护的指南

一、引言 随着电子商务的快速发展&#xff0c;淘宝/天猫等电商平台已成为商家和消费者的重要交易场所。对于电商企业而言&#xff0c;实时掌握店铺商品的销售情况、库存状态等信息至关重要。然而&#xff0c;手动管理和更新商品信息既费时又费力。因此&#xff0c;淘宝/天猫提…...

使用 SSH 方式实现 Git 远程连接GitHub

git是目前世界上最先进的分布式版本控制系统&#xff0c;相比于SVN&#xff0c;分布式版本系统的最大好处之一是在本地工作完全不需要考虑远程库的存在&#xff0c;也就是有没有联网都可以正常工作&#xff01;当有网络的时候&#xff0c;再把本地提交推送一下就完成了同步&…...

Centos7部署Keepalived+lvs服务

IP规划&#xff1a; 服务器IP地址主服务器20.0.0.22/24从服务器20.0.0.24/24Web-120.0.0.26/24Web-220.0.0.27/24 一、主服务器安装部署keepalivedlvs服务 1、调整/proc响应参数 关闭Linux内核的重定向参数&#xff0c;因为LVS负载服务器和两个页面服务器需要共用一个VIP地…...

12/31

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 摘要Abstract文献阅读&#xff1a;用于密集预测的多路径视觉Transformer1、研究背景2、方法提出3、相关方法3.1、Vision Transformers for dense predictions3.2、C…...

python使用openpyxl为excel模版填充数据,生成多个Sheet页面

目标&#xff1a;希望根据一个给定的excel模版&#xff0c;生成多个Sheet页面&#xff0c;比如模版&#xff1a; 示例程序 import openpyxlexcel_workbook openpyxl.load_workbook("模版.xlsx") for _i in range(3): # 比如填充3个页面# 复制模版sheet页&#x…...

基于ssm的4S店预约保养系统开发+vue论文

目 录 目 录 I 摘 要 III ABSTRACT IV 1 绪论 1 1.1 课题背景 1 1.2 研究现状 1 1.3 研究内容 2 2 系统开发环境 3 2.1 vue技术 3 2.2 JAVA技术 3 2.3 MYSQL数据库 3 2.4 B/S结构 4 2.5 SSM框架技术 4 3 系统分析 5 3.1 可行性分析 5 3.1.1 技术可行性 5 3.1.2 操作可行性 5 3…...

【Git】Git的基本操作

前言 Git是当前最主流的版本管理器&#xff0c;它可以控制电脑上的所有格式的文件。 它对于开发人员&#xff0c;可以管理项目中的源代码文档。&#xff08;可以记录不同提交的修改细节&#xff0c;并且任意跳转版本&#xff09; 本篇博客基于最近对Git的学习&#xff0c;简单介…...

业务系统对接大模型的基础方案:架构设计与关键步骤

业务系统对接大模型&#xff1a;架构设计与关键步骤 在当今数字化转型的浪潮中&#xff0c;大语言模型&#xff08;LLM&#xff09;已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中&#xff0c;不仅可以优化用户体验&#xff0c;还能为业务决策提供…...

linux之kylin系统nginx的安装

一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源&#xff08;HTML/CSS/图片等&#xff09;&#xff0c;响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址&#xff0c;提高安全性 3.负载均衡服务器 支持多种策略分发流量…...

k8s从入门到放弃之Ingress七层负载

k8s从入门到放弃之Ingress七层负载 在Kubernetes&#xff08;简称K8s&#xff09;中&#xff0c;Ingress是一个API对象&#xff0c;它允许你定义如何从集群外部访问集群内部的服务。Ingress可以提供负载均衡、SSL终结和基于名称的虚拟主机等功能。通过Ingress&#xff0c;你可…...

Qt Widget类解析与代码注释

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码&#xff0c;写上注释 当然可以&#xff01;这段代码是 Qt …...

【算法训练营Day07】字符串part1

文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接&#xff1a;344. 反转字符串 双指针法&#xff0c;两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...

【git】把本地更改提交远程新分支feature_g

创建并切换新分支 git checkout -b feature_g 添加并提交更改 git add . git commit -m “实现图片上传功能” 推送到远程 git push -u origin feature_g...

土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等

&#x1f50d; 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术&#xff0c;可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势&#xff0c;还能有效评价重大生态工程…...

《基于Apache Flink的流处理》笔记

思维导图 1-3 章 4-7章 8-11 章 参考资料 源码&#xff1a; https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...

SpringCloudGateway 自定义局部过滤器

场景&#xff1a; 将所有请求转化为同一路径请求&#xff08;方便穿网配置&#xff09;在请求头内标识原来路径&#xff0c;然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...

聊一聊接口测试的意义有哪些?

目录 一、隔离性 & 早期测试 二、保障系统集成质量 三、验证业务逻辑的核心层 四、提升测试效率与覆盖度 五、系统稳定性的守护者 六、驱动团队协作与契约管理 七、性能与扩展性的前置评估 八、持续交付的核心支撑 接口测试的意义可以从四个维度展开&#xff0c;首…...