From 572cd70d9fc7baf4d86a633a3ab74c6d058a4de8 Mon Sep 17 00:00:00 2001 From: nsfisis Date: Sun, 19 Mar 2023 04:02:56 +0900 Subject: fix(content): fix XML notations --- .../phperkaigi-2023-unused-token-quiz-1.xml | 331 ++++++++++----------- 1 file changed, 162 insertions(+), 169 deletions(-) (limited to 'content/posts/2022-10-23') diff --git a/content/posts/2022-10-23/phperkaigi-2023-unused-token-quiz-1.xml b/content/posts/2022-10-23/phperkaigi-2023-unused-token-quiz-1.xml index f53d339..7bfbbd7 100644 --- a/content/posts/2022-10-23/phperkaigi-2023-unused-token-quiz-1.xml +++ b/content/posts/2022-10-23/phperkaigi-2023-unused-token-quiz-1.xml @@ -19,177 +19,170 @@
はじめに - 2023 年 3 月 23 日から 25 日にかけて開催予定 (記事執筆時点) - の、 PHPerKaigi 2023 - において、昨年と同様に、弊社 デジタルサーカス株式会社 - から、トークン問題を出題予定である。 - - - 昨年のトークン問題の記事はこちら: - PHPerKaigi 2022 - トークン問題の解説 - - - すでに 2023 - 年用の問題は作成済みであるが、その制作過程の中でいくつかボツ問ができた。せっかくなので、PHPerKaigi - 開催を待つ間に紹介しようと思う。 - - - 10 月から 2 月まで、毎月 1 記事ずつ公開していく予定 (忘れていなければ)。 - -
-
- 問題 - - 注意: これはボツ問なので、得られたトークンを PHPerKaigi - で入力してもポイントにはならない。 - - - PHPerKaigi 2023 において、 + 昨年と同様に、弊社 デジタルサーカス株式会社 から、 + トークン問題を出題予定である。 + + + 昨年のトークン問題の記事はこちら: PHPerKaigi 2022 トークン問題の解説 + + + すでに 2023 年用の問題は作成済みであるが、その制作過程の中でいくつかボツ問ができた。 + せっかくなので、PHPerKaigi 開催を待つ間に紹介しようと思う。 + + + 10 月から 2 月まで、毎月 1 記事ずつ公開していく予定 (忘れていなければ)。 + +
+
+ 問題 + + 注意: これはボツ問なので、得られたトークンを PHPerKaigi で入力してもポイントにはならない。 + + + - -
-
- トークン入手方法 - - ソースを見るとわかるとおり、$argv[1] を参照している。それを - なる変数に代入しているので、円周率を渡してみる。 - - - - - - 失敗してしまった。精度を上げてみる。 - - - - - - だめだった。これを成功するまで繰り返す。 - - - 最初にトークンが得られるのは、小数点以下 16 - 桁目まで入力したときで、こうなる。 - - - - - - めでたくトークン「#YO」が手に入った。 - -
-
- 解説 - - 短いので頭から追っていく。 - - - - - - 入力のバリデーション部分。数値のみ受け付ける。 - - - - - - を 2 文字ごとに区切り (str_split)、数値を ASCII - コードと見做して文字に変換 (chr) して結合 (implode) している。 - - - 例えば、'656667' だったとすると、656667 に対応した - 'A''B''C' へと変換され、'ABC' になる。 - - - ABC - ]]> - - - - - - 正規表現でマッチングしている。\x23# - と同じであることに留意すると、この正規表現は「# から始まる 2 - 以上の長さ (含 #) - の文字列で、最初に現れるスペースまで」にマッチする。つまりこれは、PHPerKaigi - におけるトークンである。 - - - なお、# を直接書いていないのは、/#.+?) / と書くと、#.+?) - という意図せぬトークンが登録されてしまうからである。 - - - - - - 最後にトークンのハッシュ値を見て、想定解かどうかを確認する。 - -
-
- おわりに - - 円周率を何桁も計算して ASCII - コード経由で文字列化すれば、トークンっぽいものがどこかで出てくるのではないか、と考えて生まれた作品。 - - - 最初は真面目に円周率の計算プログラムを組んでいたのだが、いざ動かしてみるとやけに浅いところにあったので驚いた - (ちなみに、それでも M_PIpi() - では精度が足りない)。見つけたときは狂喜したものの、冷静になってみると大して面白くなかったのでボツになった。むしろ、100 - 万桁目くらいに埋まっていてくれたほうがよかったかもしれない。 - -
+ if (md5($t) === '056e831a4146bf123e8ea16613303d2e') { + echo "Token: {$t}\n"; + } else { + echo "Failed.\n"; + } + ]]> + + +
+ トークン入手方法 + + ソースを見るとわかるとおり、$argv[1] を参照している。 + それを なる変数に代入しているので、円周率を渡してみる。 + + + + + + 失敗してしまった。精度を上げてみる。 + + + + + + だめだった。これを成功するまで繰り返す。 + + + 最初にトークンが得られるのは、小数点以下 16 桁目まで入力したときで、こうなる。 + + + + + + めでたくトークン「#YO」が手に入った。 + +
+
+ 解説 + + 短いので頭から追っていく。 + + + + + + 入力のバリデーション部分。数値のみ受け付ける。 + + + + + + を 2 文字ごとに区切り (str_split)、 + 数値を ASCII コードと見做して文字に変換 (chr) して結合 (implode) している。 + + + 例えば、'656667' だったとすると、 + 656667 に対応した + 'A''B''C' へと変換され、'ABC' になる。 + + + ABC + ]]> + + + + + + 正規表現でマッチングしている。\x23# と同じであることに留意すると、 + この正規表現は「# から始まる 2 以上の長さ (含 #) の文字列で、 + 最初に現れるスペースまで」にマッチする。つまりこれは、PHPerKaigi におけるトークンである。 + + + なお、# を直接書いていないのは、/#.+?) / と書くと、 + #.+?) という意図せぬトークンが登録されてしまうからである。 + + + + + + 最後にトークンのハッシュ値を見て、想定解かどうかを確認する。 + +
+
+ おわりに + + 円周率を何桁も計算して ASCII コード経由で文字列化すれば、トークンっぽいものがどこかで出てくるのではないか、と考えて生まれた作品。 + + + 最初は真面目に円周率の計算プログラムを組んでいたのだが、いざ動かしてみるとやけに浅いところにあったので驚いた + (ちなみに、それでも M_PIpi() では精度が足りない)。 + 見つけたときは狂喜したものの、冷静になってみると大して面白くなかったのでボツになった。 + むしろ、100 万桁目くらいに埋まっていてくれたほうがよかったかもしれない。 + +
-- cgit v1.2.3-70-g09d2